summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/wasm/spec/gc/array_copy.wast.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /js/src/jit-test/tests/wasm/spec/gc/array_copy.wast.js
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/jit-test/tests/wasm/spec/gc/array_copy.wast.js')
-rw-r--r--js/src/jit-test/tests/wasm/spec/gc/array_copy.wast.js202
1 files changed, 202 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/wasm/spec/gc/array_copy.wast.js b/js/src/jit-test/tests/wasm/spec/gc/array_copy.wast.js
new file mode 100644
index 0000000000..0109df19e9
--- /dev/null
+++ b/js/src/jit-test/tests/wasm/spec/gc/array_copy.wast.js
@@ -0,0 +1,202 @@
+/* Copyright 2021 Mozilla Foundation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+// ./test/core/gc/array_copy.wast
+
+// ./test/core/gc/array_copy.wast:5
+assert_invalid(
+ () => instantiate(`(module
+ (type $$a (array i8))
+ (type $$b (array (mut i8)))
+
+ (func (export "array.copy-immutable") (param $$1 (ref $$a)) (param $$2 (ref $$b))
+ (array.copy $$a $$b (local.get $$1) (i32.const 0) (local.get $$2) (i32.const 0) (i32.const 0))
+ )
+ )`),
+ `array is immutable`,
+);
+
+// ./test/core/gc/array_copy.wast:17
+assert_invalid(
+ () => instantiate(`(module
+ (type $$a (array (mut i8)))
+ (type $$b (array i16))
+
+ (func (export "array.copy-packed-invalid") (param $$1 (ref $$a)) (param $$2 (ref $$b))
+ (array.copy $$a $$b (local.get $$1) (i32.const 0) (local.get $$2) (i32.const 0) (i32.const 0))
+ )
+ )`),
+ `array types do not match`,
+);
+
+// ./test/core/gc/array_copy.wast:29
+assert_invalid(
+ () => instantiate(`(module
+ (type $$a (array (mut i8)))
+ (type $$b (array (mut (ref $$a))))
+
+ (func (export "array.copy-ref-invalid-1") (param $$1 (ref $$a)) (param $$2 (ref $$b))
+ (array.copy $$a $$b (local.get $$1) (i32.const 0) (local.get $$2) (i32.const 0) (i32.const 0))
+ )
+ )`),
+ `array types do not match`,
+);
+
+// ./test/core/gc/array_copy.wast:41
+assert_invalid(
+ () => instantiate(`(module
+ (type $$a (array (mut i8)))
+ (type $$b (array (mut (ref $$a))))
+ (type $$c (array (mut (ref $$b))))
+
+ (func (export "array.copy-ref-invalid-1") (param $$1 (ref $$b)) (param $$2 (ref $$c))
+ (array.copy $$b $$c (local.get $$1) (i32.const 0) (local.get $$2) (i32.const 0) (i32.const 0))
+ )
+ )`),
+ `array types do not match`,
+);
+
+// ./test/core/gc/array_copy.wast:54
+let $0 = instantiate(`(module
+ (type $$arr8 (array i8))
+ (type $$arr8_mut (array (mut i8)))
+
+ (global $$g_arr8 (ref $$arr8) (array.new $$arr8 (i32.const 10) (i32.const 12)))
+ (global $$g_arr8_mut (mut (ref $$arr8_mut)) (array.new_default $$arr8_mut (i32.const 12)))
+
+ (data $$d1 "abcdefghijkl")
+
+ (func (export "array_get_nth") (param $$1 i32) (result i32)
+ (array.get_u $$arr8_mut (global.get $$g_arr8_mut) (local.get $$1))
+ )
+
+ (func (export "array_copy-null-left")
+ (array.copy $$arr8_mut $$arr8 (ref.null $$arr8_mut) (i32.const 0) (global.get $$g_arr8) (i32.const 0) (i32.const 0))
+ )
+
+ (func (export "array_copy-null-right")
+ (array.copy $$arr8_mut $$arr8 (global.get $$g_arr8_mut) (i32.const 0) (ref.null $$arr8) (i32.const 0) (i32.const 0))
+ )
+
+ (func (export "array_copy") (param $$1 i32) (param $$2 i32) (param $$3 i32)
+ (array.copy $$arr8_mut $$arr8 (global.get $$g_arr8_mut) (local.get $$1) (global.get $$g_arr8) (local.get $$2) (local.get $$3))
+ )
+
+ (func (export "array_copy_overlap_test-1")
+ (local $$1 (ref $$arr8_mut))
+ (array.new_data $$arr8_mut $$d1 (i32.const 0) (i32.const 12))
+ (local.set $$1)
+ (array.copy $$arr8_mut $$arr8_mut (local.get $$1) (i32.const 1) (local.get $$1) (i32.const 0) (i32.const 11))
+ (global.set $$g_arr8_mut (local.get $$1))
+ )
+
+ (func (export "array_copy_overlap_test-2")
+ (local $$1 (ref $$arr8_mut))
+ (array.new_data $$arr8_mut $$d1 (i32.const 0) (i32.const 12))
+ (local.set $$1)
+ (array.copy $$arr8_mut $$arr8_mut (local.get $$1) (i32.const 0) (local.get $$1) (i32.const 1) (i32.const 11))
+ (global.set $$g_arr8_mut (local.get $$1))
+ )
+)`);
+
+// ./test/core/gc/array_copy.wast:97
+assert_trap(() => invoke($0, `array_copy-null-left`, []), `null array reference`);
+
+// ./test/core/gc/array_copy.wast:98
+assert_trap(() => invoke($0, `array_copy-null-right`, []), `null array reference`);
+
+// ./test/core/gc/array_copy.wast:101
+assert_trap(() => invoke($0, `array_copy`, [13, 0, 0]), `out of bounds array access`);
+
+// ./test/core/gc/array_copy.wast:102
+assert_trap(() => invoke($0, `array_copy`, [0, 13, 0]), `out of bounds array access`);
+
+// ./test/core/gc/array_copy.wast:105
+assert_trap(() => invoke($0, `array_copy`, [0, 0, 13]), `out of bounds array access`);
+
+// ./test/core/gc/array_copy.wast:106
+assert_trap(() => invoke($0, `array_copy`, [0, 0, 13]), `out of bounds array access`);
+
+// ./test/core/gc/array_copy.wast:109
+assert_return(() => invoke($0, `array_copy`, [12, 0, 0]), []);
+
+// ./test/core/gc/array_copy.wast:110
+assert_return(() => invoke($0, `array_copy`, [0, 12, 0]), []);
+
+// ./test/core/gc/array_copy.wast:113
+assert_return(() => invoke($0, `array_get_nth`, [0]), [value("i32", 0)]);
+
+// ./test/core/gc/array_copy.wast:114
+assert_return(() => invoke($0, `array_get_nth`, [5]), [value("i32", 0)]);
+
+// ./test/core/gc/array_copy.wast:115
+assert_return(() => invoke($0, `array_get_nth`, [11]), [value("i32", 0)]);
+
+// ./test/core/gc/array_copy.wast:116
+assert_trap(() => invoke($0, `array_get_nth`, [12]), `out of bounds array access`);
+
+// ./test/core/gc/array_copy.wast:119
+assert_return(() => invoke($0, `array_copy`, [0, 0, 2]), []);
+
+// ./test/core/gc/array_copy.wast:120
+assert_return(() => invoke($0, `array_get_nth`, [0]), [value("i32", 10)]);
+
+// ./test/core/gc/array_copy.wast:121
+assert_return(() => invoke($0, `array_get_nth`, [1]), [value("i32", 10)]);
+
+// ./test/core/gc/array_copy.wast:122
+assert_return(() => invoke($0, `array_get_nth`, [2]), [value("i32", 0)]);
+
+// ./test/core/gc/array_copy.wast:125
+assert_return(() => invoke($0, `array_copy_overlap_test-1`, []), []);
+
+// ./test/core/gc/array_copy.wast:126
+assert_return(() => invoke($0, `array_get_nth`, [0]), [value("i32", 97)]);
+
+// ./test/core/gc/array_copy.wast:127
+assert_return(() => invoke($0, `array_get_nth`, [1]), [value("i32", 97)]);
+
+// ./test/core/gc/array_copy.wast:128
+assert_return(() => invoke($0, `array_get_nth`, [2]), [value("i32", 98)]);
+
+// ./test/core/gc/array_copy.wast:129
+assert_return(() => invoke($0, `array_get_nth`, [5]), [value("i32", 101)]);
+
+// ./test/core/gc/array_copy.wast:130
+assert_return(() => invoke($0, `array_get_nth`, [10]), [value("i32", 106)]);
+
+// ./test/core/gc/array_copy.wast:131
+assert_return(() => invoke($0, `array_get_nth`, [11]), [value("i32", 107)]);
+
+// ./test/core/gc/array_copy.wast:133
+assert_return(() => invoke($0, `array_copy_overlap_test-2`, []), []);
+
+// ./test/core/gc/array_copy.wast:134
+assert_return(() => invoke($0, `array_get_nth`, [0]), [value("i32", 98)]);
+
+// ./test/core/gc/array_copy.wast:135
+assert_return(() => invoke($0, `array_get_nth`, [1]), [value("i32", 99)]);
+
+// ./test/core/gc/array_copy.wast:136
+assert_return(() => invoke($0, `array_get_nth`, [5]), [value("i32", 103)]);
+
+// ./test/core/gc/array_copy.wast:137
+assert_return(() => invoke($0, `array_get_nth`, [9]), [value("i32", 107)]);
+
+// ./test/core/gc/array_copy.wast:138
+assert_return(() => invoke($0, `array_get_nth`, [10]), [value("i32", 108)]);
+
+// ./test/core/gc/array_copy.wast:139
+assert_return(() => invoke($0, `array_get_nth`, [11]), [value("i32", 108)]);