perf(ivy): add ngIf-like directive to the ng_template benchmark (#33595)

PR Close #33595
This commit is contained in:
Pawel Kozlowski 2019-11-04 15:16:54 +01:00 committed by atscott
parent 3297a76195
commit e89c2dd8d0
1 changed files with 44 additions and 25 deletions

View File

@ -5,43 +5,62 @@
* Use of this source code is governed by an MIT-style license that can be * 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 * found in the LICENSE file at https://angular.io/license
*/ */
import {ɵɵtemplate} from '../../../../src/render3/instructions/container'; import {ElementRef, TemplateRef, ViewContainerRef} from '../../../../src/linker';
import {ɵɵdefineDirective, ɵɵdirectiveInject, ɵɵtemplate} from '../../../../src/render3/index';
import {createTNode, createTView} from '../../../../src/render3/instructions/shared'; import {createTNode, createTView} from '../../../../src/render3/instructions/shared';
import {RenderFlags} from '../../../../src/render3/interfaces/definition'; import {RenderFlags} from '../../../../src/render3/interfaces/definition';
import {TNodeType, TViewNode} from '../../../../src/render3/interfaces/node'; import {TNodeType, TViewNode} from '../../../../src/render3/interfaces/node';
import {injectTemplateRef, injectViewContainerRef} from '../../../../src/render3/view_engine_compatibility';
import {createBenchmark} from '../micro_bench'; import {createBenchmark} from '../micro_bench';
import {createAndRenderLView} from '../setup'; import {createAndRenderLView} from '../setup';
`<div> class TemplateRefToken {
<ng-template></ng-template> /**
<ng-template></ng-template> * @internal
<ng-template></ng-template> * @nocollapse
<ng-template></ng-template> */
<ng-template></ng-template> static __NG_ELEMENT_ID__(): TemplateRef<any>|null {
<ng-template></ng-template> return injectTemplateRef(TemplateRef, ElementRef);
<ng-template></ng-template> }
<ng-template></ng-template> }
<ng-template></ng-template> class ViewContainerRefToken {
<ng-template></ng-template> /**
</div> * @internal
</ng-template>`; * @nocollapse
*/
static __NG_ELEMENT_ID__(): ViewContainerRef {
return injectViewContainerRef(ViewContainerRef, ElementRef);
}
}
class NgIfLike {
static ɵfac() {
return new NgIfLike(
ɵɵdirectiveInject(TemplateRefToken), ɵɵdirectiveInject(ViewContainerRefToken));
}
static ɵdir = ɵɵdefineDirective({
type: NgIfLike,
selectors: [['', 'viewManipulation', '']],
});
constructor(private tplRef: TemplateRefToken, private vcRef: ViewContainerRefToken) {}
}
`
<ng-template viewManipulation></ng-template>
<ng-template viewManipulation></ng-template>
`;
function testTemplate(rf: RenderFlags, ctx: any) { function testTemplate(rf: RenderFlags, ctx: any) {
if (rf & 1) { if (rf & 1) {
ɵɵtemplate(0, null, 0, 0); ɵɵtemplate(0, null, 0, 0, 'ng-template', 0);
ɵɵtemplate(1, null, 0, 0); ɵɵtemplate(1, null, 0, 0, 'ng-template', 0);
ɵɵtemplate(2, null, 0, 0);
ɵɵtemplate(3, null, 0, 0);
ɵɵtemplate(4, null, 0, 0);
ɵɵtemplate(5, null, 0, 0);
ɵɵtemplate(6, null, 0, 0);
ɵɵtemplate(7, null, 0, 0);
ɵɵtemplate(8, null, 0, 0);
ɵɵtemplate(9, null, 0, 0);
} }
} }
const viewTNode = createTNode(null !, null, TNodeType.View, -1, null, null) as TViewNode; const viewTNode = createTNode(null !, null, TNodeType.View, -1, null, null) as TViewNode;
const embeddedTView = createTView(-1, testTemplate, 10, 0, null, null, null, null, null); const embeddedTView = createTView(
-1, testTemplate, 2, 0, [NgIfLike.ɵdir], null, null, null, [['viewManipulation', '']]);
// create view once so we don't profile first template pass // create view once so we don't profile first template pass
createAndRenderLView(null, embeddedTView, viewTNode); createAndRenderLView(null, embeddedTView, viewTNode);