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>
79 lines
3.1 KiB
TypeScript
79 lines
3.1 KiB
TypeScript
import type { FakeTimerInstallOpts, InstalledClock, install } from '@sinonjs/fake-timers';
|
|
declare global {
|
|
interface Window {
|
|
__clock: InstalledClock;
|
|
__wdio_sinon: {
|
|
install: typeof install;
|
|
};
|
|
}
|
|
}
|
|
export declare class ClockManager {
|
|
#private;
|
|
constructor(browser: WebdriverIO.Browser);
|
|
/**
|
|
* Install fake timers on the browser. If you call the `emulate` command, WebdriverIO will automatically install
|
|
* the fake timers for you. You can use this method to re-install the fake timers if you have called `restore`.
|
|
*
|
|
* @param options {FakeTimerInstallOpts} Options to pass to the fake clock
|
|
* @returns {Promise<void>}
|
|
*/
|
|
install(options?: FakeTimerInstallOpts): Promise<void>;
|
|
/**
|
|
* Restore all overridden native functions. This is automatically called between tests, so should not
|
|
* generally be needed.
|
|
*
|
|
* ```ts
|
|
* it('should restore the clock', async () => {
|
|
* console.log(new Date()) // returns e.g. 1722560447102
|
|
*
|
|
* const clock = await browser.emulate('clock', { now: new Date(2021, 3, 14) })
|
|
* console.log(await browser.execute(() => new Date().getTime())) // returns 1618383600000
|
|
*
|
|
* await clock.restore()
|
|
* console.log(await browser.execute(() => new Date().getTime())) // returns 1722560447102
|
|
* })
|
|
* ```
|
|
*
|
|
* @returns {Promise<void>}
|
|
*/
|
|
restore(): Promise<void>;
|
|
/**
|
|
* Move the clock the specified number of `milliseconds`. Any timers within the affected range of time will be called.
|
|
* @param ms {number} The number of milliseconds to move the clock.
|
|
*
|
|
* ```ts
|
|
* it('should move the clock', async () => {
|
|
* console.log(new Date()) // returns e.g. 1722560447102
|
|
*
|
|
* const clock = await browser.emulate('clock', { now: new Date(2021, 3, 14) })
|
|
* console.log(await browser.execute(() => new Date().getTime())) // returns 1618383600000
|
|
*
|
|
* await clock.tick(1000)
|
|
* console.log(await browser.execute(() => new Date().getTime())) // returns 1618383601000
|
|
* })
|
|
* ```
|
|
*
|
|
* @param {number} ms The number of milliseconds to move the clock.
|
|
* @returns {Promise<void>}
|
|
*/
|
|
tick(ms: number): Promise<void>;
|
|
/**
|
|
* Change the system time to the new now. Now can be a timestamp, date object, or not passed in which defaults
|
|
* to 0. No timers will be called, nor will the time left before they trigger change.
|
|
*
|
|
* ```ts
|
|
* it('should set the system time', async () => {
|
|
* const clock = await browser.emulate('clock', { now: new Date(2021, 3, 14) })
|
|
* console.log(await browser.execute(() => new Date().getTime())) // returns 1618383600000
|
|
*
|
|
* await clock.setSystemTime(new Date(2011, 3, 15))
|
|
* console.log(await browser.execute(() => new Date().getTime())) // returns 1302850800000
|
|
* })
|
|
* ```
|
|
*
|
|
* @param date {Date|number} The new date to set the system time to.
|
|
* @returns {Promise<void>}
|
|
*/
|
|
setSystemTime(date: number | Date): Promise<void>;
|
|
}
|
|
//# sourceMappingURL=clock.d.ts.map
|