| 
									
										
										
										
											2016-06-23 09:47:54 -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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-12 19:14:17 -07:00
										 |  |  | import {Component, Directive, Injector} from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2016-08-19 13:51:45 -07:00
										 |  |  | import {TestBed, inject} from '@angular/core/testing'; | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-30 18:07:40 -07:00
										 |  |  | import {MockDirectiveResolver} from '../testing/index'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import {ViewMetadata} from './private_import_core'; | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | export function main() { | 
					
						
							| 
									
										
										
										
											2016-07-28 06:31:26 -07:00
										 |  |  |   describe('MockDirectiveResolver', () => { | 
					
						
							|  |  |  |     var dirResolver: MockDirectiveResolver; | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-19 13:51:45 -07:00
										 |  |  |     beforeEach(() => { | 
					
						
							|  |  |  |       TestBed.configureTestingModule( | 
					
						
							|  |  |  |           {declarations: [SomeDirective, SomeOtherDirective, SomeComponent]}); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-28 06:31:26 -07:00
										 |  |  |     beforeEach(inject([Injector], (injector: Injector) => { | 
					
						
							|  |  |  |       dirResolver = new MockDirectiveResolver(injector); | 
					
						
							|  |  |  |     })); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-28 06:45:22 -07:00
										 |  |  |     describe('Directive overriding', () => { | 
					
						
							|  |  |  |       it('should fallback to the default DirectiveResolver when templates are not overridden', | 
					
						
							|  |  |  |          () => { | 
					
						
							|  |  |  |            var ngModule = dirResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |            expect(ngModule.selector).toEqual('cmp'); | 
					
						
							|  |  |  |          }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-28 04:54:49 -07:00
										 |  |  |       it('should allow overriding the @Directive', () => { | 
					
						
							| 
									
										
										
										
											2016-09-12 19:14:17 -07:00
										 |  |  |         dirResolver.setDirective(SomeComponent, new Component({selector: 'someOtherSelector'})); | 
					
						
							| 
									
										
										
										
											2016-07-28 06:45:22 -07:00
										 |  |  |         var metadata = dirResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(metadata.selector).toEqual('someOtherSelector'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-09 21:20:11 +02:00
										 |  |  |     describe('View overriding', () => { | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |       it('should fallback to the default ViewResolver when templates are not overridden', () => { | 
					
						
							| 
									
										
										
										
											2016-09-12 19:14:17 -07:00
										 |  |  |         var view = <Component>dirResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         expect(view.template).toEqual('template'); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-09 21:20:11 +02:00
										 |  |  |       it('should allow overriding the @View', () => { | 
					
						
							| 
									
										
										
										
											2016-07-28 06:31:26 -07:00
										 |  |  |         dirResolver.setView(SomeComponent, new ViewMetadata({template: 'overridden template'})); | 
					
						
							| 
									
										
										
										
											2016-09-12 19:14:17 -07:00
										 |  |  |         var view = <Component>dirResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         expect(view.template).toEqual('overridden template'); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |       it('should allow overriding a view after it has been resolved', () => { | 
					
						
							| 
									
										
										
										
											2016-07-28 06:31:26 -07:00
										 |  |  |         dirResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         dirResolver.setView(SomeComponent, new ViewMetadata({template: 'overridden template'})); | 
					
						
							| 
									
										
										
										
											2016-09-12 19:14:17 -07:00
										 |  |  |         var view = <Component>dirResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |         expect(view.template).toEqual('overridden template'); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-09 21:20:11 +02:00
										 |  |  |     describe('inline template definition overriding', () => { | 
					
						
							|  |  |  |       it('should allow overriding the default template', () => { | 
					
						
							| 
									
										
										
										
											2016-07-28 06:31:26 -07:00
										 |  |  |         dirResolver.setInlineTemplate(SomeComponent, 'overridden template'); | 
					
						
							| 
									
										
										
										
											2016-09-12 19:14:17 -07:00
										 |  |  |         var view = <Component>dirResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         expect(view.template).toEqual('overridden template'); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 15:47:48 +08:00
										 |  |  |       it('should allow overriding an overridden @View', () => { | 
					
						
							| 
									
										
										
										
											2016-07-28 06:31:26 -07:00
										 |  |  |         dirResolver.setView(SomeComponent, new ViewMetadata({template: 'overridden template'})); | 
					
						
							|  |  |  |         dirResolver.setInlineTemplate(SomeComponent, 'overridden template x 2'); | 
					
						
							| 
									
										
										
										
											2016-09-12 19:14:17 -07:00
										 |  |  |         var view = <Component>dirResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         expect(view.template).toEqual('overridden template x 2'); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |       it('should allow overriding a view after it has been resolved', () => { | 
					
						
							| 
									
										
										
										
											2016-07-28 06:31:26 -07:00
										 |  |  |         dirResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         dirResolver.setInlineTemplate(SomeComponent, 'overridden template'); | 
					
						
							| 
									
										
										
										
											2016-09-12 19:14:17 -07:00
										 |  |  |         var view = <Component>dirResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |         expect(view.template).toEqual('overridden template'); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-19 13:51:45 -07:00
										 |  |  | @Directive({selector: 'some-directive'}) | 
					
						
							|  |  |  | class SomeDirective { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2015-06-02 17:41:44 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-19 13:51:45 -07:00
										 |  |  | @Component({selector: 'cmp', template: 'template'}) | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | class SomeComponent { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-19 13:51:45 -07:00
										 |  |  | @Directive({selector: 'some-other-directive'}) | 
					
						
							|  |  |  | class SomeOtherDirective { | 
					
						
							|  |  |  | } |