nodejs/deps/v8/test/mjsunit/wasm/wasm-interpreter-fuzzer.js
Michaël Zasso 918fe04351
deps: update V8 to 13.6.233.8
PR-URL: https://github.com/nodejs/node/pull/58070
Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com>
Reviewed-By: Darshan Sen <raisinten@gmail.com>
Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com>
Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com>
2025-05-02 15:06:53 +02:00

28 lines
927 B
JavaScript

// Copyright 2024 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --drumbrake-fuzzer-timeout --drumbrake-fuzzer-timeout-limit-ms=10
d8.file.execute("test/mjsunit/wasm/wasm-module-builder.js");
// Test that the interpreter can handle infinite loops on fuzzer test.
(function testInfiniteLoop() {
print(arguments.callee.name);
const builder = new WasmModuleBuilder();
let sig_v_v = builder.addType(kSig_v_v);
builder.addFunction("main", kSig_v_v)
.addBody([
kExprBlock, kWasmVoid,
kExprLoop, kWasmVoid,
...wasmI32Const(1),
kExprBrIf, 0,
kExprEnd,
kExprEnd
])
.exportAs("main");
const instance = builder.instantiate();
// This should trap with the trap reason kTrapUnreachable.
assertTraps(kTrapUnreachable, () => instance.exports.main());
})();