diff options
author | Thomas Lively <tlively@google.com> | 2024-08-20 17:16:44 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-08-20 17:16:44 -0700 |
commit | 435eeead73cf02a6fb5bc7d7a36dd45b8d700cb2 (patch) | |
tree | d079d92a6d934175d6f1b276deb0ef78d14d058b /scripts | |
parent | 340ad71810484c279b1a36a9a7e458c9b18855b9 (diff) | |
download | binaryen-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.py | 96 | ||||
-rw-r--r-- | scripts/test/wasm2js.py | 9 |
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') |