Implements Phases 1-8 of the TFTSR implementation plan. Rust backend (Tauri 2.x, src-tauri/): - Multi-provider AI: OpenAI-compatible, Anthropic, Gemini, Mistral, Ollama - PII detection engine: 11 regex patterns with overlap resolution - SQLCipher AES-256 encrypted database with 10 versioned migrations - 28 Tauri IPC commands for triage, analysis, document, and system ops - Ollama: hardware probe, model recommendations, pull/delete with events - RCA and blameless post-mortem Markdown document generators - PDF export via printpdf - Audit log: SHA-256 hash of every external data send - Integration stubs for Confluence, ServiceNow, Azure DevOps (v0.2) Frontend (React 18 + TypeScript + Vite, src/): - 9 pages: full triage workflow NewIssue→LogUpload→Triage→Resolution→RCA→Postmortem→History+Settings - 7 components: ChatWindow, TriageProgress, PiiDiffViewer, DocEditor, HardwareReport, ModelSelector, UI primitives - 3 Zustand stores: session, settings (persisted), history - Type-safe tauriCommands.ts matching Rust backend types exactly - 8 IT domain system prompts (Linux, Windows, Network, K8s, DB, Virt, HW, Obs) DevOps: - .woodpecker/test.yml: rustfmt, clippy, cargo test, tsc, vitest on every push - .woodpecker/release.yml: linux/amd64 + linux/arm64 builds, Gogs release upload Verified: - cargo check: zero errors - tsc --noEmit: zero errors - vitest run: 13/13 unit tests passing Co-Authored-By: Claude Sonnet 4.6 (1M context) <noreply@anthropic.com>
102 lines
2.4 KiB
JavaScript
102 lines
2.4 KiB
JavaScript
// src/index.ts
|
|
var globals = globalThis._wdioGlobals = globalThis._wdioGlobals || /* @__PURE__ */ new Map();
|
|
var GLOBALS_ERROR_MESSAGE = `No browser instance registered. Don't import @wdio/globals outside of the WDIO testrunner context. Or you have two two different "@wdio/globals" packages installed.`;
|
|
function proxyHandler(key) {
|
|
return {
|
|
get: (self, prop) => {
|
|
if (!globals.has(key)) {
|
|
throw new Error(GLOBALS_ERROR_MESSAGE);
|
|
}
|
|
const receiver = globals.get(key);
|
|
const field = receiver[prop];
|
|
return typeof field === "function" ? field.bind(receiver) : field;
|
|
}
|
|
};
|
|
}
|
|
var browser = new Proxy(
|
|
class Browser {
|
|
},
|
|
proxyHandler("browser")
|
|
);
|
|
var driver = new Proxy(
|
|
class Browser2 {
|
|
},
|
|
proxyHandler("driver")
|
|
);
|
|
var multiremotebrowser = new Proxy(
|
|
class Browser3 {
|
|
},
|
|
proxyHandler("multiremotebrowser")
|
|
);
|
|
var multiRemoteBrowser = new Proxy(
|
|
class Browser4 {
|
|
},
|
|
proxyHandler("multiRemoteBrowser")
|
|
);
|
|
var $ = (...args) => {
|
|
if (!globals.has("$")) {
|
|
throw new Error(GLOBALS_ERROR_MESSAGE);
|
|
}
|
|
return globals.get("$")(...args);
|
|
};
|
|
var $$ = (...args) => {
|
|
if (!globals.has("$$")) {
|
|
throw new Error(GLOBALS_ERROR_MESSAGE);
|
|
}
|
|
return globals.get("$$")(...args);
|
|
};
|
|
var expect = (...args) => {
|
|
if (!globals.has("expect")) {
|
|
throw new Error(GLOBALS_ERROR_MESSAGE);
|
|
}
|
|
return globals.get("expect")(...args);
|
|
};
|
|
var ASYNC_MATCHERS = [
|
|
"any",
|
|
"anything",
|
|
"arrayContaining",
|
|
"objectContaining",
|
|
"stringContaining",
|
|
"stringMatching"
|
|
];
|
|
for (const matcher of ASYNC_MATCHERS) {
|
|
expect[matcher] = (...args) => {
|
|
if (!globals.has("expect")) {
|
|
throw new Error(GLOBALS_ERROR_MESSAGE);
|
|
}
|
|
return globals.get("expect")[matcher](...args);
|
|
};
|
|
}
|
|
expect.not = ASYNC_MATCHERS.reduce((acc, matcher) => {
|
|
acc[matcher] = (...args) => {
|
|
if (!globals.has("expect")) {
|
|
throw new Error(GLOBALS_ERROR_MESSAGE);
|
|
}
|
|
return globals.get("expect").not[matcher](...args);
|
|
};
|
|
return acc;
|
|
}, {});
|
|
expect.extend = (...args) => {
|
|
if (!globals.has("expect")) {
|
|
throw new Error(GLOBALS_ERROR_MESSAGE);
|
|
}
|
|
const expect2 = globals.get("expect");
|
|
return expect2.extend(...args);
|
|
};
|
|
function _setGlobal(key, value, setGlobal = true) {
|
|
globals.set(key, value);
|
|
if (setGlobal) {
|
|
globalThis[key] = value;
|
|
}
|
|
}
|
|
export {
|
|
$,
|
|
$$,
|
|
_setGlobal,
|
|
browser,
|
|
driver,
|
|
expect,
|
|
multiRemoteBrowser,
|
|
multiremotebrowser
|
|
};
|