diff options
author | Ben Smith <binjimin@gmail.com> | 2019-04-03 11:36:14 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-04-03 11:36:14 -0700 |
commit | a5919e92af2e1ef9172d541f1b30d143d5f96e56 (patch) | |
tree | 541547fc477dbae8f9aa850298fb33ff38f5fb80 /test/run-spec-wasm2c.py | |
parent | d7d7945a4823a666d5d967f7cb2069cf8797b7d7 (diff) | |
download | wabt-a5919e92af2e1ef9172d541f1b30d143d5f96e56.tar.gz wabt-a5919e92af2e1ef9172d541f1b30d143d5f96e56.tar.bz2 wabt-a5919e92af2e1ef9172d541f1b30d143d5f96e56.zip |
Update testsuite; fix linking spec test (#1055)
When a module is instantiated, and the start function traps, the
contents of the memory and the table may have been modified. This case
is handled by the `assert_uninstantiable` check in a wast test.
In spectest-interp, assert_uninstantiable would instantiate the module,
but was incorrectly resetting the environment. In run-spec-wasm2c, the
`assert_uninstantiable` tests weren't being run at all. Now the module's
`init` function is run, and it is expected to trap.
Diffstat (limited to 'test/run-spec-wasm2c.py')
-rwxr-xr-x | test/run-spec-wasm2c.py | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/test/run-spec-wasm2c.py b/test/run-spec-wasm2c.py index baf08a72..741722f9 100755 --- a/test/run-spec-wasm2c.py +++ b/test/run-spec-wasm2c.py @@ -104,6 +104,11 @@ def MangleName(s): return result +def IsModuleCommand(command): + return (command['type'] == 'module' or + command['type'] == 'assert_uninstantiable') + + class CWriter(object): def __init__(self, spec_json, prefix, out_file, out_dir): @@ -127,7 +132,7 @@ class CWriter(object): self.out_file.write("\n}\n") def GetModuleFilenames(self): - return [c['filename'] for c in self.commands if c['type'] == 'module'] + return [c['filename'] for c in self.commands if IsModuleCommand(c)] def GetModulePrefix(self, idx_or_name=None): if idx_or_name is not None: @@ -137,7 +142,7 @@ class CWriter(object): def _CacheModulePrefixes(self): idx = 0 for command in self.commands: - if command['type'] == 'module': + if IsModuleCommand(command): name = os.path.basename(command['filename']) name = os.path.splitext(name)[0] name = re.sub(r'[^a-zA-Z0-9_]', '_', name) @@ -186,6 +191,7 @@ class CWriter(object): def _WriteCommand(self, command): command_funcs = { 'module': self._WriteModuleCommand, + 'assert_uninstantiable': self._WriteAssertUninstantiableCommand, 'action': self._WriteActionCommand, 'assert_return': self._WriteAssertReturnCommand, 'assert_return_canonical_nan': self._WriteAssertReturnNanCommand, @@ -204,6 +210,10 @@ class CWriter(object): self.module_idx += 1 self.out_file.write('%sinit();\n' % self.GetModulePrefix()) + def _WriteAssertUninstantiableCommand(self, command): + self.module_idx += 1 + self.out_file.write('ASSERT_TRAP(%sinit());\n' % self.GetModulePrefix()) + def _WriteActionCommand(self, command): self.out_file.write('%s;\n' % self._Action(command)) |