mirror of
https://github.com/usebruno/bruno.git
synced 2025-01-20 12:48:41 +01:00
refactor for reporters directory
This commit is contained in:
parent
de530a889c
commit
ab37e53346
@ -1,12 +1,11 @@
|
|||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const chalk = require('chalk');
|
const chalk = require('chalk');
|
||||||
const os = require('os');
|
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const xmlbuilder = require('xmlbuilder');
|
|
||||||
const { forOwn, result } = require('lodash');
|
const { forOwn, result } = require('lodash');
|
||||||
const { exists, isFile, isDirectory } = require('../utils/filesystem');
|
const { exists, isFile, isDirectory } = require('../utils/filesystem');
|
||||||
const { runSingleRequest } = require('../runner/run-single-request');
|
const { runSingleRequest } = require('../runner/run-single-request');
|
||||||
const { bruToEnvJson, getEnvVars } = require('../utils/bru');
|
const { bruToEnvJson, getEnvVars } = require('../utils/bru');
|
||||||
|
const makeJUnitOutput = require('../reporters/junit');
|
||||||
const { rpad } = require('../utils/common');
|
const { rpad } = require('../utils/common');
|
||||||
const { bruToJson, getOptions, collectionBruToJson } = require('../utils/bru');
|
const { bruToJson, getOptions, collectionBruToJson } = require('../utils/bru');
|
||||||
const { dotenvToJson } = require('@usebruno/lang');
|
const { dotenvToJson } = require('@usebruno/lang');
|
||||||
@ -167,86 +166,6 @@ const getCollectionRoot = (dir) => {
|
|||||||
return collectionBruToJson(content);
|
return collectionBruToJson(content);
|
||||||
};
|
};
|
||||||
|
|
||||||
const makeJunitOutput = async (results, outputPath) => {
|
|
||||||
const output = {
|
|
||||||
testsuites: {
|
|
||||||
testsuite: []
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
results.forEach((result) => {
|
|
||||||
const assertionTestCount = result.assertionResults ? result.assertionResults.length : 0;
|
|
||||||
const testCount = result.testResults ? result.testResults.length : 0;
|
|
||||||
const totalTests = assertionTestCount + testCount;
|
|
||||||
|
|
||||||
const suite = {
|
|
||||||
'@name': result.suitename,
|
|
||||||
'@errors': 0,
|
|
||||||
'@failures': 0,
|
|
||||||
'@skipped': 0,
|
|
||||||
'@tests': totalTests,
|
|
||||||
'@timestamp': new Date().toISOString().split('Z')[0],
|
|
||||||
'@hostname': os.hostname(),
|
|
||||||
'@time': result.runtime.toFixed(3),
|
|
||||||
testcase: []
|
|
||||||
};
|
|
||||||
|
|
||||||
result.assertionResults &&
|
|
||||||
result.assertionResults.forEach((assertion) => {
|
|
||||||
const testcase = {
|
|
||||||
'@name': `${assertion.lhsExpr} ${assertion.rhsExpr}`,
|
|
||||||
'@status': assertion.status,
|
|
||||||
'@classname': result.request.url,
|
|
||||||
'@time': (result.runtime / totalTests).toFixed(3)
|
|
||||||
};
|
|
||||||
|
|
||||||
if (assertion.status === 'fail') {
|
|
||||||
suite['@failures']++;
|
|
||||||
|
|
||||||
testcase.failure = [{ '@type': 'failure', '@message': assertion.error }];
|
|
||||||
}
|
|
||||||
|
|
||||||
suite.testcase.push(testcase);
|
|
||||||
});
|
|
||||||
|
|
||||||
result.testResults &&
|
|
||||||
result.testResults.forEach((test) => {
|
|
||||||
const testcase = {
|
|
||||||
'@name': test.description,
|
|
||||||
'@status': test.status,
|
|
||||||
'@classname': result.request.url,
|
|
||||||
'@time': (result.runtime / totalTests).toFixed(3)
|
|
||||||
};
|
|
||||||
|
|
||||||
if (test.status === 'fail') {
|
|
||||||
suite['@failures']++;
|
|
||||||
|
|
||||||
testcase.failure = [{ '@type': 'failure', '@message': test.error }];
|
|
||||||
}
|
|
||||||
|
|
||||||
suite.testcase.push(testcase);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (result.error) {
|
|
||||||
suite['@errors'] = 1;
|
|
||||||
suite['@tests'] = 1;
|
|
||||||
suite.testcase = [
|
|
||||||
{
|
|
||||||
'@name': 'Test suite has no errors',
|
|
||||||
'@status': 'fail',
|
|
||||||
'@classname': result.request.url,
|
|
||||||
'@time': result.runtime.toFixed(3),
|
|
||||||
error: [{ '@type': 'error', '@message': result.error }]
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
output.testsuites.testsuite.push(suite);
|
|
||||||
});
|
|
||||||
|
|
||||||
fs.writeFileSync(outputPath, xmlbuilder.create(output).end({ pretty: true }));
|
|
||||||
};
|
|
||||||
|
|
||||||
const builder = async (yargs) => {
|
const builder = async (yargs) => {
|
||||||
yargs
|
yargs
|
||||||
.option('r', {
|
.option('r', {
|
||||||
@ -519,7 +438,7 @@ const handler = async function (argv) {
|
|||||||
if (format === 'json') {
|
if (format === 'json') {
|
||||||
fs.writeFileSync(outputPath, JSON.stringify(outputJson, null, 2));
|
fs.writeFileSync(outputPath, JSON.stringify(outputJson, null, 2));
|
||||||
} else if (format === 'junit') {
|
} else if (format === 'junit') {
|
||||||
makeJunitOutput(results, outputPath);
|
makeJUnitOutput(results, outputPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log(chalk.dim(chalk.grey(`Wrote results to ${outputPath}`)));
|
console.log(chalk.dim(chalk.grey(`Wrote results to ${outputPath}`)));
|
||||||
@ -540,6 +459,5 @@ module.exports = {
|
|||||||
desc,
|
desc,
|
||||||
builder,
|
builder,
|
||||||
handler,
|
handler,
|
||||||
printRunSummary,
|
printRunSummary
|
||||||
makeJunitOutput
|
|
||||||
};
|
};
|
||||||
|
85
packages/bruno-cli/src/reporters/junit.js
Normal file
85
packages/bruno-cli/src/reporters/junit.js
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
const os = require('os');
|
||||||
|
const fs = require('fs');
|
||||||
|
const xmlbuilder = require('xmlbuilder');
|
||||||
|
|
||||||
|
const makeJUnitOutput = async (results, outputPath) => {
|
||||||
|
const output = {
|
||||||
|
testsuites: {
|
||||||
|
testsuite: []
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
results.forEach((result) => {
|
||||||
|
const assertionTestCount = result.assertionResults ? result.assertionResults.length : 0;
|
||||||
|
const testCount = result.testResults ? result.testResults.length : 0;
|
||||||
|
const totalTests = assertionTestCount + testCount;
|
||||||
|
|
||||||
|
const suite = {
|
||||||
|
'@name': result.suitename,
|
||||||
|
'@errors': 0,
|
||||||
|
'@failures': 0,
|
||||||
|
'@skipped': 0,
|
||||||
|
'@tests': totalTests,
|
||||||
|
'@timestamp': new Date().toISOString().split('Z')[0],
|
||||||
|
'@hostname': os.hostname(),
|
||||||
|
'@time': result.runtime.toFixed(3),
|
||||||
|
testcase: []
|
||||||
|
};
|
||||||
|
|
||||||
|
result.assertionResults &&
|
||||||
|
result.assertionResults.forEach((assertion) => {
|
||||||
|
const testcase = {
|
||||||
|
'@name': `${assertion.lhsExpr} ${assertion.rhsExpr}`,
|
||||||
|
'@status': assertion.status,
|
||||||
|
'@classname': result.request.url,
|
||||||
|
'@time': (result.runtime / totalTests).toFixed(3)
|
||||||
|
};
|
||||||
|
|
||||||
|
if (assertion.status === 'fail') {
|
||||||
|
suite['@failures']++;
|
||||||
|
|
||||||
|
testcase.failure = [{ '@type': 'failure', '@message': assertion.error }];
|
||||||
|
}
|
||||||
|
|
||||||
|
suite.testcase.push(testcase);
|
||||||
|
});
|
||||||
|
|
||||||
|
result.testResults &&
|
||||||
|
result.testResults.forEach((test) => {
|
||||||
|
const testcase = {
|
||||||
|
'@name': test.description,
|
||||||
|
'@status': test.status,
|
||||||
|
'@classname': result.request.url,
|
||||||
|
'@time': (result.runtime / totalTests).toFixed(3)
|
||||||
|
};
|
||||||
|
|
||||||
|
if (test.status === 'fail') {
|
||||||
|
suite['@failures']++;
|
||||||
|
|
||||||
|
testcase.failure = [{ '@type': 'failure', '@message': test.error }];
|
||||||
|
}
|
||||||
|
|
||||||
|
suite.testcase.push(testcase);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (result.error) {
|
||||||
|
suite['@errors'] = 1;
|
||||||
|
suite['@tests'] = 1;
|
||||||
|
suite.testcase = [
|
||||||
|
{
|
||||||
|
'@name': 'Test suite has no errors',
|
||||||
|
'@status': 'fail',
|
||||||
|
'@classname': result.request.url,
|
||||||
|
'@time': result.runtime.toFixed(3),
|
||||||
|
error: [{ '@type': 'error', '@message': result.error }]
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
output.testsuites.testsuite.push(suite);
|
||||||
|
});
|
||||||
|
|
||||||
|
fs.writeFileSync(outputPath, xmlbuilder.create(output).end({ pretty: true }));
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = makeJUnitOutput;
|
Loading…
Reference in New Issue
Block a user