Spaces:
Runtime error
Runtime error
| import fs from "node:fs"; | |
| import url from "node:url"; | |
| process.on("unhandledRejection", exn => { throw exn; }); | |
| const __dirname = url.fileURLToPath(new URL(".", import.meta.url)); | |
| const TEST_RELEASE_BUILD = +process.env.TEST_RELEASE_BUILD; | |
| const { V86 } = await import(TEST_RELEASE_BUILD ? "../../build/libv86.mjs" : "../../src/main.js"); | |
| var test_executable = new Uint8Array(fs.readFileSync(__dirname + "/test-jit")); | |
| var emulator = new V86({ | |
| bios: { url: __dirname + "/../../bios/seabios.bin" }, | |
| vga_bios: { url: __dirname + "/../../bios/vgabios.bin" }, | |
| cdrom: { url: __dirname + "/../../images/linux4.iso" }, | |
| autostart: true, | |
| memory_size: 32 * 1024 * 1024, | |
| filesystem: {}, | |
| disable_jit: +process.env.DISABLE_JIT, | |
| log_level: 0, | |
| }); | |
| emulator.bus.register("emulator-started", function() | |
| { | |
| console.log("Booting now, please stand by"); | |
| emulator.create_file("test-jit", test_executable); | |
| }); | |
| var ran_command = false; | |
| var line = ""; | |
| emulator.add_listener("serial0-output-byte", async function(byte) | |
| { | |
| var chr = String.fromCharCode(byte); | |
| if(chr < " " && chr !== "\n" && chr !== "\t" || chr > "~") | |
| { | |
| return; | |
| } | |
| if(chr === "\n") | |
| { | |
| var new_line = line; | |
| console.error("Serial: %s", line); | |
| line = ""; | |
| } | |
| else | |
| { | |
| line += chr; | |
| } | |
| if(!ran_command && line.endsWith("~% ")) | |
| { | |
| ran_command = true; | |
| emulator.serial0_send("chmod +x /mnt/test-jit\n"); | |
| emulator.serial0_send("/mnt/test-jit 2>&1 | tee /mnt/result\n"); | |
| emulator.serial0_send("echo test fini''shed\n"); | |
| } | |
| if(new_line && new_line.includes("test finished")) | |
| { | |
| console.error("Done. Reading result ..."); | |
| const data = await emulator.read_file("/result"); | |
| emulator.destroy(); | |
| let result = Buffer.from(data).toString(); | |
| if(result !== "test_shared passed\ntest_consecutive_written passed\n") | |
| { | |
| console.error("[!] Error. Result was:\n" + result); | |
| process.exit(1); | |
| } | |
| else | |
| { | |
| console.log("[+] Test passed"); | |
| } | |
| } | |
| }); | |