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>
90 lines
1.7 KiB
JavaScript
90 lines
1.7 KiB
JavaScript
'use strict';
|
|
|
|
var Runnable = require('./runnable');
|
|
const {inherits, constants} = require('./utils');
|
|
const {MOCHA_ID_PROP_NAME} = constants;
|
|
|
|
/**
|
|
* Expose `Hook`.
|
|
*/
|
|
|
|
module.exports = Hook;
|
|
|
|
/**
|
|
* Initialize a new `Hook` with the given `title` and callback `fn`
|
|
*
|
|
* @class
|
|
* @extends Runnable
|
|
* @param {String} title
|
|
* @param {Function} fn
|
|
*/
|
|
function Hook(title, fn) {
|
|
Runnable.call(this, title, fn);
|
|
this.type = 'hook';
|
|
}
|
|
|
|
/**
|
|
* Inherit from `Runnable.prototype`.
|
|
*/
|
|
inherits(Hook, Runnable);
|
|
|
|
/**
|
|
* Resets the state for a next run.
|
|
*/
|
|
Hook.prototype.reset = function () {
|
|
Runnable.prototype.reset.call(this);
|
|
delete this._error;
|
|
};
|
|
|
|
/**
|
|
* Get or set the test `err`.
|
|
*
|
|
* @memberof Hook
|
|
* @public
|
|
* @param {Error} err
|
|
* @return {Error}
|
|
*/
|
|
Hook.prototype.error = function (err) {
|
|
if (!arguments.length) {
|
|
err = this._error;
|
|
this._error = null;
|
|
return err;
|
|
}
|
|
|
|
this._error = err;
|
|
};
|
|
|
|
/**
|
|
* Returns an object suitable for IPC.
|
|
* Functions are represented by keys beginning with `$$`.
|
|
* @private
|
|
* @returns {Object}
|
|
*/
|
|
Hook.prototype.serialize = function serialize() {
|
|
return {
|
|
$$currentRetry: this.currentRetry(),
|
|
$$fullTitle: this.fullTitle(),
|
|
$$isPending: Boolean(this.isPending()),
|
|
$$titlePath: this.titlePath(),
|
|
ctx:
|
|
this.ctx && this.ctx.currentTest
|
|
? {
|
|
currentTest: {
|
|
title: this.ctx.currentTest.title,
|
|
[MOCHA_ID_PROP_NAME]: this.ctx.currentTest.id
|
|
}
|
|
}
|
|
: {},
|
|
duration: this.duration,
|
|
file: this.file,
|
|
parent: {
|
|
$$fullTitle: this.parent.fullTitle(),
|
|
[MOCHA_ID_PROP_NAME]: this.parent.id
|
|
},
|
|
state: this.state,
|
|
title: this.title,
|
|
type: this.type,
|
|
[MOCHA_ID_PROP_NAME]: this.id
|
|
};
|
|
};
|