mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-26 01:11:37 +00:00
34 lines
1.2 KiB
TypeScript
34 lines
1.2 KiB
TypeScript
import { readdirSync, readFileSync } from "node:fs";
|
|
import { dirname, resolve } from "node:path";
|
|
import { fileURLToPath } from "node:url";
|
|
import { describe, expect, it } from "vitest";
|
|
|
|
const ROOT_DIR = resolve(dirname(fileURLToPath(import.meta.url)), "..");
|
|
const REPO_ROOT = resolve(ROOT_DIR, "..");
|
|
const EXTENSIONS_DIR = resolve(REPO_ROOT, "extensions");
|
|
const CORE_PLUGIN_ENTRY_IMPORT_RE =
|
|
/import\s*\{[^}]*\bdefinePluginEntry\b[^}]*\}\s*from\s*"openclaw\/plugin-sdk\/core"/;
|
|
|
|
describe("plugin entry guardrails", () => {
|
|
it("keeps bundled extension entry modules off direct definePluginEntry imports from core", () => {
|
|
const failures: string[] = [];
|
|
|
|
for (const entry of readdirSync(EXTENSIONS_DIR, { withFileTypes: true })) {
|
|
if (!entry.isDirectory()) {
|
|
continue;
|
|
}
|
|
const indexPath = resolve(EXTENSIONS_DIR, entry.name, "index.ts");
|
|
try {
|
|
const source = readFileSync(indexPath, "utf8");
|
|
if (CORE_PLUGIN_ENTRY_IMPORT_RE.test(source)) {
|
|
failures.push(`extensions/${entry.name}/index.ts`);
|
|
}
|
|
} catch {
|
|
// Skip extensions without index.ts entry modules.
|
|
}
|
|
}
|
|
|
|
expect(failures).toEqual([]);
|
|
});
|
|
});
|