-
Notifications
You must be signed in to change notification settings - Fork 248
/
reporter.spec.coffee
166 lines (143 loc) · 5.44 KB
/
reporter.spec.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
#==============================================================================
# lib/reporters/Coverage.js module
#==============================================================================
describe 'reporter', ->
events = require 'events'
path = require 'path'
istanbul = require 'istanbul'
# TODO(vojta): remove the dependency on karma
helper = require '../node_modules/karma/lib/helper'
browser = require '../node_modules/karma/lib/browser'
require('../node_modules/karma/lib/logger').setup 'INFO', false, []
Browser = browser.Browser
Collection = browser.Collection
nodeMocks = require 'mocks'
loadFile = nodeMocks.loadFile
m = null
mockFs =
writeFile: sinon.spy()
mockStore = sinon.spy()
mockStore.mix = (fn, obj) ->
istanbul.Store.mix fn, obj
mockFslookup = sinon.stub
keys: ->
get: ->
hasKey: ->
set: ->
mockStore.create = sinon.stub().returns mockFslookup
mockAdd = sinon.spy()
mockDispose = sinon.spy()
mockCollector = class Collector
add: mockAdd
dispose: mockDispose
getFinalCoverage: -> null
mockWriteReport = sinon.spy()
mockReportCreate = sinon.stub().returns writeReport: mockWriteReport
mockMkdir = sinon.spy()
mockHelper =
isDefined: (v) -> helper.isDefined v
merge: (v...) -> helper.merge v...
mkdirIfNotExists: mockMkdir
normalizeWinPath: (path) -> helper.normalizeWinPath path
mocks =
fs: mockFs
istanbul:
Store: mockStore
Collector: mockCollector
Report: create: mockReportCreate
dateformat: require 'dateformat'
beforeEach ->
m = loadFile __dirname + '/../lib/reporter.js', mocks
describe 'BasePathStore', ->
options = store = null
beforeEach ->
options =
basePath: 'path/to/coverage/'
store = new m.BasePathStore options
describe 'toKey', ->
it 'should concat relative path and basePath', ->
expect(store.toKey './foo').to.deep.equal path.join(options.basePath, 'foo')
it 'should does not concat absolute path and basePath', ->
expect(store.toKey '/foo').to.deep.equal '/foo'
it 'should call keys and delegate to inline store', ->
store.keys()
expect(mockFslookup.keys).to.have.been.called
it 'should call get and delegate to inline store', ->
key = './path/to/js'
store.get(key)
expect(mockFslookup.get).to.have.been.calledWith path.join(options.basePath, key)
it 'should call hasKey and delegate to inline store', ->
key = './path/to/js'
store.hasKey(key)
expect(mockFslookup.hasKey).to.have.been.calledWith path.join(options.basePath, key)
it 'should call set and delegate to inline store', ->
key = './path/to/js'
content = 'any content'
store.set key, content
expect(mockFslookup.set).to.have.been.calledWith path.join(options.basePath, key), content
describe 'CoverageReporter', ->
rootConfig = emitter = reporter = null
browsers = fakeChrome = fakeOpera = null
mockLogger = create: (name) ->
debug: -> null
info: -> null
warn: -> null
error: -> null
makeBrowser = (id, name, collection, emitter) ->
browser = new Browser id, collection, emitter
browser.onRegister
id: id + name
name: name
browser
beforeEach ->
rootConfig =
basePath: '/base'
coverageReporter: dir: 'path/to/coverage/'
emitter = new events.EventEmitter
reporter = new m.CoverageReporter rootConfig, mockHelper, mockLogger
browsers = new Collection emitter
# fake user agent only for testing
# cf. helper.browserFullNameToShort
fakeChrome = makeBrowser 'aaa', 'Windows NT 6.1 Chrome/16.0.912.75', browsers, emitter
fakeOpera = makeBrowser 'bbb', 'Opera/9.80 Mac OS X Version/12.00', browsers, emitter
browsers.add fakeChrome
browsers.add fakeOpera
reporter.onRunStart()
browsers.forEach (b) -> reporter.onBrowserStart b
mockFs.writeFile.reset()
mockMkdir.reset()
it 'has no pending file writings', ->
done = sinon.spy()
reporter.onExit done
expect(done).to.have.been.called
it 'has no coverage', ->
result =
coverage: null
reporter.onBrowserComplete fakeChrome, result
expect(mockAdd).not.to.have.been.called
it 'should handle no result', ->
reporter.onBrowserComplete fakeChrome, undefined
expect(mockAdd).not.to.have.been.called
it 'should store coverage json', ->
result =
coverage:
aaa: 1
bbb: 2
reporter.onBrowserComplete fakeChrome, result
expect(mockAdd).to.have.been.calledWith result.coverage
expect(mockMkdir).to.have.been.called
args = mockMkdir.lastCall.args
expect(args[0]).to.deep.equal path.resolve('/base', rootConfig.coverageReporter.dir)
args[1]()
expect(mockFs.writeFile).to.have.been.calledWith
args2 = mockFs.writeFile.lastCall.args
# expect(args2[1]).to.deep.equal JSON.stringify(result.coverage)
it 'should make reports', ->
reporter.onRunComplete browsers
expect(mockMkdir).to.have.been.calledTwice
dir = rootConfig.coverageReporter.dir
expect(mockMkdir.getCall(0).args[0]).to.deep.equal path.resolve('/base', dir, fakeChrome.name)
expect(mockMkdir.getCall(1).args[0]).to.deep.equal path.resolve('/base', dir, fakeOpera.name)
mockMkdir.getCall(0).args[1]()
expect(mockReportCreate).to.have.been.called
expect(mockWriteReport).to.have.been.called