| Index: test/mjsunit/wasm/test-wasm-module-builder.js
|
| diff --git a/test/mjsunit/wasm/test-wasm-module-builder.js b/test/mjsunit/wasm/test-wasm-module-builder.js
|
| index 8be2933b87e4e135f523c2c78cc92f900d3d6769..30bbe4ac9377a559d51ca42100b9b4e3aa718d07 100644
|
| --- a/test/mjsunit/wasm/test-wasm-module-builder.js
|
| +++ b/test/mjsunit/wasm/test-wasm-module-builder.js
|
| @@ -9,40 +9,44 @@ load('test/mjsunit/wasm/wasm-module-builder.js');
|
|
|
| var debug = true;
|
|
|
| +function instantiate(buffer, ffi) {
|
| + return new WebAssembly.Instance(WebAssembly.Module(buffer), ffi);
|
| +}
|
| +
|
| (function BasicTest() {
|
| - var module = new WasmModuleBuilder();
|
| - module.addMemory(1, 2, false);
|
| - module.addFunction("foo", kSig_i_v)
|
| + let builder = new WasmModuleBuilder();
|
| + builder.addMemory(1, 2, false);
|
| + builder.addFunction("foo", kSig_i_v)
|
| .addBody([kExprI8Const, 11])
|
| .exportAs("blarg");
|
|
|
| - var buffer = module.toBuffer(debug);
|
| - var instance = Wasm.instantiateModule(buffer);
|
| + var buffer = builder.toBuffer(debug);
|
| + var instance = instantiate(buffer);
|
| assertEquals(11, instance.exports.blarg());
|
| })();
|
|
|
| (function ImportTest() {
|
| - var module = new WasmModuleBuilder();
|
| - var index = module.addImport("print", makeSig_v_x(kAstI32));
|
| - module.addFunction("foo", kSig_v_v)
|
| + let builder = new WasmModuleBuilder();
|
| + var index = builder.addImport("print", makeSig_v_x(kAstI32));
|
| + builder.addFunction("foo", kSig_v_v)
|
| .addBody([kExprI8Const, 13, kExprCallFunction, index])
|
| .exportAs("main");
|
|
|
| - var buffer = module.toBuffer(debug);
|
| - var instance = Wasm.instantiateModule(buffer, {print: print});
|
| + var buffer = builder.toBuffer(debug);
|
| + var instance = instantiate(buffer, {print: print});
|
| print("should print 13! ");
|
| instance.exports.main();
|
| })();
|
|
|
| (function LocalsTest() {
|
| - var module = new WasmModuleBuilder();
|
| - module.addFunction(undefined, kSig_i_i)
|
| + let builder = new WasmModuleBuilder();
|
| + builder.addFunction(undefined, kSig_i_i)
|
| .addLocals({i32_count: 1})
|
| .addBody([kExprGetLocal, 0, kExprSetLocal, 1, kExprGetLocal, 1])
|
| .exportAs("main");
|
|
|
| - var buffer = module.toBuffer(debug);
|
| - var instance = Wasm.instantiateModule(buffer);
|
| + var buffer = builder.toBuffer(debug);
|
| + var instance = instantiate(buffer);
|
| assertEquals(19, instance.exports.main(19));
|
| assertEquals(27777, instance.exports.main(27777));
|
| })();
|
| @@ -57,72 +61,72 @@ var debug = true;
|
| ];
|
|
|
| for (p of types) {
|
| - var module = new WasmModuleBuilder();
|
| - module.addFunction(undefined, makeSig_r_x(p.type, p.type))
|
| + let builder = new WasmModuleBuilder();
|
| + builder.addFunction(undefined, makeSig_r_x(p.type, p.type))
|
| .addLocals(p.locals)
|
| .addBody([kExprGetLocal, 0, kExprSetLocal, 1, kExprGetLocal, 1])
|
| .exportAs("main");
|
|
|
| - var buffer = module.toBuffer(debug);
|
| - var instance = Wasm.instantiateModule(buffer);
|
| + var buffer = builder.toBuffer(debug);
|
| + var instance = instantiate(buffer);
|
| assertEquals(19, instance.exports.main(19));
|
| assertEquals(27777, instance.exports.main(27777));
|
| }
|
| })();
|
|
|
| (function CallTest() {
|
| - var module = new WasmModuleBuilder();
|
| - module.addFunction("add", kSig_i_ii)
|
| + let builder = new WasmModuleBuilder();
|
| + builder.addFunction("add", kSig_i_ii)
|
| .addBody([kExprGetLocal, 0, kExprGetLocal, 1, kExprI32Add]);
|
| - module.addFunction("main", kSig_i_ii)
|
| + builder.addFunction("main", kSig_i_ii)
|
| .addBody([kExprGetLocal, 0, kExprGetLocal, 1, kExprCallFunction, 0])
|
| .exportAs("main");
|
|
|
| - var instance = module.instantiate();
|
| + var instance = builder.instantiate();
|
| assertEquals(44, instance.exports.main(11, 33));
|
| assertEquals(7777, instance.exports.main(2222, 5555));
|
| })();
|
|
|
| (function IndirectCallTest() {
|
| - var module = new WasmModuleBuilder();
|
| - module.addFunction("add", kSig_i_ii)
|
| + let builder = new WasmModuleBuilder();
|
| + builder.addFunction("add", kSig_i_ii)
|
| .addBody([kExprGetLocal, 0, kExprGetLocal, 1, kExprI32Add]);
|
| - module.addFunction("main", kSig_i_iii)
|
| + builder.addFunction("main", kSig_i_iii)
|
| .addBody([kExprGetLocal,
|
| 1, kExprGetLocal, 2, kExprGetLocal, 0, kExprCallIndirect, 0, kTableZero])
|
| .exportAs("main");
|
| - module.appendToTable([0]);
|
| + builder.appendToTable([0]);
|
|
|
| - var instance = module.instantiate();
|
| + var instance = builder.instantiate();
|
| assertEquals(44, instance.exports.main(0, 11, 33));
|
| assertEquals(7777, instance.exports.main(0, 2222, 5555));
|
| assertThrows(function() { instance.exports.main(1, 1, 1); });
|
| })();
|
|
|
| (function DataSegmentTest() {
|
| - var module = new WasmModuleBuilder();
|
| - module.addMemory(1, 1, false);
|
| - module.addFunction("load", kSig_i_i)
|
| + let builder = new WasmModuleBuilder();
|
| + builder.addMemory(1, 1, false);
|
| + builder.addFunction("load", kSig_i_i)
|
| .addBody([kExprGetLocal, 0, kExprI32LoadMem, 0, 0])
|
| .exportAs("load");
|
| - module.addDataSegment(0, [9, 9, 9, 9]);
|
| + builder.addDataSegment(0, [9, 9, 9, 9]);
|
|
|
| - var buffer = module.toBuffer(debug);
|
| - var instance = Wasm.instantiateModule(buffer);
|
| + var buffer = builder.toBuffer(debug);
|
| + var instance = instantiate(buffer);
|
| assertEquals(151587081, instance.exports.load(0));
|
| })();
|
|
|
|
|
| (function BasicTestWithUint8Array() {
|
| - var module = new WasmModuleBuilder();
|
| - module.addMemory(1, 2, false);
|
| - module.addFunction("foo", kSig_i_v)
|
| + let builder = new WasmModuleBuilder();
|
| + builder.addMemory(1, 2, false);
|
| + builder.addFunction("foo", kSig_i_v)
|
| .addBody([kExprI8Const, 17])
|
| .exportAs("blarg");
|
|
|
| - var buffer = module.toBuffer(debug);
|
| + var buffer = builder.toBuffer(debug);
|
| var array = new Uint8Array(buffer);
|
| - var instance = Wasm.instantiateModule(array);
|
| + var instance = instantiate(array);
|
| assertEquals(17, instance.exports.blarg());
|
|
|
| var kPad = 5;
|
| @@ -135,19 +139,19 @@ var debug = true;
|
| for (var i = 0; i < array2.byteLength; i++) {
|
| array2[i] = array[i];
|
| }
|
| - var instance = Wasm.instantiateModule(array2);
|
| + var instance = instantiate(array2);
|
| assertEquals(17, instance.exports.blarg());
|
| })();
|
|
|
| (function ImportTestTwoLevel() {
|
| - var module = new WasmModuleBuilder();
|
| - var index = module.addImportWithModule("mod", "print", makeSig_v_x(kAstI32));
|
| - module.addFunction("foo", kSig_v_v)
|
| + let builder = new WasmModuleBuilder();
|
| + var index = builder.addImportWithModule("mod", "print", makeSig_v_x(kAstI32));
|
| + builder.addFunction("foo", kSig_v_v)
|
| .addBody([kExprI8Const, 19, kExprCallFunction, index])
|
| .exportAs("main");
|
|
|
| - var buffer = module.toBuffer(debug);
|
| - var instance = Wasm.instantiateModule(buffer, {mod: {print: print}});
|
| + var buffer = builder.toBuffer(debug);
|
| + var instance = instantiate(buffer, {mod: {print: print}});
|
| print("should print 19! ");
|
| instance.exports.main();
|
| })();
|
|
|