2018-05-07 13:46:23 -05:00
|
|
|
#!/usr/bin/env node
|
|
|
|
|
|
2025-03-18 00:29:11 -07:00
|
|
|
import url from "node:url";
|
|
|
|
|
|
|
|
|
|
const __dirname = url.fileURLToPath(new URL(".", import.meta.url));
|
|
|
|
|
|
2018-05-07 13:46:23 -05:00
|
|
|
process.on("unhandledRejection", exn => { throw exn; });
|
|
|
|
|
|
2018-11-20 16:42:32 -06:00
|
|
|
const TEST_RELEASE_BUILD = +process.env.TEST_RELEASE_BUILD;
|
2025-04-07 19:29:47 +07:00
|
|
|
const { V86 } = await import(TEST_RELEASE_BUILD ? "../../build/libv86.mjs" : "../../src/main.js");
|
2018-05-07 13:46:23 -05:00
|
|
|
|
2018-05-19 17:09:57 -05:00
|
|
|
const config_async_cdrom = {
|
2018-05-07 13:46:23 -05:00
|
|
|
bios: { url: __dirname + "/../../bios/seabios.bin" },
|
|
|
|
|
vga_bios: { url: __dirname + "/../../bios/vgabios.bin" },
|
2021-01-03 19:22:21 -06:00
|
|
|
cdrom: { url: __dirname + "/../../images/linux4.iso", async: true },
|
2018-05-07 13:46:23 -05:00
|
|
|
autostart: true,
|
2024-09-01 14:08:21 +02:00
|
|
|
memory_size: 64 * 1024 * 1024,
|
2018-05-07 13:46:23 -05:00
|
|
|
filesystem: {},
|
2023-09-30 17:41:10 -05:00
|
|
|
disable_jit: +process.env.DISABLE_JIT,
|
2018-05-07 13:46:23 -05:00
|
|
|
log_level: 0,
|
2018-05-19 17:09:57 -05:00
|
|
|
};
|
2018-05-07 13:46:23 -05:00
|
|
|
|
2018-05-19 17:09:57 -05:00
|
|
|
const config_sync_cdrom = {
|
|
|
|
|
bios: { url: __dirname + "/../../bios/seabios.bin" },
|
|
|
|
|
vga_bios: { url: __dirname + "/../../bios/vgabios.bin" },
|
2021-01-03 19:22:21 -06:00
|
|
|
cdrom: { url: __dirname + "/../../images/linux4.iso", async: false },
|
2018-05-19 17:09:57 -05:00
|
|
|
autostart: true,
|
2024-09-01 14:08:21 +02:00
|
|
|
memory_size: 64 * 1024 * 1024,
|
2018-05-19 17:09:57 -05:00
|
|
|
filesystem: {},
|
2023-09-30 17:41:10 -05:00
|
|
|
disable_jit: +process.env.DISABLE_JIT,
|
2018-05-19 17:09:57 -05:00
|
|
|
log_level: 0,
|
|
|
|
|
};
|
|
|
|
|
|
2020-12-31 19:14:32 -06:00
|
|
|
const config_filesystem = {
|
|
|
|
|
bios: { url: __dirname + "/../../bios/seabios.bin" },
|
|
|
|
|
vga_bios: { url: __dirname + "/../../bios/vgabios.bin" },
|
|
|
|
|
autostart: true,
|
2024-09-01 14:08:21 +02:00
|
|
|
memory_size: 64 * 1024 * 1024,
|
2020-12-31 19:14:32 -06:00
|
|
|
filesystem: {},
|
2024-09-01 14:08:21 +02:00
|
|
|
bzimage: { url: __dirname + "/../../images/buildroot-bzimage68.bin" },
|
2020-12-31 19:14:32 -06:00
|
|
|
cmdline: "tsc=reliable mitigations=off random.trust_cpu=on",
|
|
|
|
|
network_relay_url: "<UNUSED>",
|
2023-09-30 17:41:10 -05:00
|
|
|
disable_jit: +process.env.DISABLE_JIT,
|
2020-12-31 19:14:32 -06:00
|
|
|
log_level: 0,
|
|
|
|
|
};
|
|
|
|
|
|
2023-12-08 13:01:11 -05:00
|
|
|
const config_large_memory = {
|
|
|
|
|
bios: { url: __dirname + "/../../bios/seabios.bin" },
|
|
|
|
|
vga_bios: { url: __dirname + "/../../bios/vgabios.bin" },
|
|
|
|
|
cdrom: { url: __dirname + "/../../images/linux4.iso", async: true },
|
|
|
|
|
autostart: true,
|
|
|
|
|
memory_size: 2048 * 1024 * 1024,
|
|
|
|
|
vga_memory_size: 512 * 1024 * 1024,
|
|
|
|
|
network_relay_url: "<UNUSED>",
|
|
|
|
|
disable_jit: +process.env.DISABLE_JIT,
|
|
|
|
|
log_level: 0,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
async function sleep(ms) { return new Promise(resolve => setTimeout(resolve, ms)); }
|
|
|
|
|
|
|
|
|
|
async function run_test(name, config, done)
|
2018-05-19 17:09:57 -05:00
|
|
|
{
|
|
|
|
|
const emulator = new V86(config);
|
|
|
|
|
|
2023-12-14 16:29:52 -05:00
|
|
|
await sleep(2000);
|
2023-12-08 13:01:11 -05:00
|
|
|
|
|
|
|
|
console.log("Saving: %s", name);
|
|
|
|
|
const state = await emulator.save_state();
|
|
|
|
|
|
|
|
|
|
await sleep(1000);
|
|
|
|
|
|
|
|
|
|
console.log("Restoring: %s", name);
|
|
|
|
|
await emulator.restore_state(state);
|
|
|
|
|
|
2024-09-13 13:32:26 -06:00
|
|
|
await emulator.wait_until_vga_screen_contains("~% ");
|
|
|
|
|
await sleep(1000);
|
2023-12-14 16:29:52 -05:00
|
|
|
|
|
|
|
|
emulator.keyboard_send_text("echo -n test; echo passed\n");
|
2023-12-08 13:01:11 -05:00
|
|
|
await sleep(1000);
|
|
|
|
|
|
2023-12-14 16:29:52 -05:00
|
|
|
const lines = emulator.screen_adapter.get_text_screen();
|
2024-09-13 13:32:26 -06:00
|
|
|
if(!lines.some(line => line.startsWith("testpassed")))
|
2023-12-14 16:29:52 -05:00
|
|
|
{
|
|
|
|
|
console.warn("Failed: " + name);
|
|
|
|
|
console.warn(lines.map(line => line.replace(/\x00/g, " ")));
|
|
|
|
|
process.exit(1);
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-08 13:01:11 -05:00
|
|
|
console.log("Done: %s", name);
|
2024-12-20 10:35:55 -07:00
|
|
|
emulator.destroy();
|
2018-05-19 17:09:57 -05:00
|
|
|
}
|
|
|
|
|
|
2023-12-08 13:01:11 -05:00
|
|
|
(async function() {
|
|
|
|
|
await run_test("async cdrom", config_async_cdrom);
|
|
|
|
|
await run_test("sync cdrom", config_sync_cdrom);
|
|
|
|
|
await run_test("filesystem", config_filesystem);
|
|
|
|
|
await run_test("large memory size", config_large_memory);
|
|
|
|
|
})();
|