tests for enforce policy
This commit is contained in:
@@ -0,0 +1,58 @@
|
|||||||
|
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
||||||
|
import * as fs from 'node:fs';
|
||||||
|
import * as path from 'node:path';
|
||||||
|
import * as os from 'node:os';
|
||||||
|
import { checkReports } from './enforce-policy.js';
|
||||||
|
|
||||||
|
describe('enforce-policy', () => {
|
||||||
|
let tempDir: string;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'reports-'));
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
fs.rmSync(tempDir, { recursive: true, force: true });
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should find vulnerabilities above threshold in SARIF', () => {
|
||||||
|
const sarifData = {
|
||||||
|
runs: [{
|
||||||
|
results: [
|
||||||
|
{ properties: { 'security-severity': '8.5' } },
|
||||||
|
{ properties: { 'security-severity': '5.0' } }
|
||||||
|
]
|
||||||
|
}]
|
||||||
|
};
|
||||||
|
fs.writeFileSync(path.join(tempDir, 'test.sarif'), JSON.stringify(sarifData));
|
||||||
|
|
||||||
|
const findings = checkReports(tempDir, 7.0);
|
||||||
|
expect(findings).toHaveLength(1);
|
||||||
|
expect(findings[0].name).toBe('test.sarif');
|
||||||
|
expect(findings[0].score).toBe(8.5);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should find vulnerabilities above threshold in JSON', () => {
|
||||||
|
const jsonData = {
|
||||||
|
findings: [
|
||||||
|
{ cvss: 9.0 },
|
||||||
|
{ score: 6.5 }
|
||||||
|
]
|
||||||
|
};
|
||||||
|
fs.writeFileSync(path.join(tempDir, 'test.json'), JSON.stringify(jsonData));
|
||||||
|
|
||||||
|
const findings = checkReports(tempDir, 7.0);
|
||||||
|
expect(findings).toHaveLength(1);
|
||||||
|
expect(findings[0].name).toBe('test.json');
|
||||||
|
expect(findings[0].score).toBe(9.0);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should set process.exitCode = 1 for invalid JSON', () => {
|
||||||
|
fs.writeFileSync(path.join(tempDir, 'invalid.json'), '{ "bad": json');
|
||||||
|
|
||||||
|
const findings = checkReports(tempDir, 7.0);
|
||||||
|
expect(findings).toHaveLength(0);
|
||||||
|
expect(process.exitCode).toBe(1);
|
||||||
|
process.exitCode = 0; // reset for other tests
|
||||||
|
});
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user