fix(core): don’t create a comment for components with empty template. (#15260)

Fixes #15143

PR Close #15260
This commit is contained in:
Tobias Bosch
2017-03-17 15:34:37 -07:00
committed by Miško Hevery
parent aeb99645bb
commit f8c075ae27
3 changed files with 44 additions and 16 deletions

View File

@ -24,10 +24,6 @@ export function viewDef(
flags: ViewFlags, nodes: NodeDef[], updateDirectives?: ViewUpdateFn,
updateRenderer?: ViewUpdateFn): ViewDefinition {
// clone nodes and set auto calculated values
if (nodes.length === 0) {
throw new Error(`Illegal State: Views without nodes are not allowed!`);
}
const reverseChildNodes: NodeDef[] = new Array(nodes.length);
let viewBindingCount = 0;
let viewDisposableCount = 0;
@ -152,6 +148,9 @@ export function viewDef(
function validateNode(parent: NodeDef, node: NodeDef, nodeCount: number) {
const template = node.element && node.element.template;
if (template) {
if (!template.lastRenderRootNode) {
throw new Error(`Illegal State: Embedded templates without nodes are not allowed!`);
}
if (template.lastRenderRootNode &&
template.lastRenderRootNode.flags & NodeFlags.EmbeddedViews) {
throw new Error(

View File

@ -306,6 +306,36 @@ function declareTests({useJit}: {useJit: boolean}) {
ctx.detectChanges();
expect(ctx.componentInstance.viewContainers.first).toBe(vc);
});
describe('empty templates - #15143', () => {
it('should allow empty components', () => {
@Component({template: ''})
class MyComp {
}
const fixture =
TestBed.configureTestingModule({declarations: [MyComp]}).createComponent(MyComp);
fixture.detectChanges();
expect(fixture.debugElement.childNodes.length).toBe(0);
});
it('should allow empty embedded templates', () => {
@Component({template: '<ng-template [ngIf]="true"></ng-template>'})
class MyComp {
}
const fixture =
TestBed.configureTestingModule({declarations: [MyComp]}).createComponent(MyComp);
fixture.detectChanges();
// Note: We always need to create at least a comment in an embedded template,
// so we can append other templates after it.
// 1 comment for the anchor,
// 1 comment for the empty embedded template.
expect(fixture.debugElement.childNodes.length).toBe(2);
});
});
});
}