test: move test file into separate subfolder

This commit is contained in:
Jörg Krzeslak
2025-07-23 21:11:12 +02:00
parent 4fa471263f
commit 2db99edeaf

View File

@@ -0,0 +1,64 @@
import type { ExecFileException } from "node:child_process";
import { expect, test } from "bun:test";
import { convert, ExecFileFn } from "../../src/converters/assimp.ts";
test("convert resolves when execFile succeeds", async () => {
const originalConsoleLog = console.log;
let loggedMessage = "";
console.log = (msg) => {
loggedMessage = msg;
};
const mockExecFile: ExecFileFn = (
_cmd: string,
_args: string[],
callback: (err: ExecFileException | null, stdout: string, stderr: string) => void,
) => {
callback(null, "Fake stdout", "");
};
const result = await convert("input.obj", "obj", "stl", "output.stl", undefined, mockExecFile);
console.log = originalConsoleLog;
expect(result).toBe("Done");
expect(loggedMessage).toBe("stdout: Fake stdout");
});
test("convert rejects when execFile fails", async () => {
const mockExecFile: ExecFileFn = (
_cmd: string,
_args: string[],
callback: (err: ExecFileException | null, stdout: string, stderr: string) => void,
) => {
callback(new Error("Test error"), "", "");
};
expect(convert("input.obj", "obj", "stl", "output.stl", undefined, mockExecFile)).rejects.toMatch(
/error: Error: Test error/,
);
});
test("convert logs stderr when present", async () => {
const originalConsoleError = console.error;
let loggedMessage = "";
console.error = (msg) => {
loggedMessage = msg;
};
const mockExecFile = (
_cmd: string,
_args: string[],
cb: (err: Error | null, stdout: string, stderr: string) => void,
) => {
cb(null, "", "Fake stderr");
};
await convert("file.obj", "obj", "stl", "out.stl", undefined, mockExecFile);
console.error = originalConsoleError;
expect(loggedMessage).toBe("stderr: Fake stderr");
});