Skip to content

Commit

Permalink
feat(in-memory-reporter) Added a new reporter in-memory which will ra…
Browse files Browse the repository at this point in the history
…ise an event rather than write to disk
  • Loading branch information
nicojs committed Mar 2, 2016
1 parent 75006b7 commit dc03238
Show file tree
Hide file tree
Showing 6 changed files with 55 additions and 7 deletions.
13 changes: 13 additions & 0 deletions lib/in-memory-report.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@

function InMemoryReport (opt) {
this.browser = opt.browser
this.emitter = opt.emitter
}

InMemoryReport.prototype.writeReport = function (collector, sync) {
this.emitter.emit('coverage_complete', this.browser, collector.getFinalCoverage())
}

InMemoryReport.TYPE = 'in-memory'

module.exports = InMemoryReport
3 changes: 3 additions & 0 deletions lib/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@
// Main entry point for the karma-coverage module.
// Exposes the preprocessor and reporter plugins.

// Registering one additional (karma specific) reporter: in-memory
require('istanbul').Report.register(require('./in-memory-report'))

module.exports = {
'preprocessor:coverage': ['factory', require('./preprocessor')],
'reporter:coverage': ['type', require('./reporter')]
Expand Down
14 changes: 8 additions & 6 deletions lib/reporter.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ function isAbsolute (file) {
}

// TODO(vojta): inject only what required (config.basePath, config.coverageReporter)
var CoverageReporter = function (rootConfig, helper, logger) {
var CoverageReporter = function (rootConfig, helper, logger, emitter) {
var _ = helper._
var log = logger.create('coverage')

Expand Down Expand Up @@ -270,15 +270,17 @@ var CoverageReporter = function (rootConfig, helper, logger) {
var options = helper.merge({
sourceStore: sourceStore
}, config, reporterConfig, {
dir: outputDir
dir: outputDir,
browser: browser,
emitter: emitter
})
var reporter = istanbul.Report.create(reporterConfig.type || 'html', options)

// If reporting to console, skip directory creation
var isConsole = reporterConfig.type && reporterConfig.type.match(/^(text|text-summary)$/)
// If reporting to console or in-memory skip directory creation
var toDisk = !reporterConfig.type || !reporterConfig.type.match(/^(text|text-summary|in-memory)$/)
var hasNoFile = _.isUndefined(reporterConfig.file)

if (isConsole && hasNoFile) {
if (!toDisk && hasNoFile) {
writeReport(reporter, collector)
return
}
Expand All @@ -303,7 +305,7 @@ var CoverageReporter = function (rootConfig, helper, logger) {
}
}

CoverageReporter.$inject = ['config', 'helper', 'logger']
CoverageReporter.$inject = ['config', 'helper', 'logger', 'emitter']

// PUBLISH
module.exports = CoverageReporter
19 changes: 19 additions & 0 deletions test/in-memory-report.spec.coffee
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
InMemoryReport = require '../lib/in-memory-report'

describe 'InMemoryReport', ->

emitter =
emit: sinon.stub()
browser = { name: 'firefox' }
result = { coverage: 'result' }
collector =
getFinalCoverage: sinon.stub().returns result

it 'should raise an "coverage_complete" event.', ->
sut = new InMemoryReport { browser: browser, emitter: emitter}
sut.writeReport collector
expect(collector.getFinalCoverage).to.have.been.called
expect(emitter.emit).to.have.been.calledWith('coverage_complete', browser, result)

it 'should be of type "in-memory"', ->
expect(InMemoryReport.TYPE).to.be.equal('in-memory')
7 changes: 7 additions & 0 deletions test/index.spec.coffee
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
index = require '../lib/index'
InMemoryReport = require '../lib/in-memory-report'
istanbul = require 'istanbul'

describe 'Index', ->
it 'should register "InMemoryReport" to istanbul', ->
expect(istanbul.Report.create('in-memory', {})).to.be.an.instanceof(InMemoryReport)
6 changes: 5 additions & 1 deletion test/reporter.spec.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ describe 'reporter', ->
basePath: '/base'
coverageReporter: dir: 'path/to/coverage/'
emitter = new events.EventEmitter
reporter = new m.CoverageReporter rootConfig, mockHelper, mockLogger
reporter = new m.CoverageReporter rootConfig, mockHelper, mockLogger, emitter
browsers = new Collection emitter
# fake user agent only for testing
# cf. helper.browserFullNameToShort
Expand Down Expand Up @@ -144,6 +144,10 @@ describe 'reporter', ->
mockMkdir.getCall(0).args[1]()
expect(mockReportCreate).to.have.been.called
expect(mockWriteReport).to.have.been.called
createArgs = mockReportCreate.getCall(0).args
expect(createArgs[0]).to.be.equal 'html'
expect(createArgs[1].browser).to.be.equal fakeChrome
expect(createArgs[1].emitter).to.be.equal emitter

it 'should support a string for the subdir option', ->
customConfig = _.merge {}, rootConfig,
Expand Down

0 comments on commit dc03238

Please sign in to comment.