tftsr-devops_investigation/node_modules/@wdio/globals/build/index.js

102 lines
2.4 KiB
JavaScript
Raw Normal View History

feat: initial implementation of TFTSR IT Triage & RCA application 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>
2026-03-15 03:36:25 +00:00
// 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
};