diff options
author | Sergio Garcia Murillo <sergio.garcia.murillo@gmail.com> | 2022-10-11 14:09:07 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-10-11 14:09:07 +0200 |
commit | cdb0e498a1453be2c77ddd3a11ba658f97ce0500 (patch) | |
tree | 0530103b59b26a7a03a4d0e018fd008af2358202 | |
parent | e38883636ec7b8868e0f25d84a951330de5f1354 (diff) | |
parent | 55d7a513436bc61cc1ac1017a9c732b5a11a3209 (diff) | |
download | swig-cdb0e498a1453be2c77ddd3a11ba658f97ce0500.tar.gz |
Merge pull request #2 from mildsunrise/fix-cast
expand testcase to test for new casting behavior
-rw-r--r-- | Examples/test-suite/javascript/integers_runme.js | 32 |
1 files changed, 19 insertions, 13 deletions
diff --git a/Examples/test-suite/javascript/integers_runme.js b/Examples/test-suite/javascript/integers_runme.js index 0356176ad..4aeb13d7a 100644 --- a/Examples/test-suite/javascript/integers_runme.js +++ b/Examples/test-suite/javascript/integers_runme.js @@ -1,18 +1,24 @@ var integers = require("integers"); -var val = 3902408827 -ret = integers.signed_long_identity(val) -if (ret != val) - throw "Incorrect value: " + ret +function checkOne(val, signed, typeName) { + typeName = (signed ? 'signed_' : 'unsigned_') + typeName -ret = integers.unsigned_long_identity(val) -if (ret != val) - throw "Incorrect value: " + ret + var size = integers[typeName + '_size']() + if ((!signed && val < 0) || (size < 8)) + return // out of range, skip test -ret = integers.signed_long_long_identity(val) -if (ret != val) - throw "Incorrect value: " + ret + ret = integers[typeName + '_identity'](val) + if (ret !== val) + throw "Incorrect value: expected " + val + ", got " + ret +} -ret = integers.unsigned_long_long_identity(val) -if (ret != val) - throw "Incorrect value: " + ret +function checkAll(val) { + checkOne(val, true, 'long') + checkOne(val, false, 'long') + checkOne(val, true, 'long_long') + checkOne(val, false, 'long_long') +} + +checkAll(3902408827) +checkAll(Number.MAX_SAFE_INTEGER) +checkAll(Number.MIN_SAFE_INTEGER) |