skip tests when value is out of range
This commit is contained in:
parent
cf7733e4b8
commit
5b02dc93d6
1 changed files with 12 additions and 6 deletions
|
|
@ -1,16 +1,22 @@
|
||||||
var integers = require("integers");
|
var integers = require("integers");
|
||||||
|
|
||||||
function checkOne(val, fn) {
|
function checkOne(val, signed, typeName) {
|
||||||
ret = fn(val)
|
typeName = (signed ? 'signed_' : 'unsigned_') + typeName
|
||||||
|
|
||||||
|
var size = integers[typeName + '_size']()
|
||||||
|
if ((!signed && val < 0) || (size < 8))
|
||||||
|
return // out of range, skip test
|
||||||
|
|
||||||
|
ret = integers[typeName + '_identity'](val)
|
||||||
if (ret !== val)
|
if (ret !== val)
|
||||||
throw "Incorrect value: expected " + val + ", got " + ret
|
throw "Incorrect value: expected " + val + ", got " + ret
|
||||||
}
|
}
|
||||||
|
|
||||||
function checkAll(val) {
|
function checkAll(val) {
|
||||||
checkOne(val, integers.signed_long_identity)
|
checkOne(val, true, 'long')
|
||||||
checkOne(val, integers.unsigned_long_identity)
|
checkOne(val, false, 'long')
|
||||||
checkOne(val, integers.signed_long_long_identity)
|
checkOne(val, true, 'long_long')
|
||||||
checkOne(val, integers.unsigned_long_long_identity)
|
checkOne(val, false, 'long_long')
|
||||||
}
|
}
|
||||||
|
|
||||||
checkAll(3902408827)
|
checkAll(3902408827)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue