summaryrefslogtreecommitdiffstats
path: root/vendor/js-sys/tests/wasm/BigInt.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 12:41:41 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 12:41:41 +0000
commit10ee2acdd26a7f1298c6f6d6b7af9b469fe29b87 (patch)
treebdffd5d80c26cf4a7a518281a204be1ace85b4c1 /vendor/js-sys/tests/wasm/BigInt.rs
parentReleasing progress-linux version 1.70.0+dfsg1-9~progress7.99u1. (diff)
downloadrustc-10ee2acdd26a7f1298c6f6d6b7af9b469fe29b87.tar.xz
rustc-10ee2acdd26a7f1298c6f6d6b7af9b469fe29b87.zip
Merging upstream version 1.70.0+dfsg2.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'vendor/js-sys/tests/wasm/BigInt.rs')
-rw-r--r--vendor/js-sys/tests/wasm/BigInt.rs43
1 files changed, 43 insertions, 0 deletions
diff --git a/vendor/js-sys/tests/wasm/BigInt.rs b/vendor/js-sys/tests/wasm/BigInt.rs
new file mode 100644
index 000000000..a9cd30dfb
--- /dev/null
+++ b/vendor/js-sys/tests/wasm/BigInt.rs
@@ -0,0 +1,43 @@
+use js_sys::BigInt;
+use wasm_bindgen::prelude::*;
+use wasm_bindgen_test::wasm_bindgen_test;
+
+/// `assert_eq!`, but the arguments are converted to `JsValue`s.
+#[track_caller]
+fn assert_jsvalue_eq(a: impl Into<JsValue>, b: impl Into<JsValue>) {
+ assert_eq!(a.into(), b.into());
+}
+
+#[wasm_bindgen_test]
+fn from() {
+ // Test that all the `From` impls work properly.
+ assert_jsvalue_eq(BigInt::from(1u8), 1u64);
+ assert_jsvalue_eq(BigInt::from(1u16), 1u64);
+ assert_jsvalue_eq(BigInt::from(1u32), 1u64);
+ assert_jsvalue_eq(BigInt::from(1u64), 1u64);
+ assert_jsvalue_eq(BigInt::from(1u128), 1u64);
+ assert_jsvalue_eq(BigInt::from(1usize), 1u64);
+ assert_jsvalue_eq(BigInt::from(-3i8), -3i64);
+ assert_jsvalue_eq(BigInt::from(-3i16), -3i64);
+ assert_jsvalue_eq(BigInt::from(-3i32), -3i64);
+ assert_jsvalue_eq(BigInt::from(-3i64), -3i64);
+ assert_jsvalue_eq(BigInt::from(-3i128), -3i64);
+ assert_jsvalue_eq(BigInt::from(-3isize), -3i64);
+}
+
+#[wasm_bindgen_test]
+fn eq() {
+ // Test that all the `Eq` impls work properly.
+ assert_eq!(BigInt::from(1u64), 1u8);
+ assert_eq!(BigInt::from(1u64), 1u16);
+ assert_eq!(BigInt::from(1u64), 1u32);
+ assert_eq!(BigInt::from(1u64), 1u64);
+ assert_eq!(BigInt::from(1u64), 1u128);
+ assert_eq!(BigInt::from(1u64), 1usize);
+ assert_eq!(BigInt::from(-3i64), -3i8);
+ assert_eq!(BigInt::from(-3i64), -3i16);
+ assert_eq!(BigInt::from(-3i64), -3i32);
+ assert_eq!(BigInt::from(-3i64), -3i64);
+ assert_eq!(BigInt::from(-3i64), -3i128);
+ assert_eq!(BigInt::from(-3i64), -3isize);
+}