summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/tools/wasm-reduce.cpp29
-rw-r--r--test/unit/test_reduce.py13
2 files changed, 33 insertions, 9 deletions
diff --git a/src/tools/wasm-reduce.cpp b/src/tools/wasm-reduce.cpp
index 13288c79d..a6bf238fc 100644
--- a/src/tools/wasm-reduce.cpp
+++ b/src/tools/wasm-reduce.cpp
@@ -1199,19 +1199,30 @@ int main(int argc, const char* argv[]) {
expected);
}
- std::cerr
- << "|checking that command has different behavior on invalid binary (this "
- "verifies that the test file is used by the command)\n";
- {
+ if (!force) {
+ std::cerr << "|checking that command has different behavior on different "
+ "inputs (this "
+ "verifies that the test file is used by the command)\n";
+ // Try it on an invalid input.
{
std::ofstream dst(test, std::ios::binary);
dst << "waka waka\n";
}
- ProgramResult result(command);
- if (result == expected) {
- stopIfNotForced(
- "running command on an invalid module should give different results",
- result);
+ ProgramResult resultOnInvalid(command);
+ if (resultOnInvalid == expected) {
+ // Try it on a valid input.
+ Module emptyModule;
+ ModuleWriter writer;
+ writer.setBinary(true);
+ writer.write(emptyModule, test);
+ ProgramResult resultOnValid(command);
+ if (resultOnValid == expected) {
+ 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 (" +
+ test + ")? (use -f to ignore this check)";
+ }
}
}
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)