summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSergio Garcia Murillo <sergio.garcia.murillo@gmail.com>2022-10-11 14:09:07 +0200
committerGitHub <noreply@github.com>2022-10-11 14:09:07 +0200
commitcdb0e498a1453be2c77ddd3a11ba658f97ce0500 (patch)
tree0530103b59b26a7a03a4d0e018fd008af2358202
parente38883636ec7b8868e0f25d84a951330de5f1354 (diff)
parent55d7a513436bc61cc1ac1017a9c732b5a11a3209 (diff)
downloadswig-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.js32
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)