Skip to content

Commit

Permalink
Modified how classname is generated to be usable in sonar
Browse files Browse the repository at this point in the history
Updated Readme.md

Modified README.md
  • Loading branch information
Raymond Asuncion committed Jul 7, 2015
1 parent d9c3f9f commit de5bdc3
Show file tree
Hide file tree
Showing 2 changed files with 103 additions and 34 deletions.
66 changes: 66 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,72 @@ You can pass list of reporters as a CLI argument too:
karma start --reporters junit,dots
```

## Produce test result with schema acceptable in sonar

To make this possible, it's required to make the classnames of each tests to match its file name.

For Example:
```js
describe('analytics.AnalyticsModule_test', function(){

var analytics;
beforeEach(module('ECApp'));
beforeEach(module('angularytics'));
beforeEach(module('AnalyticsModule'));
...
```
should have a file name AnalyticsModule_test.js
This will produce test result with schema acceptable in sonar.
Grunt file reporters property example:
```js
reporters: ['junit', 'coverage', 'progress'],
junitReporter: {
outputDir: $junitResults,
suite: 'models'
},
coverageReporter: {
type: 'lcov',
dir: $coverageOutputDir,
subdir: '.'
},
preprocessors: {
'src/main/webapp/public/js/ec3.3/**/*.js': 'coverage',
'src/main/webapp/public/js/ec3/**/*.js': 'coverage'
},
plugins: [
'karma-jasmine',
'karma-phantomjs-launcher',
'ec-karma-junit-reporter23',
'karma-coverage'
]
```
Sonar property example:
```js
sonar.projectName=js
sonar.sources=site-main-php/src/main/webapp/public/js
sonar.projectBaseDir=.
sonar.exclusions=site-main-php/src/main/webapp/public/js/lib/*.js,site-main-php/src/main/webapp/public/js/tests/**/*.php,site-main-php/src/main/webapp/public/js/tests/**/*.js,site-main-php/src/main/webapp/public/js/ec3.3/vendor/**
sonar.javascript.lcov.reportPath=site-main-php/target/coverage/lcov.info
sonar.javascript.jstestdriver.reportsPath=site-main-php/target/surefire-reports/
sonar.tests=site-main-php/src/main/webapp/public/js/tests
```
Example junit xml report:
```xml
<?xml version="1.0"?>
<testsuite name="PhantomJS 1.9.8 (Linux)" package="models" timestamp="2015-03-10T13:59:23" id="0" hostname="admin" tests="629" errors="0" failures="0" time="11.452">
<properties>
<property name="browser.fullName" value="Mozilla/5.0 (Unknown; Linux x86_64) AppleWebKit/534.34 (KHTML, like Gecko) PhantomJS/1.9.8 Safari/534.34"/>
</properties>
<testcase name="(C.2) Checks if an empty object is returned when error 404 is encountered" time="0.01" classname="PhantomJS_1_9_8_(Linux).models.AnalyticsModule_test"/>
<testcase name="(C.3) Checks if an empty array is returned when error 405 is encountered" time="0.013" classname="PhantomJS_1_9_8_(Linux).models.AnalyticsModule_test"/>
</testsuite>
...
```
----
For more information on Karma see the [homepage].
Expand Down
71 changes: 37 additions & 34 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,12 @@ var JUnitReporter = function(baseReporterDecorator, config, logger, helper, form
var log = logger.create('reporter.junit');
var reporterConfig = config.junitReporter || {};
var pkgName = reporterConfig.suite || '';
var outputFile = helper.normalizeWinPath(path.resolve(config.basePath, reporterConfig.outputFile
|| 'test-results.xml'));

var xml;
if (!reporterConfig.outputDir) {
throw new Error('You must set an output directory for JUnitReporter via the outputDir config property');
}

var outputDir = helper.normalizeWinPath(path.resolve(config.basePath, reporterConfig.outputDir)) + path.sep;
var suites;
var pendingFileWritings = 0;
var fileWritingFinished = function() {};
Expand All @@ -25,15 +27,38 @@ var JUnitReporter = function(baseReporterDecorator, config, logger, helper, form

var initliazeXmlForBrowser = function(browser) {
var timestamp = (new Date()).toISOString().substr(0, 19);
var suite = suites[browser.id] = xml.ele('testsuite', {
name: browser.name, 'package': pkgName, timestamp: timestamp, id: 0, hostname: os.hostname()
var suite = suites[browser.id] = builder.create('testsuite');
suite.att('name', browser.name)
.att('package', pkgName)
.att('timestamp', timestamp)
.att('id', 0)
.att('hostname', os.hostname());
suite.ele('properties')
.ele('property', {name: 'browser.fullName', value: browser.fullName});
};

var writeXmlForBrowser = function(browser) {
var outputFile = outputDir + 'TESTS-' + browser.name.replace(/ /g, '_') + '.xml';
var xmlToOutput = suites[browser.id];

pendingFileWritings++;
helper.mkdirIfNotExists(outputDir, function() {
fs.writeFile(outputFile, xmlToOutput.end({pretty: true}), function(err) {
if (err) {
log.warn('Cannot write JUnit xml\n\t' + err.message);
} else {
log.debug('JUnit results written to "%s".', outputFile);
}

if (!--pendingFileWritings) {
fileWritingFinished();
}
});
});
suite.ele('properties').ele('property', {name: 'browser.fullName', value: browser.fullName});
};

this.onRunStart = function(browsers) {
suites = Object.create(null);
xml = builder.create('testsuites');

// TODO(vojta): remove once we don't care about Karma 0.10
browsers.forEach(initliazeXmlForBrowser);
Expand All @@ -45,13 +70,6 @@ var JUnitReporter = function(baseReporterDecorator, config, logger, helper, form

this.onBrowserComplete = function(browser) {
var suite = suites[browser.id];

if (!suite) {
// This browser did not signal `onBrowserStart`. That happens
// if the browser timed out during the start phase.
return;
}

var result = browser.lastResult;

suite.att('tests', result.total);
Expand All @@ -61,34 +79,19 @@ var JUnitReporter = function(baseReporterDecorator, config, logger, helper, form

suite.ele('system-out').dat(allMessages.join() + '\n');
suite.ele('system-err');

writeXmlForBrowser(browser);
};

this.onRunComplete = function() {
var xmlToOutput = xml;

pendingFileWritings++;
helper.mkdirIfNotExists(path.dirname(outputFile), function() {
fs.writeFile(outputFile, xmlToOutput.end({pretty: true}), function(err) {
if (err) {
log.warn('Cannot write JUnit xml\n\t' + err.message);
} else {
log.debug('JUnit results written to "%s".', outputFile);
}

if (!--pendingFileWritings) {
fileWritingFinished();
}
});
});

suites = xml = null;
suites = null;
allMessages.length = 0;
};

this.specSuccess = this.specSkipped = this.specFailure = function(browser, result) {
var spec = suites[browser.id].ele('testcase', {
name: result.description, time: ((result.time || 0) / 1000),
classname: (pkgName ? pkgName + ' ' : '') + browser.name + '.' + result.suite.join(' ').replace(/\./g, '_')
classname: browser.name.replace(/ /g,'_').replace(/\./g,'_') + '.' + (pkgName ? pkgName + '.' : '') + result.suite[0]
});

if (result.skipped) {
Expand Down Expand Up @@ -117,4 +120,4 @@ JUnitReporter.$inject = ['baseReporterDecorator', 'config', 'logger', 'helper',
// PUBLISH DI MODULE
module.exports = {
'reporter:junit': ['type', JUnitReporter]
};
};

0 comments on commit de5bdc3

Please sign in to comment.