| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-20 17:45:53 -08:00
										 |  |  | import {Component, Directive, Inject, InjectionToken, NgModule, Optional, Pipe} from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  | import {TestBed, getTestBed} from '@angular/core/testing/src/test_bed'; | 
					
						
							|  |  |  | import {By} from '@angular/platform-browser'; | 
					
						
							|  |  |  | import {expect} from '@angular/platform-browser/testing/src/matchers'; | 
					
						
							| 
									
										
										
										
											2018-12-20 17:45:53 -08:00
										 |  |  | import {onlyInIvy} from '@angular/private/testing'; | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | const NAME = new InjectionToken<string>('name'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // -- module: HWModule
 | 
					
						
							|  |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'hello-world', | 
					
						
							|  |  |  |   template: '<greeting-cmp></greeting-cmp>', | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | export class HelloWorld { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // -- module: Greeting
 | 
					
						
							|  |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'greeting-cmp', | 
					
						
							|  |  |  |   template: 'Hello {{ name }}', | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | export class GreetingCmp { | 
					
						
							|  |  |  |   name: string; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   constructor(@Inject(NAME) @Optional() name: string) { this.name = name || 'nobody!'; } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @NgModule({ | 
					
						
							|  |  |  |   declarations: [GreetingCmp], | 
					
						
							|  |  |  |   exports: [GreetingCmp], | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | export class GreetingModule { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @Component({selector: 'simple-cmp', template: '<b>simple</b>'}) | 
					
						
							|  |  |  | export class SimpleCmp { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-24 10:30:29 +02:00
										 |  |  | @Component({selector: 'with-refs-cmp', template: '<div #firstDiv></div>'}) | 
					
						
							|  |  |  | export class WithRefsCmp { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-16 16:28:04 -08:00
										 |  |  | @Component({selector: 'inherited-cmp', template: 'inherited'}) | 
					
						
							|  |  |  | export class InheritedCmp extends SimpleCmp { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-24 08:53:00 -08:00
										 |  |  | @Directive({selector: '[hostBindingDir]', host: {'[id]': 'id'}}) | 
					
						
							| 
									
										
										
										
											2019-01-22 15:02:52 -08:00
										 |  |  | export class HostBindingDir { | 
					
						
							|  |  |  |   id = 'one'; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-24 08:53:00 -08:00
										 |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'component-with-prop-bindings', | 
					
						
							|  |  |  |   template: `
 | 
					
						
							|  |  |  |     <div hostBindingDir [title]="title" [attr.aria-label]="label"></div> | 
					
						
							|  |  |  |     <p title="( {{ label }} - {{ title }} )" [attr.aria-label]="label" id="[ {{ label }} ] [ {{ title }} ]"> | 
					
						
							|  |  |  |     </p> | 
					
						
							|  |  |  |   `
 | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | export class ComponentWithPropBindings { | 
					
						
							|  |  |  |   title = 'some title'; | 
					
						
							|  |  |  |   label = 'some label'; | 
					
						
							| 
									
										
										
										
											2019-01-22 15:02:52 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-16 16:28:04 -08:00
										 |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'simple-app', | 
					
						
							|  |  |  |   template: `
 | 
					
						
							|  |  |  |     <simple-cmp></simple-cmp> - <inherited-cmp></inherited-cmp> | 
					
						
							|  |  |  |   `
 | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | export class SimpleApp { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-23 15:09:27 -08:00
										 |  |  | @Component({selector: 'inline-template', template: '<p>Hello</p>'}) | 
					
						
							|  |  |  | export class ComponentWithInlineTemplate { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  | @NgModule({ | 
					
						
							| 
									
										
										
										
											2019-01-22 15:02:52 -08:00
										 |  |  |   declarations: [ | 
					
						
							| 
									
										
										
										
											2019-01-24 08:53:00 -08:00
										 |  |  |     HelloWorld, SimpleCmp, WithRefsCmp, InheritedCmp, SimpleApp, ComponentWithPropBindings, | 
					
						
							|  |  |  |     HostBindingDir | 
					
						
							| 
									
										
										
										
											2019-01-22 15:02:52 -08:00
										 |  |  |   ], | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  |   imports: [GreetingModule], | 
					
						
							|  |  |  |   providers: [ | 
					
						
							|  |  |  |     {provide: NAME, useValue: 'World!'}, | 
					
						
							|  |  |  |   ] | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | export class HelloWorldModule { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe('TestBed', () => { | 
					
						
							|  |  |  |   beforeEach(() => { | 
					
						
							|  |  |  |     getTestBed().resetTestingModule(); | 
					
						
							|  |  |  |     TestBed.configureTestingModule({imports: [HelloWorldModule]}); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it('should compile and render a component', () => { | 
					
						
							|  |  |  |     const hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expect(hello.nativeElement).toHaveText('Hello World!'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it('should give access to the component instance', () => { | 
					
						
							|  |  |  |     const hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expect(hello.componentInstance).toBeAnInstanceOf(HelloWorld); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it('should give the ability to query by css', () => { | 
					
						
							|  |  |  |     const hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const greetingByCss = hello.debugElement.query(By.css('greeting-cmp')); | 
					
						
							|  |  |  |     expect(greetingByCss.nativeElement).toHaveText('Hello World!'); | 
					
						
							|  |  |  |     expect(greetingByCss.componentInstance).toBeAnInstanceOf(GreetingCmp); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it('should give the ability to trigger the change detection', () => { | 
					
						
							|  |  |  |     const hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  |     const greetingByCss = hello.debugElement.query(By.css('greeting-cmp')); | 
					
						
							|  |  |  |     expect(greetingByCss.nativeElement).toHaveText('Hello World!'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     greetingByCss.componentInstance.name = 'TestBed!'; | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  |     expect(greetingByCss.nativeElement).toHaveText('Hello TestBed!'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-24 08:53:00 -08:00
										 |  |  |   it('should give the ability to access property bindings on a node', () => { | 
					
						
							|  |  |  |     const fixture = TestBed.createComponent(ComponentWithPropBindings); | 
					
						
							|  |  |  |     fixture.detectChanges(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const divElement = fixture.debugElement.query(By.css('div')); | 
					
						
							|  |  |  |     expect(divElement.properties).toEqual({id: 'one', title: 'some title'}); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it('should give the ability to access interpolated properties on a node', () => { | 
					
						
							|  |  |  |     const fixture = TestBed.createComponent(ComponentWithPropBindings); | 
					
						
							| 
									
										
										
										
											2019-01-22 15:02:52 -08:00
										 |  |  |     fixture.detectChanges(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-24 08:53:00 -08:00
										 |  |  |     const paragraphEl = fixture.debugElement.query(By.css('p')); | 
					
						
							|  |  |  |     expect(paragraphEl.properties) | 
					
						
							|  |  |  |         .toEqual({title: '( some label - some title )', id: '[ some label ] [ some title ]'}); | 
					
						
							| 
									
										
										
										
											2019-01-22 15:02:52 -08:00
										 |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  |   it('should give access to the node injector', () => { | 
					
						
							| 
									
										
										
										
											2018-09-24 10:30:29 +02:00
										 |  |  |     const fixture = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     fixture.detectChanges(); | 
					
						
							|  |  |  |     const injector = fixture.debugElement.query(By.css('greeting-cmp')).injector; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // from the node injector
 | 
					
						
							|  |  |  |     const greetingCmp = injector.get(GreetingCmp); | 
					
						
							|  |  |  |     expect(greetingCmp.constructor).toBe(GreetingCmp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // from the node injector (inherited from a parent node)
 | 
					
						
							|  |  |  |     const helloWorldCmp = injector.get(HelloWorld); | 
					
						
							|  |  |  |     expect(fixture.componentInstance).toBe(helloWorldCmp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const nameInjected = injector.get(NAME); | 
					
						
							|  |  |  |     expect(nameInjected).toEqual('World!'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-30 17:14:53 +01:00
										 |  |  |   it('should give access to the node injector for root node', () => { | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  |     const hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							| 
									
										
										
										
											2018-09-24 10:30:29 +02:00
										 |  |  |     const injector = hello.debugElement.injector; | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // from the node injector
 | 
					
						
							|  |  |  |     const helloInjected = injector.get(HelloWorld); | 
					
						
							|  |  |  |     expect(helloInjected).toBe(hello.componentInstance); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // from the module injector
 | 
					
						
							|  |  |  |     const nameInjected = injector.get(NAME); | 
					
						
							|  |  |  |     expect(nameInjected).toEqual('World!'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-24 10:30:29 +02:00
										 |  |  |   it('should give access to local refs on a node', () => { | 
					
						
							|  |  |  |     const withRefsCmp = TestBed.createComponent(WithRefsCmp); | 
					
						
							|  |  |  |     const firstDivDebugEl = withRefsCmp.debugElement.query(By.css('div')); | 
					
						
							|  |  |  |     // assert that a native element is referenced by a local ref
 | 
					
						
							|  |  |  |     expect(firstDivDebugEl.references.firstDiv.tagName.toLowerCase()).toBe('div'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  |   it('should give the ability to query by directive', () => { | 
					
						
							|  |  |  |     const hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const greetingByDirective = hello.debugElement.query(By.directive(GreetingCmp)); | 
					
						
							|  |  |  |     expect(greetingByDirective.componentInstance).toBeAnInstanceOf(GreetingCmp); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it('allow to override a template', () => { | 
					
						
							|  |  |  |     // use original template when there is no override
 | 
					
						
							|  |  |  |     let hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  |     expect(hello.nativeElement).toHaveText('Hello World!'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // override the template
 | 
					
						
							|  |  |  |     getTestBed().resetTestingModule(); | 
					
						
							|  |  |  |     TestBed.configureTestingModule({imports: [HelloWorldModule]}); | 
					
						
							|  |  |  |     TestBed.overrideComponent(GreetingCmp, {set: {template: `Bonjour {{ name }}`}}); | 
					
						
							|  |  |  |     hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  |     expect(hello.nativeElement).toHaveText('Bonjour World!'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // restore the original template by calling `.resetTestingModule()`
 | 
					
						
							|  |  |  |     getTestBed().resetTestingModule(); | 
					
						
							|  |  |  |     TestBed.configureTestingModule({imports: [HelloWorldModule]}); | 
					
						
							|  |  |  |     hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  |     expect(hello.nativeElement).toHaveText('Hello World!'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it('allow to override a provider', () => { | 
					
						
							|  |  |  |     TestBed.overrideProvider(NAME, {useValue: 'injected World !'}); | 
					
						
							|  |  |  |     const hello = TestBed.createComponent(HelloWorld); | 
					
						
							|  |  |  |     hello.detectChanges(); | 
					
						
							|  |  |  |     expect(hello.nativeElement).toHaveText('Hello injected World !'); | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2018-12-20 17:45:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-16 16:28:04 -08:00
										 |  |  |   it('should resolve components that are extended by other components', () => { | 
					
						
							|  |  |  |     // SimpleApp uses SimpleCmp in its template, which is extended by InheritedCmp
 | 
					
						
							|  |  |  |     const simpleApp = TestBed.createComponent(SimpleApp); | 
					
						
							|  |  |  |     simpleApp.detectChanges(); | 
					
						
							|  |  |  |     expect(simpleApp.nativeElement).toHaveText('simple - inherited'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-23 15:09:27 -08:00
										 |  |  |   it('should resolve components without async resources synchronously', (done) => { | 
					
						
							|  |  |  |     TestBed | 
					
						
							|  |  |  |         .configureTestingModule({ | 
					
						
							|  |  |  |           declarations: [ComponentWithInlineTemplate], | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         .compileComponents() | 
					
						
							|  |  |  |         .then(done) | 
					
						
							|  |  |  |         .catch(error => { | 
					
						
							|  |  |  |           // This should not throw any errors. If an error is thrown, the test will fail.
 | 
					
						
							|  |  |  |           // Specifically use `catch` here to mark the test as done and *then* throw the error
 | 
					
						
							|  |  |  |           // so that the test isn't treated as a timeout.
 | 
					
						
							|  |  |  |           done(); | 
					
						
							|  |  |  |           throw error; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Intentionally call `createComponent` before `compileComponents` is resolved. We want this to
 | 
					
						
							|  |  |  |     // work for components that don't have any async resources (templateUrl, styleUrls).
 | 
					
						
							|  |  |  |     TestBed.createComponent(ComponentWithInlineTemplate); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-20 17:45:53 -08:00
										 |  |  |   onlyInIvy('patched ng defs should be removed after resetting TestingModule') | 
					
						
							| 
									
										
										
										
											2019-01-29 17:13:02 -08:00
										 |  |  |       .describe('resetting ng defs', () => { | 
					
						
							|  |  |  |         it('should restore ng defs to their initial states', () => { | 
					
						
							|  |  |  |           @Pipe({name: 'somePipe', pure: true}) | 
					
						
							|  |  |  |           class SomePipe { | 
					
						
							|  |  |  |             transform(value: string): string { return `transformed ${value}`; } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           @Directive({selector: 'someDirective'}) | 
					
						
							|  |  |  |           class SomeDirective { | 
					
						
							|  |  |  |             someProp = 'hello'; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           @Component({selector: 'comp', template: 'someText'}) | 
					
						
							|  |  |  |           class SomeComponent { | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           @NgModule({declarations: [SomeComponent]}) | 
					
						
							|  |  |  |           class SomeModule { | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           TestBed.configureTestingModule({imports: [SomeModule]}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           // adding Pipe and Directive via metadata override
 | 
					
						
							|  |  |  |           TestBed.overrideModule( | 
					
						
							|  |  |  |               SomeModule, {set: {declarations: [SomeComponent, SomePipe, SomeDirective]}}); | 
					
						
							|  |  |  |           TestBed.overrideComponent( | 
					
						
							|  |  |  |               SomeComponent, | 
					
						
							|  |  |  |               {set: {template: `<span someDirective>{{'hello' | somePipe}}</span>`}}); | 
					
						
							|  |  |  |           TestBed.createComponent(SomeComponent); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           const defBeforeReset = (SomeComponent as any).ngComponentDef; | 
					
						
							|  |  |  |           expect(defBeforeReset.pipeDefs().length).toEqual(1); | 
					
						
							|  |  |  |           expect(defBeforeReset.directiveDefs().length).toEqual(2);  // directive + component
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           TestBed.resetTestingModule(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           const defAfterReset = (SomeComponent as any).ngComponentDef; | 
					
						
							| 
									
										
										
										
											2019-03-11 10:35:25 -07:00
										 |  |  |           expect(defAfterReset.pipeDefs).toBe(null); | 
					
						
							|  |  |  |           expect(defAfterReset.directiveDefs).toBe(null); | 
					
						
							| 
									
										
										
										
											2019-01-29 17:13:02 -08:00
										 |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         it('should cleanup ng defs for classes with no ng annotations (in case of inheritance)', | 
					
						
							|  |  |  |            () => { | 
					
						
							|  |  |  |              @Component({selector: 'someDirective', template: '...'}) | 
					
						
							|  |  |  |              class SomeComponent { | 
					
						
							|  |  |  |              } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              class ComponentWithNoAnnotations extends SomeComponent {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              TestBed.configureTestingModule({declarations: [ComponentWithNoAnnotations]}); | 
					
						
							|  |  |  |              TestBed.createComponent(ComponentWithNoAnnotations); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              expect(ComponentWithNoAnnotations.hasOwnProperty('ngComponentDef')).toBeTruthy(); | 
					
						
							|  |  |  |              expect(SomeComponent.hasOwnProperty('ngComponentDef')).toBeTruthy(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              TestBed.resetTestingModule(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              expect(ComponentWithNoAnnotations.hasOwnProperty('ngComponentDef')).toBeFalsy(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              // ngComponentDef should be preserved on super component
 | 
					
						
							|  |  |  |              expect(SomeComponent.hasOwnProperty('ngComponentDef')).toBeTruthy(); | 
					
						
							|  |  |  |            }); | 
					
						
							| 
									
										
										
										
											2018-12-20 17:45:53 -08:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  | }); |