mirror of
https://github.com/prompt-security/clawsec.git
synced 2026-06-13 05:28:02 +03:00
c9a66d5c99
* refactor: extract shared test harness module from 9 test files Extract duplicated test utilities into a reusable test_harness.mjs module to eliminate ~200-250 lines of boilerplate code across test files. Changes: - Create skills/clawsec-suite/test/lib/test_harness.mjs with: - Test reporting: pass(), fail(), report(), exitWithResults() - Crypto utilities: generateEd25519KeyPair(), signPayload() - Temp directory: createTempDir() with cleanup - Environment helpers: withEnv() for isolated env vars - Test runner factory: createTestRunner() for isolated counters - Refactor 9 test files to use shared harness: - feed_verification.test.mjs - guarded_install.test.mjs - skill_catalog_discovery.test.mjs - advisory_suppression.test.mjs - advisory_application_scope.test.mjs - path_resolution.test.mjs - fuzz_properties.test.mjs - suppression_config.test.mjs - render_report_suppression.test.mjs Benefits: - Single source of truth for test utilities - Consistent test reporting across all files - Easier to add new test files - Reduced maintenance burden Verification: - All 80 tests pass (15+8+3+15+4+6+1+17+11) - Zero ESLint warnings - No behavior changes - only code deduplication - Cross-skill module sharing works (openclaw-audit-watchdog → clawsec-suite) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com> * fix: update minimatch override to 10.2.4 to resolve ReDoS vulnerabilities Bump minimatch from 10.2.1 to 10.2.4 in overrides to fix 10 high-severity ReDoS vulnerabilities (GHSA-7r86-cg39-jmmj, GHSA-23c5-xmqv-rm74). Also add .venv/ to ESLint ignores to prevent linting Python venv files. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> --------- Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com>
44 lines
1.1 KiB
JSON
44 lines
1.1 KiB
JSON
{
|
|
"name": "ClawSec",
|
|
"private": true,
|
|
"license": "AGPL-3.0-or-later",
|
|
"version": "0.0.0",
|
|
"type": "module",
|
|
"scripts": {
|
|
"gen:wiki-llms": "node scripts/generate-wiki-llms.mjs",
|
|
"populate-local-wiki": "./scripts/populate-local-wiki.sh",
|
|
"predev": "npm run gen:wiki-llms",
|
|
"dev": "vite",
|
|
"prebuild": "npm run gen:wiki-llms",
|
|
"build": "vite build",
|
|
"preview": "vite preview"
|
|
},
|
|
"dependencies": {
|
|
"lucide-react": "^0.575.0",
|
|
"react": "^19.2.4",
|
|
"react-dom": "^19.2.4",
|
|
"react-markdown": "^10.1.0",
|
|
"react-router-dom": "^7.13.1",
|
|
"remark-gfm": "^4.0.1"
|
|
},
|
|
"devDependencies": {
|
|
"@eslint/js": "~9.28.0",
|
|
"@types/node": "^25.2.3",
|
|
"@typescript-eslint/eslint-plugin": "^8.55.0",
|
|
"@typescript-eslint/parser": "^8.56.0",
|
|
"@vitejs/plugin-react": "^5.1.4",
|
|
"eslint": "^9.39.2",
|
|
"eslint-plugin-react": "^7.37.5",
|
|
"eslint-plugin-react-hooks": "^7.0.1",
|
|
"fast-check": "^4.5.3",
|
|
"typescript": "~5.8.2",
|
|
"vite": "^7.3.1"
|
|
},
|
|
"overrides": {
|
|
"ajv": "6.14.0",
|
|
"balanced-match": "4.0.3",
|
|
"brace-expansion": "5.0.2",
|
|
"minimatch": "10.2.4"
|
|
}
|
|
}
|