-
Notifications
You must be signed in to change notification settings - Fork 12k
/
Copy pathcode-coverage_spec_large.ts
107 lines (93 loc) · 3.69 KB
/
code-coverage_spec_large.ts
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
/**
* @license
* Copyright Google Inc. All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
import { runTargetSpec } from '@angular-devkit/architect/testing';
import { normalize, virtualFs } from '@angular-devkit/core';
import { debounceTime, tap } from 'rxjs/operators';
import { NormalizedKarmaBuilderSchema } from '../../src/utils';
import { host, karmaTargetSpec } from '../utils';
describe('Karma Builder code coverage', () => {
const coverageFilePath = normalize('coverage/lcov.info');
beforeEach(done => host.initialize().toPromise().then(done, done.fail));
afterEach(done => host.restore().toPromise().then(done, done.fail));
it('works', (done) => {
const overrides: Partial<NormalizedKarmaBuilderSchema> = { codeCoverage: true };
runTargetSpec(host, karmaTargetSpec, overrides).pipe(
// It seems like the coverage files take a while being written to disk, so we wait 500ms here.
debounceTime(500),
tap(buildEvent => {
expect(buildEvent.success).toBe(true);
expect(host.scopedSync().exists(coverageFilePath)).toBe(true);
const content = virtualFs.fileBufferToString(host.scopedSync().read(coverageFilePath));
expect(content).toContain('polyfills.ts');
expect(content).toContain('test.ts');
}),
).toPromise().then(done, done.fail);
}, 120000);
it('supports exclude', (done) => {
const overrides: Partial<NormalizedKarmaBuilderSchema> = {
codeCoverage: true,
codeCoverageExclude: [
'src/polyfills.ts',
'**/test.ts',
],
};
runTargetSpec(host, karmaTargetSpec, overrides).pipe(
// It seems like the coverage files take a while being written to disk, so we wait 500ms here.
debounceTime(500),
tap(buildEvent => {
expect(buildEvent.success).toBe(true);
expect(host.scopedSync().exists(coverageFilePath)).toBe(true);
const content = virtualFs.fileBufferToString(host.scopedSync().read(coverageFilePath));
expect(content).not.toContain('polyfills.ts');
expect(content).not.toContain('test.ts');
}),
).toPromise().then(done, done.fail);
}, 120000);
it(`should collect coverage from paths in 'sourceRoot'`, (done) => {
const overrides: Partial<NormalizedKarmaBuilderSchema> = { codeCoverage: true };
const files: { [path: string]: string } = {
'./dist/my-lib/index.d.ts': `
export declare const title = 'app';
`,
'./dist/my-lib/index.js': `
export const title = 'app';
`,
'./src/app/app.component.ts': `
import { Component } from '@angular/core';
import { title } from 'my-lib';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = title;
}
`,
};
host.writeMultipleFiles(files);
host.replaceInFile('tsconfig.json', /"baseUrl": ".\/",/, `
"baseUrl": "./",
"paths": {
"my-lib": [
"./dist/my-lib"
]
},
`);
runTargetSpec(host, karmaTargetSpec, overrides).pipe(
// It seems like the coverage files take a while being written to disk, so we wait 500ms here.
debounceTime(500),
tap(buildEvent => {
expect(buildEvent.success).toBe(true);
expect(host.scopedSync().exists(coverageFilePath)).toBe(true);
const content = virtualFs.fileBufferToString(host.scopedSync().read(coverageFilePath));
expect(content).not.toContain('my-lib');
}),
).toPromise().then(done, done.fail);
}, 120000);
});