tftsr-devops_investigation/node_modules/@wdio/globals/build/index.js
Shaun Arman 8839075805 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-14 22:36:25 -05:00

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
};