mirror of
https://github.com/openclaw/openclaw.git
synced 2026-06-01 15:58:58 +00:00
* refactor: extract agent core package Introduce packages/agent-core as the OpenClaw-owned home for reusable agent loop, harness, session, prompt, and runtime dependency contracts. * refactor: extract shared llm runtime Move provider model registries, stream wrappers, OAuth helpers, and LLM utilities into src/llm with plugin-sdk barrels instead of depending on the old embedded runtime layout. * refactor: remove pi runtime internals Rename remaining Pi-shaped agent surfaces to OpenClaw agent runtime names, delete obsolete Pi docs and package graph checks, and add the third-party notice for incorporated code. * refactor: tighten agent session runtime Make agent-core/runtime dependencies explicit, consolidate compaction and session transcript helpers, and move model/session helpers behind OpenClaw-owned contracts. * refactor: remove static model and pi auth paths Drop static model catalogs and Pi auth bridges, move model/provider facts to manifest-owned runtime contracts, and harden internal embedded-agent utilities. * refactor: remove legacy provider compat paths * docs: remove agent parity notes * fix: skip provider wildcard metadata parsing * refactor: share session extension sdk loading * refactor: inline acpx proxy error formatter * refactor: fold edit recovery into edit tool * fix: accept extension batch separator * test: align startup provider plugin expectations * fix: restore provider-scoped release discovery * test: align static asset packaging expectations * fix: run static provider catalogs during scoped discovery * fix: add provider entry catalogs for scoped live discovery * fix: load lightweight provider catalog entries * fix: refresh provider-scoped plugin metadata * fix: keep provider catalog entries on release live path * fix: keep static manifest models in release live checks * fix: harden release model discovery * fix: reduce OpenAI live cache probe reasoning * fix: disable OpenAI cache probe reasoning * ci: extend OpenAI gateway live timeout * fix: extend live gateway model budget * fix: stabilize release validation regressions * fix: honor provider aliases in model rows * fix: stabilize release validation lanes * fix: stabilize release memory qa * ci: stabilize release validation lanes * ci: prefer ipv4 for live docker node calls * fix: restore shared tool-call stream wrapper * ci: remove legacy pi test shard alias * fix: clean up embedded agent test drift * fix: stabilize runtime alias status * fix: clean up embedded agent ci drift * fix: restore release ci invariants * fix: clean up post-rebase runtime drift * fix: restore release ci checks * fix: restore release ci after rebase * fix: remove stale pi runtime path * test: align compaction runtime expectations * test: update plugin prerelease expectations * fix: handle claude live tool approvals * fix: stabilize release validation gates * fix: finish agent runtime import * test: finish post-rebase agent runtime mocks * fix: keep codex compaction native * fix: stabilize codex app-server hook tests * test: isolate codex diagnostic active run * test: remove codex diagnostic completion race # Conflicts: # extensions/codex/src/app-server/run-attempt.test.ts * ci: fix full release manifest performance run id * refactor: narrow llm plugin sdk boundary * chore: drop generated google boundary stamps * fix: repair rebase fallout * fix: clean up rebased runtime references * fix: decode codex jwt payloads as base64url * fix: preserve shipped pi runtime alias * fix: add scoped sdk virtual modules * fix: decode llm codex oauth jwt as base64url * fix: avoid stale vertex adc negative cache * fix: harden tool arg decoding and codeql path * fix: keep vertex adc negative checks live * refactor: consolidate codex jwt and edit helpers * fix: await codex oauth node runtime imports * fix: preserve sdk tool and notice contracts * fix: preserve shipped compat config boundaries * fix: align codex oauth callback host * fix: terminate agent-core loop streams on failure * fix: keep codex oauth callback alive during fallback * ci: include session tools in critical codeql scans * fix: keep Cloudflare Anthropic provider auth header * docs: redirect legacy pi runtime pages * fix: honor bundled web provider compat discovery * fix: protect session output spill files * fix: keep legacy agent dir env blocked * fix: contain auto-discovered skill symlinks * fix: harden agent core sdk proxy surfaces * fix: restore approval reaction sdk compat * fix: keep live docker runs bounded * fix: keep codex oauth redirect host aligned * fix: resolve post-rebase agent runtime drift * fix: redact anthropic oauth parse failures * fix: preserve responses strict tool shaping * fix: repair agent runtime rebase cleanup * docs: redirect retired parity pages * fix: bound auto-discovered resources to roots * fix: repair post-rebase agent test drift * fix: preserve bundled provider allowlist migration * fix: preserve manifest-owned provider aliases * fix: declare photon image dependency * fix: keep provider headers out of proxy body * fix: preserve shipped env aliases * fix: refresh control ui i18n generated state * fix: quote read fallback paths * fix: preview edits through configured backend * test: satisfy core test typecheck * fix: preserve ZAI usage auth fallback * test: repair codex diagnostic test * fix: repair agent runtime rebase drift * test: finish embedded runner import rename * fix: repair agent runtime rebase integrations * test: align compaction oauth fallback expectations * fix: allow sdk-auth session models * fix: update doctor tool schema import * fix: preserve bedrock plugin region * fix: stream harmony-like prose immediately * ci: include session runtime in codeql shards * fix: repair latest rebase integrations * fix: honor explicit codex websocket transport * fix: keep openai-compatible credentials provider-scoped * fix: refresh sdk api baseline after rebase * fix: route cli runtime aliases through openclaw harness * test: rename stale harness mock expectation * test: rename embedded agent overflow calls * test: clean embedded auth test wording * test: use openclaw stream types in deepinfra cache test * fix: refresh sdk api baseline on latest main * fix: honor bundled discovery compat allowlists * fix: refresh sdk api baseline after latest rebase * fix: remove stale rebase imports * test: rename stale model catalog mock * test: mock renamed doctor runtime modules * fix: map canonical kimi env auth * fix: use internal model registry in bench script * fix: migrate deepinfra provider catalog entry * fix: enforce builtin tool suppression * fix: route compaction auth and proxy payloads safely * refactor: prune unused llm registry leftovers * test: update codex hooks session import * test: fix model picker ci coverage * test: align model picker auth mock types
413 lines
15 KiB
TypeScript
413 lines
15 KiB
TypeScript
import path from "node:path";
|
|
import { fileURLToPath } from "node:url";
|
|
import { pluginSdkSubpaths } from "../../scripts/lib/plugin-sdk-entries.mjs";
|
|
import privateLocalOnlyPluginSdkSubpaths from "../../scripts/lib/plugin-sdk-private-local-only-subpaths.json" with { type: "json" };
|
|
import {
|
|
detectVitestHostInfo as detectVitestHostInfoImpl,
|
|
isCiLikeEnv,
|
|
resolveLocalVitestMaxWorkers as resolveLocalVitestMaxWorkersImpl,
|
|
resolveLocalVitestScheduling as resolveLocalVitestSchedulingImpl,
|
|
} from "../../scripts/lib/vitest-local-scheduling.mjs";
|
|
import {
|
|
BUNDLED_PLUGIN_ROOT_DIR,
|
|
BUNDLED_PLUGIN_TEST_GLOB,
|
|
} from "./vitest.bundled-plugin-paths.ts";
|
|
import { loadVitestExperimentalConfig } from "./vitest.performance-config.ts";
|
|
import { shouldPrintVitestThrottle } from "./vitest.system-load.ts";
|
|
|
|
type VitestHostInfo = {
|
|
cpuCount?: number;
|
|
loadAverage1m?: number;
|
|
totalMemoryBytes?: number;
|
|
};
|
|
|
|
export type OpenClawVitestPool = "forks" | "threads";
|
|
|
|
export type LocalVitestScheduling = {
|
|
maxWorkers: number;
|
|
fileParallelism: boolean;
|
|
throttledBySystem: boolean;
|
|
};
|
|
|
|
export const jsdomOptimizedDeps = {
|
|
optimizer: {
|
|
web: {
|
|
enabled: true,
|
|
include: ["lit", "lit-html", "@lit/reactive-element", "marked"] as string[],
|
|
},
|
|
},
|
|
};
|
|
|
|
function detectVitestHostInfo(): Required<VitestHostInfo> {
|
|
return detectVitestHostInfoImpl() as Required<VitestHostInfo>;
|
|
}
|
|
|
|
export function resolveLocalVitestMaxWorkers(
|
|
env: Record<string, string | undefined> = process.env,
|
|
system: VitestHostInfo = detectVitestHostInfo(),
|
|
pool: OpenClawVitestPool = resolveDefaultVitestPool(env),
|
|
): number {
|
|
return resolveLocalVitestMaxWorkersImpl(env, system, pool);
|
|
}
|
|
|
|
export function resolveLocalVitestScheduling(
|
|
env: Record<string, string | undefined> = process.env,
|
|
system: VitestHostInfo = detectVitestHostInfo(),
|
|
pool: OpenClawVitestPool = resolveDefaultVitestPool(env),
|
|
): LocalVitestScheduling {
|
|
return resolveLocalVitestSchedulingImpl(env, system, pool) as LocalVitestScheduling;
|
|
}
|
|
|
|
export function resolveDefaultVitestPool(
|
|
_env: Record<string, string | undefined> = process.env,
|
|
): OpenClawVitestPool {
|
|
return "threads";
|
|
}
|
|
|
|
export const repoRoot = path.resolve(path.dirname(fileURLToPath(import.meta.url)), "../..");
|
|
export const nonIsolatedRunnerPath = path.join(repoRoot, "test", "non-isolated-runner.ts");
|
|
export function resolveRepoRootPath(value: string): string {
|
|
return path.isAbsolute(value) ? value : path.join(repoRoot, value);
|
|
}
|
|
const isCI = isCiLikeEnv(process.env);
|
|
const isWindows = process.platform === "win32";
|
|
const defaultPool = resolveDefaultVitestPool();
|
|
const localScheduling = resolveLocalVitestScheduling(
|
|
process.env,
|
|
detectVitestHostInfo(),
|
|
defaultPool,
|
|
);
|
|
|
|
function hasWorkerOverride(env: Record<string, string | undefined>): boolean {
|
|
return Boolean((env.OPENCLAW_VITEST_MAX_WORKERS ?? env.OPENCLAW_TEST_WORKERS)?.trim());
|
|
}
|
|
|
|
export function resolveSharedVitestWorkerConfig(params: {
|
|
env?: Record<string, string | undefined>;
|
|
isCI?: boolean;
|
|
isWindows?: boolean;
|
|
localScheduling?: LocalVitestScheduling;
|
|
}): Pick<LocalVitestScheduling, "fileParallelism" | "maxWorkers"> {
|
|
const env = params.env ?? process.env;
|
|
const local = params.localScheduling ?? localScheduling;
|
|
if (hasWorkerOverride(env)) {
|
|
return {
|
|
fileParallelism: local.fileParallelism,
|
|
maxWorkers: local.maxWorkers,
|
|
};
|
|
}
|
|
if (params.isCI ?? isCI) {
|
|
return {
|
|
fileParallelism: true,
|
|
maxWorkers: (params.isWindows ?? isWindows) ? 2 : 3,
|
|
};
|
|
}
|
|
return {
|
|
fileParallelism: local.fileParallelism,
|
|
maxWorkers: local.maxWorkers,
|
|
};
|
|
}
|
|
|
|
const workerConfig = resolveSharedVitestWorkerConfig({
|
|
env: process.env,
|
|
isCI,
|
|
isWindows,
|
|
localScheduling,
|
|
});
|
|
const sourcePluginSdkSubpaths = [
|
|
...new Set([...pluginSdkSubpaths, ...privateLocalOnlyPluginSdkSubpaths]),
|
|
].toSorted((left, right) => left.localeCompare(right));
|
|
|
|
if (!isCI && localScheduling.throttledBySystem && shouldPrintVitestThrottle(process.env)) {
|
|
console.error(
|
|
`[vitest] throttling local workers to ${localScheduling.maxWorkers}${
|
|
localScheduling.fileParallelism ? "" : " with file parallelism disabled"
|
|
} because the host already looks busy.`,
|
|
);
|
|
}
|
|
|
|
export const sharedVitestConfig = {
|
|
root: repoRoot,
|
|
envFile: false,
|
|
resolve: {
|
|
alias: [
|
|
{
|
|
find: "discord-api-types/v10",
|
|
replacement: path.join(repoRoot, "test", "vitest", "discord-api-types-v10-runtime.ts"),
|
|
},
|
|
{
|
|
find: "discord-api-types/gateway/v10",
|
|
replacement: path.join(
|
|
repoRoot,
|
|
"test",
|
|
"vitest",
|
|
"discord-api-types-gateway-v10-runtime.ts",
|
|
),
|
|
},
|
|
{
|
|
find: "discord-api-types/payloads/v10",
|
|
replacement: path.join(
|
|
repoRoot,
|
|
"test",
|
|
"vitest",
|
|
"discord-api-types-payloads-v10-runtime.ts",
|
|
),
|
|
},
|
|
{
|
|
find: "openclaw/extension-api",
|
|
replacement: path.join(repoRoot, "src", "extensionAPI.ts"),
|
|
},
|
|
{
|
|
find: "@openclaw/qa-channel/api.js",
|
|
replacement: path.join(repoRoot, "extensions", "qa-channel", "api.ts"),
|
|
},
|
|
{
|
|
find: "@openclaw/discord/api.js",
|
|
replacement: path.join(repoRoot, "extensions", "discord", "api.ts"),
|
|
},
|
|
{
|
|
find: "@openclaw/slack/api.js",
|
|
replacement: path.join(repoRoot, "extensions", "slack", "api.ts"),
|
|
},
|
|
{
|
|
find: "@openclaw/whatsapp/api.js",
|
|
replacement: path.join(repoRoot, "extensions", "whatsapp", "api.ts"),
|
|
},
|
|
...sourcePluginSdkSubpaths.map((subpath) => ({
|
|
find: `openclaw/plugin-sdk/${subpath}`,
|
|
replacement: path.join(repoRoot, "src", "plugin-sdk", `${subpath}.ts`),
|
|
})),
|
|
...pluginSdkSubpaths.map((subpath) => ({
|
|
find: `@openclaw/plugin-sdk/${subpath}`,
|
|
replacement: path.join(repoRoot, "packages", "plugin-sdk", "src", `${subpath}.ts`),
|
|
})),
|
|
{
|
|
find: "openclaw/plugin-sdk",
|
|
replacement: path.join(repoRoot, "src", "plugin-sdk", "index.ts"),
|
|
},
|
|
],
|
|
},
|
|
test: {
|
|
dir: repoRoot,
|
|
testTimeout: 120_000,
|
|
hookTimeout: isWindows ? 180_000 : 120_000,
|
|
unstubEnvs: true,
|
|
unstubGlobals: true,
|
|
isolate: false,
|
|
pool: defaultPool,
|
|
runner: nonIsolatedRunnerPath,
|
|
maxWorkers: workerConfig.maxWorkers,
|
|
fileParallelism: workerConfig.fileParallelism,
|
|
forceRerunTriggers: [
|
|
"package.json",
|
|
"pnpm-lock.yaml",
|
|
"test/setup.ts",
|
|
"test/setup.shared.ts",
|
|
"test/setup.extensions.ts",
|
|
"test/setup-openclaw-runtime.ts",
|
|
"test/vitest/vitest.channel-paths.mjs",
|
|
"test/vitest/vitest.agents-paths.mjs",
|
|
"test/vitest/vitest.agents-core.config.ts",
|
|
"test/vitest/vitest.agents-embedded-agent.config.ts",
|
|
"test/vitest/vitest.agents-support.config.ts",
|
|
"test/vitest/vitest.agents-tools.config.ts",
|
|
"test/vitest/vitest.channels.config.ts",
|
|
"test/vitest/vitest.acp.config.ts",
|
|
"test/vitest/vitest.boundary.config.ts",
|
|
"test/vitest/vitest.bundled.config.ts",
|
|
"test/vitest/vitest.cli.config.ts",
|
|
"vitest.config.ts",
|
|
"test/vitest/vitest.contracts-shared.ts",
|
|
"test/vitest/vitest.contracts-channel-surface.config.ts",
|
|
"test/vitest/vitest.contracts-channel-config.config.ts",
|
|
"test/vitest/vitest.contracts-channel-registry.config.ts",
|
|
"test/vitest/vitest.contracts-channel-session.config.ts",
|
|
"test/vitest/vitest.contracts-plugin.config.ts",
|
|
"test/vitest/vitest.cron.config.ts",
|
|
"test/vitest/vitest.daemon.config.ts",
|
|
"test/vitest/vitest.e2e.config.ts",
|
|
"test/vitest/vitest.extension-acpx-paths.mjs",
|
|
"test/vitest/vitest.extension-acpx.config.ts",
|
|
"test/vitest/vitest.extension-channel-single-config.ts",
|
|
"test/vitest/vitest.extension-channel-split-paths.mjs",
|
|
"test/vitest/vitest.extension-channels.config.ts",
|
|
"test/vitest/vitest.extension-diffs-paths.mjs",
|
|
"test/vitest/vitest.extension-diffs.config.ts",
|
|
"test/vitest/vitest.extension-discord.config.ts",
|
|
"test/vitest/vitest.extension-active-memory-paths.mjs",
|
|
"test/vitest/vitest.extension-active-memory.config.ts",
|
|
"test/vitest/vitest.extension-codex-paths.mjs",
|
|
"test/vitest/vitest.extension-codex.config.ts",
|
|
"test/vitest/vitest.extension-feishu-paths.mjs",
|
|
"test/vitest/vitest.extension-feishu.config.ts",
|
|
"test/vitest/vitest.extension-imessage.config.ts",
|
|
"test/vitest/vitest.extension-irc-paths.mjs",
|
|
"test/vitest/vitest.extension-irc.config.ts",
|
|
"test/vitest/vitest.extension-line.config.ts",
|
|
"test/vitest/vitest.extension-mattermost-paths.mjs",
|
|
"test/vitest/vitest.extension-mattermost.config.ts",
|
|
"test/vitest/vitest.extension-matrix-paths.mjs",
|
|
"test/vitest/vitest.extension-matrix.config.ts",
|
|
"test/vitest/vitest.extension-memory-paths.mjs",
|
|
"test/vitest/vitest.extension-memory.config.ts",
|
|
"test/vitest/vitest.extension-messaging-paths.mjs",
|
|
"test/vitest/vitest.extension-messaging.config.ts",
|
|
"test/vitest/vitest.extension-msteams-paths.mjs",
|
|
"test/vitest/vitest.extension-msteams.config.ts",
|
|
"test/vitest/vitest.extensions.config.ts",
|
|
"test/vitest/vitest.gateway.config.ts",
|
|
"test/vitest/vitest.gateway-core.config.ts",
|
|
"test/vitest/vitest.gateway-client.config.ts",
|
|
"test/vitest/vitest.gateway-methods.config.ts",
|
|
"test/vitest/vitest.gateway-server.config.ts",
|
|
"test/vitest/vitest.hooks.config.ts",
|
|
"test/vitest/vitest.infra.config.ts",
|
|
"test/vitest/vitest.live.config.ts",
|
|
"test/vitest/vitest.media.config.ts",
|
|
"test/vitest/vitest.media-understanding.config.ts",
|
|
"test/vitest/vitest.performance-config.ts",
|
|
"test/vitest/vitest.unit-fast.config.ts",
|
|
"test/vitest/vitest.unit-fast-paths.mjs",
|
|
"test/vitest/vitest.scoped-config.ts",
|
|
"test/vitest/vitest.shared-core.config.ts",
|
|
"test/vitest/vitest.shared.config.ts",
|
|
"test/vitest/vitest.tooling-isolated.config.ts",
|
|
"test/vitest/vitest.tooling.config.ts",
|
|
"test/vitest/vitest.tui.config.ts",
|
|
"test/vitest/vitest.ui.config.ts",
|
|
"test/vitest/vitest.utils.config.ts",
|
|
"test/vitest/vitest.unit.config.ts",
|
|
"test/vitest/vitest.unit-paths.mjs",
|
|
"test/vitest/vitest.runtime-config.config.ts",
|
|
"test/vitest/vitest.secrets.config.ts",
|
|
"test/vitest/vitest.plugin-sdk.config.ts",
|
|
"test/vitest/vitest.plugins.config.ts",
|
|
"test/vitest/vitest.extension-telegram-paths.mjs",
|
|
"test/vitest/vitest.extension-telegram.config.ts",
|
|
"test/vitest/vitest.extension-voice-call-paths.mjs",
|
|
"test/vitest/vitest.extension-voice-call.config.ts",
|
|
"test/vitest/vitest.extension-whatsapp-paths.mjs",
|
|
"test/vitest/vitest.extension-whatsapp.config.ts",
|
|
"test/vitest/vitest.extension-zalo-paths.mjs",
|
|
"test/vitest/vitest.extension-zalo.config.ts",
|
|
"test/vitest/vitest.extension-provider-paths.mjs",
|
|
"test/vitest/vitest.extension-provider-openai.config.ts",
|
|
"test/vitest/vitest.extension-providers.config.ts",
|
|
"test/vitest/vitest.extension-signal.config.ts",
|
|
"test/vitest/vitest.extension-slack.config.ts",
|
|
"test/vitest/vitest.logging.config.ts",
|
|
"test/vitest/vitest.process.config.ts",
|
|
"test/vitest/vitest.tasks.config.ts",
|
|
"test/vitest/vitest.wizard.config.ts",
|
|
],
|
|
include: [
|
|
"src/**/*.test.ts",
|
|
BUNDLED_PLUGIN_TEST_GLOB,
|
|
"packages/**/*.test.ts",
|
|
"test/**/*.test.ts",
|
|
"ui/src/ui/app-chat.test.ts",
|
|
"ui/src/ui/chat/**/*.test.ts",
|
|
"ui/src/ui/views/agents-utils.test.ts",
|
|
"ui/src/ui/views/channels.test.ts",
|
|
"ui/src/ui/views/chat.test.ts",
|
|
"ui/src/ui/views/nodes.devices.test.ts",
|
|
"ui/src/ui/views/skills.test.ts",
|
|
"ui/src/ui/views/dreaming.test.ts",
|
|
"ui/src/ui/views/usage-render-details.test.ts",
|
|
"ui/src/ui/controllers/agents.test.ts",
|
|
"ui/src/ui/controllers/chat.test.ts",
|
|
"ui/src/ui/controllers/skills.test.ts",
|
|
"ui/src/ui/controllers/sessions.test.ts",
|
|
"ui/src/ui/views/sessions.test.ts",
|
|
"ui/src/ui/app-tool-stream.node.test.ts",
|
|
"ui/src/ui/app-gateway.sessions.node.test.ts",
|
|
"ui/src/ui/chat/slash-command-executor.node.test.ts",
|
|
],
|
|
setupFiles: [resolveRepoRootPath("test/setup.ts")],
|
|
exclude: [
|
|
"dist/**",
|
|
"test/fixtures/**",
|
|
"apps/macos/**",
|
|
"apps/macos/.build/**",
|
|
"**/node_modules/**",
|
|
"**/vendor/**",
|
|
"dist/OpenClaw.app/**",
|
|
"**/._*",
|
|
"**/*.live.test.ts",
|
|
"**/*.e2e.test.ts",
|
|
],
|
|
coverage: {
|
|
provider: "v8" as const,
|
|
reporter: ["text", "lcov"],
|
|
all: false,
|
|
thresholds: {
|
|
lines: 70,
|
|
functions: 70,
|
|
branches: 55,
|
|
statements: 70,
|
|
},
|
|
exclude: [
|
|
`${BUNDLED_PLUGIN_ROOT_DIR}/**`,
|
|
"apps/**",
|
|
"ui/**",
|
|
"test/**",
|
|
"src/**/*.test.ts",
|
|
"src/entry.ts",
|
|
"src/index.ts",
|
|
"src/runtime.ts",
|
|
"src/logging.ts",
|
|
"src/cli/**",
|
|
"src/commands/**",
|
|
"src/daemon/**",
|
|
"src/hooks/**",
|
|
"src/macos/**",
|
|
"src/acp/**",
|
|
"src/agents/**",
|
|
"src/channels/**",
|
|
"src/gateway/**",
|
|
"src/line/**",
|
|
"src/media-understanding/**",
|
|
"src/node-host/**",
|
|
"src/plugins/**",
|
|
"src/providers/**",
|
|
"src/secrets/**",
|
|
"src/agents/model-scan.ts",
|
|
"src/agents/embedded-agent-runner.ts",
|
|
"src/agents/sandbox-paths.ts",
|
|
"src/agents/sandbox.ts",
|
|
"src/agents/skills-install.ts",
|
|
"src/agents/agent-tool-definition-adapter.ts",
|
|
"src/agents/tools/discord-actions*.ts",
|
|
"src/agents/tools/slack-actions.ts",
|
|
"src/infra/state-migrations.ts",
|
|
"src/infra/skills-remote.ts",
|
|
"src/infra/update-check.ts",
|
|
"src/infra/ports-inspect.ts",
|
|
"src/infra/outbound/outbound-session.ts",
|
|
"src/memory/batch-gemini.ts",
|
|
"src/gateway/control-ui.ts",
|
|
"src/gateway/server-bridge.ts",
|
|
"src/gateway/server-channels.ts",
|
|
"src/gateway/server-methods/config.ts",
|
|
"src/gateway/server-methods/send.ts",
|
|
"src/gateway/server-methods/skills.ts",
|
|
"src/gateway/server-methods/talk.ts",
|
|
"src/gateway/server-methods/web.ts",
|
|
"src/gateway/server-methods/wizard.ts",
|
|
"src/gateway/call.ts",
|
|
"src/process/tau-rpc.ts",
|
|
"src/process/exec.ts",
|
|
"src/tui/**",
|
|
"src/wizard/**",
|
|
"src/browser/**",
|
|
"src/webchat/**",
|
|
"src/gateway/server.ts",
|
|
"src/gateway/client.ts",
|
|
"src/gateway/protocol/**",
|
|
"src/infra/tailscale.ts",
|
|
],
|
|
},
|
|
...loadVitestExperimentalConfig(),
|
|
},
|
|
};
|