summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorThomas Lively <tlively@google.com>2024-08-20 17:16:44 -0700
committerGitHub <noreply@github.com>2024-08-20 17:16:44 -0700
commit435eeead73cf02a6fb5bc7d7a36dd45b8d700cb2 (patch)
treed079d92a6d934175d6f1b276deb0ef78d14d058b /scripts
parent340ad71810484c279b1a36a9a7e458c9b18855b9 (diff)
downloadbinaryen-435eeead73cf02a6fb5bc7d7a36dd45b8d700cb2.tar.gz
binaryen-435eeead73cf02a6fb5bc7d7a36dd45b8d700cb2.tar.bz2
binaryen-435eeead73cf02a6fb5bc7d7a36dd45b8d700cb2.zip
Add the upstream spec testsuite as a submodule (#6853)
Run the upstream tests by default, except for a large list of them that do not successfully run. Remove the local version of those that do successfully run where the local version is entirely subsumed by the upstream version.
Diffstat (limited to 'scripts')
-rw-r--r--scripts/test/shared.py96
-rw-r--r--scripts/test/wasm2js.py9
2 files changed, 99 insertions, 6 deletions
diff --git a/scripts/test/shared.py b/scripts/test/shared.py
index 91612a8d9..08aebcdd3 100644
--- a/scripts/test/shared.py
+++ b/scripts/test/shared.py
@@ -386,7 +386,7 @@ def get_tests(test_dir, extensions=[], recursive=False):
if options.spec_tests:
options.spec_tests = [os.path.abspath(t) for t in options.spec_tests]
else:
- options.spec_tests = get_tests(get_test_dir('spec'), ['.wast'])
+ options.spec_tests = get_tests(get_test_dir('spec'), ['.wast'], recursive=True)
os.chdir(options.out_dir)
@@ -411,12 +411,102 @@ SPEC_TESTS_TO_SKIP = [
# Test invalid
'elem.wast',
]
+SPEC_TESTSUITE_TESTS_TO_SKIP = [
+ 'address.wast',
+ 'align.wast',
+ 'binary-leb128.wast',
+ 'binary.wast',
+ 'block.wast',
+ 'br_table.wast',
+ 'bulk.wast',
+ 'comments.wast',
+ 'const.wast',
+ 'conversions.wast',
+ 'data.wast',
+ 'elem.wast',
+ 'f32.wast',
+ 'f64.wast',
+ 'fac.wast',
+ 'float_exprs.wast',
+ 'float_misc.wast',
+ 'func.wast',
+ 'global.wast',
+ 'if.wast',
+ 'imports.wast',
+ 'linking.wast',
+ 'loop.wast',
+ 'memory.wast',
+ 'annotations.wast',
+ 'id.wast',
+ 'throw.wast',
+ 'try_catch.wast',
+ 'tag.wast',
+ 'throw_ref.wast',
+ 'try_table.wast',
+ 'br_on_non_null.wast',
+ 'br_on_null.wast',
+ 'local_init.wast',
+ 'ref_func.wast',
+ 'ref_is_null.wast',
+ 'ref_null.wast',
+ 'return_call_indirect.wast',
+ 'select.wast',
+ 'table.wast',
+ 'type-equivalence.wast',
+ 'unreached-invalid.wast',
+ 'array.wast',
+ 'array_init_elem.wast',
+ 'br_if.wast',
+ 'br_on_cast.wast',
+ 'br_on_cast_fail.wast',
+ 'extern.wast',
+ 'i31.wast',
+ 'ref_cast.wast',
+ 'ref_test.wast',
+ 'struct.wast',
+ 'type-rec.wast',
+ 'type-subtyping.wast',
+ 'call_indirect.wast',
+ 'memory64.wast',
+ 'table_fill.wast',
+ 'table_get.wast',
+ 'table_grow.wast',
+ 'table_init.wast',
+ 'table_set.wast',
+ 'imports0.wast',
+ 'imports2.wast',
+ 'imports3.wast',
+ 'linking0.wast',
+ 'linking3.wast',
+ 'i16x8_relaxed_q15mulr_s.wast',
+ 'i32x4_relaxed_trunc.wast',
+ 'i8x16_relaxed_swizzle.wast',
+ 'relaxed_dot_product.wast',
+ 'relaxed_laneselect.wast',
+ 'relaxed_madd_nmadd.wast',
+ 'relaxed_min_max.wast',
+ 'simd_address.wast',
+ 'simd_boolean.wast',
+ 'simd_const.wast',
+ 'simd_conversions.wast',
+ 'simd_f32x4.wast',
+ 'simd_f32x4_arith.wast',
+ 'simd_f32x4_rounding.wast',
+ 'simd_f64x2.wast',
+ 'simd_f64x2_arith.wast',
+ 'simd_f64x2_rounding.wast',
+ 'simd_i32x4_cmp.wast', # UBSan error on integer overflow
+ 'simd_i32x4_arith2.wast', # UBSan error on integer overflow
+ 'simd_i32x4_dot_i16x8.wast', # UBSan error on integer overflow
+ 'token.wast',
+]
options.spec_tests = [t for t in options.spec_tests if os.path.basename(t) not
- in SPEC_TESTS_TO_SKIP]
-
+ in (SPEC_TESTSUITE_TESTS_TO_SKIP if 'testsuite' in t
+ else SPEC_TESTS_TO_SKIP)]
# check utilities
+
def binary_format_check(wast, verify_final_result=True, wasm_as_args=['-g'],
binary_suffix='.fromBinary'):
# checks we can convert the wast to binary and back
diff --git a/scripts/test/wasm2js.py b/scripts/test/wasm2js.py
index ec2c98124..f7c9bd479 100644
--- a/scripts/test/wasm2js.py
+++ b/scripts/test/wasm2js.py
@@ -27,7 +27,10 @@ spec_tests = [t for t in spec_tests if '64.wast' not in t]
wasm2js_tests = shared.get_tests(shared.get_test_dir('wasm2js'), ['.wast'])
assert_tests = ['wasm2js.wast.asserts']
# These tests exercise functionality not supported by wasm2js
-wasm2js_blacklist = ['empty_imported_table.wast']
+wasm2js_skipped_tests = [
+ 'empty_imported_table.wast',
+ 'br.wast', # depends on multivalue
+]
def check_for_stale_files():
@@ -52,7 +55,7 @@ def test_wasm2js_output():
for opt in (0, 1):
for t in basic_tests + spec_tests + wasm2js_tests:
basename = os.path.basename(t)
- if basename in wasm2js_blacklist:
+ if basename in wasm2js_skipped_tests:
continue
asm = basename.replace('.wast', '.2asm.js')
@@ -158,7 +161,7 @@ def update_wasm2js_tests():
if not wasm.endswith('.wast'):
continue
- if os.path.basename(wasm) in wasm2js_blacklist:
+ if os.path.basename(wasm) in wasm2js_skipped_tests:
continue
asm = os.path.basename(wasm).replace('.wast', '.2asm.js')