forked from extern/bruno
200 lines
5.8 KiB
JavaScript
200 lines
5.8 KiB
JavaScript
const { describe, it, expect } = require('@jest/globals');
|
|
const xmlbuilder = require('xmlbuilder');
|
|
const fs = require('fs');
|
|
|
|
const { printRunSummary, makeJunitOutput } = require('../../src/commands/run');
|
|
|
|
describe('printRunSummary', () => {
|
|
// Suppress console.log output
|
|
jest.spyOn(console, 'log').mockImplementation(() => {});
|
|
|
|
it('should produce the correct summary for a successful run', () => {
|
|
const results = [
|
|
{
|
|
testResults: [{ status: 'pass' }, { status: 'pass' }, { status: 'pass' }],
|
|
assertionResults: [{ status: 'pass' }, { status: 'pass' }],
|
|
error: null
|
|
},
|
|
{
|
|
testResults: [{ status: 'pass' }, { status: 'pass' }],
|
|
assertionResults: [{ status: 'pass' }, { status: 'pass' }, { status: 'pass' }],
|
|
error: null
|
|
}
|
|
];
|
|
|
|
const summary = printRunSummary(results);
|
|
|
|
expect(summary.totalRequests).toBe(2);
|
|
expect(summary.passedRequests).toBe(2);
|
|
expect(summary.failedRequests).toBe(0);
|
|
expect(summary.totalAssertions).toBe(5);
|
|
expect(summary.passedAssertions).toBe(5);
|
|
expect(summary.failedAssertions).toBe(0);
|
|
expect(summary.totalTests).toBe(5);
|
|
expect(summary.passedTests).toBe(5);
|
|
expect(summary.failedTests).toBe(0);
|
|
});
|
|
|
|
it('should produce the correct summary for a failed run', () => {
|
|
const results = [
|
|
{
|
|
testResults: [{ status: 'fail' }, { status: 'pass' }, { status: 'pass' }],
|
|
assertionResults: [{ status: 'pass' }, { status: 'fail' }],
|
|
error: null
|
|
},
|
|
{
|
|
testResults: [{ status: 'pass' }, { status: 'fail' }],
|
|
assertionResults: [{ status: 'pass' }, { status: 'fail' }, { status: 'fail' }],
|
|
error: null
|
|
},
|
|
{
|
|
testResults: [],
|
|
assertionResults: [],
|
|
error: new Error('Request failed')
|
|
}
|
|
];
|
|
|
|
const summary = printRunSummary(results);
|
|
|
|
expect(summary.totalRequests).toBe(3);
|
|
expect(summary.passedRequests).toBe(2);
|
|
expect(summary.failedRequests).toBe(1);
|
|
expect(summary.totalAssertions).toBe(5);
|
|
expect(summary.passedAssertions).toBe(2);
|
|
expect(summary.failedAssertions).toBe(3);
|
|
expect(summary.totalTests).toBe(5);
|
|
expect(summary.passedTests).toBe(3);
|
|
expect(summary.failedTests).toBe(2);
|
|
});
|
|
});
|
|
|
|
describe('makeJUnitOutput', () => {
|
|
let createStub = jest.fn();
|
|
|
|
beforeEach(() => {
|
|
jest.spyOn(xmlbuilder, 'create').mockImplementation(() => {
|
|
return { end: createStub };
|
|
});
|
|
jest.spyOn(fs, 'writeFileSync').mockImplementation(() => {});
|
|
});
|
|
|
|
afterEach(() => {
|
|
jest.restoreAllMocks();
|
|
});
|
|
|
|
it('should produce a junit spec object for serialization', () => {
|
|
const results = [
|
|
{
|
|
description: 'description provided',
|
|
suitename: 'Tests/Suite A',
|
|
request: {
|
|
method: 'GET',
|
|
url: 'https://ima.test'
|
|
},
|
|
assertionResults: [
|
|
{
|
|
lhsExpr: 'res.status',
|
|
rhsExpr: 'eq 200',
|
|
status: 'pass'
|
|
},
|
|
{
|
|
lhsExpr: 'res.status',
|
|
rhsExpr: 'neq 200',
|
|
status: 'fail',
|
|
error: 'expected 200 to not equal 200'
|
|
}
|
|
],
|
|
runtime: 1.2345678
|
|
},
|
|
{
|
|
request: {
|
|
method: 'GET',
|
|
url: 'https://imanother.test'
|
|
},
|
|
suitename: 'Tests/Suite B',
|
|
testResults: [
|
|
{
|
|
lhsExpr: 'res.status',
|
|
rhsExpr: 'eq 200',
|
|
description: 'A test that passes',
|
|
status: 'pass'
|
|
},
|
|
{
|
|
description: 'A test that fails',
|
|
status: 'fail',
|
|
error: 'expected 200 to not equal 200',
|
|
status: 'fail'
|
|
}
|
|
],
|
|
runtime: 2.3456789
|
|
}
|
|
];
|
|
|
|
makeJunitOutput(results, '/tmp/testfile.xml');
|
|
expect(createStub).toBeCalled;
|
|
|
|
const junit = xmlbuilder.create.mock.calls[0][0];
|
|
|
|
expect(junit.testsuites).toBeDefined;
|
|
expect(junit.testsuites.testsuite.length).toBe(2);
|
|
expect(junit.testsuites.testsuite[0].testcase.length).toBe(2);
|
|
expect(junit.testsuites.testsuite[1].testcase.length).toBe(2);
|
|
|
|
expect(junit.testsuites.testsuite[0]['@name']).toBe('Tests/Suite A');
|
|
expect(junit.testsuites.testsuite[1]['@name']).toBe('Tests/Suite B');
|
|
|
|
expect(junit.testsuites.testsuite[0]['@tests']).toBe(2);
|
|
expect(junit.testsuites.testsuite[1]['@tests']).toBe(2);
|
|
|
|
const testcase = junit.testsuites.testsuite[0].testcase[0];
|
|
|
|
expect(testcase['@name']).toBe('res.status eq 200');
|
|
expect(testcase['@status']).toBe('pass');
|
|
|
|
const failcase = junit.testsuites.testsuite[0].testcase[1];
|
|
|
|
expect(failcase['@name']).toBe('res.status neq 200');
|
|
expect(failcase.failure).toBeDefined;
|
|
expect(failcase.failure[0]['@type']).toBe('failure');
|
|
});
|
|
|
|
it('should handle request errors', () => {
|
|
const results = [
|
|
{
|
|
description: 'description provided',
|
|
suitename: 'Tests/Suite A',
|
|
request: {
|
|
method: 'GET',
|
|
url: 'https://ima.test'
|
|
},
|
|
assertionResults: [
|
|
{
|
|
lhsExpr: 'res.status',
|
|
rhsExpr: 'eq 200',
|
|
status: 'fail'
|
|
}
|
|
],
|
|
runtime: 1.2345678,
|
|
error: 'timeout of 2000ms exceeded'
|
|
}
|
|
];
|
|
|
|
makeJunitOutput(results, '/tmp/testfile.xml');
|
|
|
|
const junit = xmlbuilder.create.mock.calls[0][0];
|
|
|
|
expect(createStub).toBeCalled;
|
|
|
|
expect(junit.testsuites).toBeDefined;
|
|
expect(junit.testsuites.testsuite.length).toBe(1);
|
|
expect(junit.testsuites.testsuite[0].testcase.length).toBe(1);
|
|
|
|
const failcase = junit.testsuites.testsuite[0].testcase[0];
|
|
|
|
expect(failcase['@name']).toBe('Test suite has no errors');
|
|
expect(failcase.error).toBeDefined;
|
|
expect(failcase.error[0]['@type']).toBe('error');
|
|
expect(failcase.error[0]['@message']).toBe('timeout of 2000ms exceeded');
|
|
});
|
|
});
|