test(ivy): add onlyInIvy perf counter expectations (#30339)

We have an issue where we would like to be able to test perf counter metrics in acceptance tests, but we are unable to do so, because it will break when those same tests are run with ViewEngine. This PR adds a testing utility to `onlyInIvy` that allows for testing of performance counters, and even gives readable errors for what value on `ngDevMode` is incorrect. Has typings for decent autocompletion as well.

PR Close #30339
This commit is contained in:
Ben Lesh 2019-05-08 13:14:42 -07:00 committed by Alex Rickabaugh
parent d70b1ff177
commit cb6ad971c3
3 changed files with 43 additions and 4 deletions

View File

@ -13,6 +13,7 @@ ts_library(
"//packages/compiler", "//packages/compiler",
"//packages/compiler/testing", "//packages/compiler/testing",
"//packages/core", "//packages/core",
"//packages/core/src/util",
"//packages/core/testing", "//packages/core/testing",
"//packages/platform-browser", "//packages/platform-browser",
"//packages/platform-browser-dynamic", "//packages/platform-browser-dynamic",

View File

@ -6,11 +6,15 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {Component, Directive, ElementRef} from '@angular/core'; import {Component, Directive, ElementRef} from '@angular/core';
import {ngDevModeResetPerfCounters} from '@angular/core/src/util/ng_dev_mode';
import {TestBed} from '@angular/core/testing'; import {TestBed} from '@angular/core/testing';
import {DomSanitizer, SafeStyle} from '@angular/platform-browser'; import {DomSanitizer, SafeStyle} from '@angular/platform-browser';
import {expect} from '@angular/platform-browser/testing/src/matchers'; import {expect} from '@angular/platform-browser/testing/src/matchers';
import {onlyInIvy} from '@angular/private/testing';
describe('styling', () => { describe('styling', () => {
beforeEach(ngDevModeResetPerfCounters);
it('should render inline style and class attribute values on the element before a directive is instantiated', it('should render inline style and class attribute values on the element before a directive is instantiated',
() => { () => {
@Component({ @Component({
@ -147,5 +151,13 @@ describe('styling', () => {
const div = fixture.nativeElement.querySelector('div') as HTMLDivElement; const div = fixture.nativeElement.querySelector('div') as HTMLDivElement;
expect(div.style.backgroundImage).toBe('url("#test")'); expect(div.style.backgroundImage).toBe('url("#test")');
onlyInIvy('perf counters').expectPerfCounters({
stylingApply: 2,
stylingApplyCacheMiss: 1,
stylingProp: 2,
stylingPropCacheMiss: 1,
tNode: 3,
});
}); });
}); });

View File

@ -90,23 +90,49 @@ export interface JasmineMethods {
fit: typeof fit; fit: typeof fit;
describe: typeof describe; describe: typeof describe;
fdescribe: typeof fdescribe; fdescribe: typeof fdescribe;
/**
* Runs jasmine expectations against the provided keys for `ngDevMode`.
*
* Will not perform expectations for keys that are not provided.
*
* ```ts
* // Expect that `ngDevMode.styleMap` is `1`, and `ngDevMode.tNode` is `3`, but we don't care
* // about the other values.
* onlyInIvy('perf counters').expectPerfCounters({
* stylingMap: 1,
* tNode: 3,
* })
* ```
*/
expectPerfCounters: (expectedCounters: Partial<NgDevModePerfCounters>) => void;
isEnabled: boolean; isEnabled: boolean;
} }
const PASSTHROUGH: JasmineMethods = { const PASSTHROUGH: JasmineMethods = {
it: it, it,
fit: fit, fit,
describe: describe, describe,
fdescribe: fdescribe, fdescribe,
expectPerfCounters,
isEnabled: true, isEnabled: true,
}; };
function noop() {} function noop() {}
function expectPerfCounters(expectedCounters: Partial<NgDevModePerfCounters>) {
Object.keys(expectedCounters).forEach(key => {
const expected = (expectedCounters as any)[key];
const actual = (ngDevMode as any)[key];
expect(actual).toBe(expected, `ngDevMode.${key}`);
});
}
const IGNORE: JasmineMethods = { const IGNORE: JasmineMethods = {
it: noop, it: noop,
fit: noop, fit: noop,
describe: noop, describe: noop,
fdescribe: noop, fdescribe: noop,
expectPerfCounters: noop,
isEnabled: false, isEnabled: false,
}; };