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>
65 lines
1.8 KiB
JavaScript
65 lines
1.8 KiB
JavaScript
var test = require('tape');
|
|
var functionsHaveNames = require('functions-have-names');
|
|
var hasSymbols = require('has-symbols');
|
|
|
|
require('./legacy-compat');
|
|
var common = require('./common');
|
|
|
|
// we do this to easily wrap each file in a mocha test
|
|
// and also have browserify be able to statically analyze this file
|
|
var orig_require = require;
|
|
var require = function(file) {
|
|
test(file, function(t) {
|
|
// Store the tape object so tests can access it.
|
|
t.on('end', function () { delete common.test; });
|
|
common.test = t;
|
|
|
|
try {
|
|
var exp = orig_require(file);
|
|
if (exp && exp.then) {
|
|
exp.then(function () { t.end(); }, t.fail);
|
|
return;
|
|
}
|
|
} catch (err) {
|
|
t.fail(err);
|
|
}
|
|
t.end();
|
|
});
|
|
};
|
|
|
|
require('./add-listeners.js');
|
|
require('./check-listener-leaks.js');
|
|
require('./errors.js');
|
|
require('./events-list.js');
|
|
if (typeof Promise === 'function') {
|
|
require('./events-once.js');
|
|
} else {
|
|
// Promise support is not available.
|
|
test('./events-once.js', { skip: true }, function () {});
|
|
}
|
|
require('./listener-count.js');
|
|
require('./listeners-side-effects.js');
|
|
require('./listeners.js');
|
|
require('./max-listeners.js');
|
|
if (functionsHaveNames()) {
|
|
require('./method-names.js');
|
|
} else {
|
|
// Function.name is not supported in IE
|
|
test('./method-names.js', { skip: true }, function () {});
|
|
}
|
|
require('./modify-in-emit.js');
|
|
require('./num-args.js');
|
|
require('./once.js');
|
|
require('./prepend.js');
|
|
require('./set-max-listeners-side-effects.js');
|
|
require('./special-event-names.js');
|
|
require('./subclass.js');
|
|
if (hasSymbols()) {
|
|
require('./symbols.js');
|
|
} else {
|
|
// Symbol is not available.
|
|
test('./symbols.js', { skip: true }, function () {});
|
|
}
|
|
require('./remove-all-listeners.js');
|
|
require('./remove-listeners.js');
|