summaryrefslogtreecommitdiff
path: root/test/unit/test_reduce.py
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2021-01-15 16:03:32 +0000
committerGitHub <noreply@github.com>2021-01-15 08:03:32 -0800
commitd808e900b8b8a0bc99d77fd38e94426df73c3afa (patch)
tree384acbd0efb0bae7fc1585be7e2abe1a6c09f41c /test/unit/test_reduce.py
parentbeccdf70258cd99ea25f10af13103e14dc243ffa (diff)
downloadbinaryen-d808e900b8b8a0bc99d77fd38e94426df73c3afa.tar.gz
binaryen-d808e900b8b8a0bc99d77fd38e94426df73c3afa.tar.bz2
binaryen-d808e900b8b8a0bc99d77fd38e94426df73c3afa.zip
Reducer: Improve warning on scripts that ignore the input (#3490)
The risk the warning checks for is giving the reducer a script that ignores the input. To do so it runs the command in the input, and runs it on a garbage file, and checks if the result is different. However, if the script does immediately fail on the input - because the input is a crash testcase or such - then this does not work, as the result on a garbage input may be the same error. To avoid that, also check what happens on a trivial valid wasm as input. Only show the warning if the result on the original input, on a garbage wasm, and on a trivial wasm, are all the same - in that case, likely the script really is ignoring the input.
Diffstat (limited to 'test/unit/test_reduce.py')
-rw-r--r--test/unit/test_reduce.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/test/unit/test_reduce.py b/test/unit/test_reduce.py
new file mode 100644
index 000000000..0abba604f
--- /dev/null
+++ b/test/unit/test_reduce.py
@@ -0,0 +1,13 @@
+import subprocess
+
+from scripts.test import shared
+from . import utils
+
+
+class ReduceTest(utils.BinaryenTestCase):
+ def test_warn_on_no_passes(self):
+ # run a reducer command that does nothing, and so ignores the input
+ open('do_nothing.py', 'w').close()
+ cmd = shared.WASM_REDUCE + [self.input_path('empty.wasm'), '-w', 'w.wasm', '-t', 't.wasm', '--command=python do_nothing.py']
+ err = shared.run_process(cmd, check=False, stderr=subprocess.PIPE).stderr
+ self.assertIn('Fatal: running the command on the given input gives the same result as when running it on either a trivial valid wasm or a file with nonsense in it. does the script not look at the test file (t.wasm)? (use -f to ignore this check)', err)