将 checker 架构重构为完全内聚模式:每个 checker 目录包含自身的 types、schema、validate、execute、expect 和 index,新增 checker 只需创建一个目录并在 runner/index.ts 添加一行注册。 主要变更: - runner/shared/ 拆分:断言基础设施迁入 checker/expect/, body.ts 迁入 http/,text.ts 迁入 command/ - config-contract/ 重命名为 schema/,schema.ts → builder.ts - size.ts + parseDuration 合并为 utils.ts - 顶层 types.ts 改为 base interface + index signature, checker 专属类型下沉到各自 types.ts - runner/index.ts 改为显式数组注册模式 - 更新 DEVELOPMENT.md 项目结构和开发新 Checker 指南
51 lines
1.7 KiB
TypeScript
51 lines
1.7 KiB
TypeScript
import { describe, expect, test } from "bun:test";
|
|
|
|
import { checkTextRules } from "../../../../../src/server/checker/runner/command/text";
|
|
|
|
describe("checkTextRules", () => {
|
|
test("无规则返回匹配成功", () => {
|
|
const r = checkTextRules("hello", [], "stdout");
|
|
expect(r.matched).toBe(true);
|
|
expect(r.failure).toBeNull();
|
|
});
|
|
|
|
test("单条 contains 规则匹配成功", () => {
|
|
const r = checkTextRules("build completed successfully", [{ contains: "completed" }], "stdout");
|
|
expect(r.matched).toBe(true);
|
|
});
|
|
|
|
test("单条 contains 规则匹配失败", () => {
|
|
const r = checkTextRules("build completed successfully", [{ contains: "failed" }], "stdout");
|
|
expect(r.matched).toBe(false);
|
|
expect(r.failure!.phase).toBe("stdout");
|
|
expect(r.failure!.path).toBe("stdout[0]");
|
|
});
|
|
|
|
test("多条规则全部通过", () => {
|
|
const r = checkTextRules(
|
|
"version: 3.2.1, build: ok",
|
|
[{ contains: "version" }, { match: "\\d+\\.\\d+\\.\\d+" }],
|
|
"stdout",
|
|
);
|
|
expect(r.matched).toBe(true);
|
|
});
|
|
|
|
test("第一条规则失败立即返回", () => {
|
|
const r = checkTextRules("error occurred", [{ contains: "success" }, { contains: "error" }], "stdout");
|
|
expect(r.matched).toBe(false);
|
|
expect(r.failure!.phase).toBe("stdout");
|
|
expect(r.failure!.path).toBe("stdout[0]");
|
|
});
|
|
|
|
test("stderr phase", () => {
|
|
const r = checkTextRules("warning: deprecated", [{ contains: "warning" }], "stderr");
|
|
expect(r.matched).toBe(true);
|
|
expect(r.failure).toBeNull();
|
|
});
|
|
|
|
test("empty 操作符", () => {
|
|
const r = checkTextRules("", [{ empty: true }], "stderr");
|
|
expect(r.matched).toBe(true);
|
|
});
|
|
});
|