52 lines
1.9 KiB
JavaScript
52 lines
1.9 KiB
JavaScript
import { describe, it, beforeEach } from 'node:test';
|
|
import assert from 'node:assert/strict';
|
|
import { resolve } from 'node:path';
|
|
import { fileURLToPath } from 'node:url';
|
|
import { execFile } from 'node:child_process';
|
|
import { promisify } from 'node:util';
|
|
|
|
const exec = promisify(execFile);
|
|
const __dirname = fileURLToPath(new URL('.', import.meta.url));
|
|
const FIXTURES = resolve(__dirname, '../fixtures');
|
|
const POSTURE_BIN = resolve(__dirname, '../../scanners/posture.mjs');
|
|
|
|
async function runPostureJson(fixturePath) {
|
|
const { stdout } = await exec('node', [POSTURE_BIN, fixturePath, '--json'], {
|
|
timeout: 30000,
|
|
cwd: resolve(__dirname, '../..'),
|
|
});
|
|
return JSON.parse(stdout);
|
|
}
|
|
|
|
describe('posture grade stability — baseline-all-a', () => {
|
|
let result;
|
|
beforeEach(async () => {
|
|
result = await runPostureJson(resolve(FIXTURES, 'baseline-all-a'));
|
|
});
|
|
|
|
it('overallGrade is A', () => {
|
|
assert.equal(result.overallGrade, 'A');
|
|
});
|
|
|
|
it('every quality area (non-Feature Coverage) has grade A', () => {
|
|
const qualityAreas = result.areas.filter(a => a.name !== 'Feature Coverage');
|
|
for (const area of qualityAreas) {
|
|
assert.equal(area.grade, 'A', `${area.name} has grade ${area.grade}, expected A (score=${area.score})`);
|
|
}
|
|
});
|
|
|
|
it('has no critical or high findings across scanners', () => {
|
|
const scanners = result.scannerEnvelope.scanners;
|
|
for (const s of scanners) {
|
|
assert.equal(s.counts.critical, 0, `${s.scanner} has ${s.counts.critical} critical findings`);
|
|
assert.equal(s.counts.high, 0, `${s.scanner} has ${s.counts.high} high findings`);
|
|
}
|
|
});
|
|
|
|
it('Token Efficiency area scores grade A or B on baseline', () => {
|
|
const te = result.areas.find(a => a.id === 'token_efficiency');
|
|
assert.ok(te, 'expected token_efficiency area to be present');
|
|
assert.ok(['A', 'B'].includes(te.grade),
|
|
`Token Efficiency grade is ${te.grade}, expected A or B (score=${te.score})`);
|
|
});
|
|
});
|