| 
									
										
										
										
											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-06-24 08:46:43 -07:00
										 |  |  | import {beforeEach, ddescribe, describe, expect, iit, it, inject,} from '@angular/core/testing/testing_internal'; | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-28 17:50:03 -07:00
										 |  |  | import {stringify} from '../src/facade/lang'; | 
					
						
							|  |  |  | import {MockViewResolver} from '../testing'; | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  | import {Component, ViewMetadata, Injector} from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2016-04-28 17:50:03 -07:00
										 |  |  | import {isBlank} from '../src/facade/lang'; | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | export function main() { | 
					
						
							| 
									
										
										
										
											2015-06-24 10:54:04 +02:00
										 |  |  |   describe('MockViewResolver', () => { | 
					
						
							| 
									
										
										
										
											2016-02-19 11:49:31 -08:00
										 |  |  |     var viewResolver: MockViewResolver; | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |     beforeEach(inject( | 
					
						
							|  |  |  |         [Injector], (injector: Injector) => { viewResolver = new MockViewResolver(injector); })); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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', () => { | 
					
						
							|  |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(view.template).toEqual('template'); | 
					
						
							|  |  |  |         expect(view.directives).toEqual([SomeDirective]); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-09 21:20:11 +02:00
										 |  |  |       it('should allow overriding the @View', () => { | 
					
						
							| 
									
										
										
										
											2015-08-20 13:51:48 +02:00
										 |  |  |         viewResolver.setView(SomeComponent, new ViewMetadata({template: 'overridden template'})); | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(view.template).toEqual('overridden template'); | 
					
						
							|  |  |  |         expect(isBlank(view.directives)).toBe(true); | 
					
						
							| 
									
										
										
										
											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', () => { | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         viewResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |         viewResolver.setView(SomeComponent, new ViewMetadata({template: 'overridden template'})); | 
					
						
							|  |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(view.template).toEqual('overridden template'); | 
					
						
							|  |  |  |         expect(isBlank(view.directives)).toBe(true); | 
					
						
							| 
									
										
										
										
											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', () => { | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         viewResolver.setInlineTemplate(SomeComponent, 'overridden template'); | 
					
						
							|  |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(view.template).toEqual('overridden template'); | 
					
						
							|  |  |  |         expect(view.directives).toEqual([SomeDirective]); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 15:47:48 +08:00
										 |  |  |       it('should allow overriding an overridden @View', () => { | 
					
						
							| 
									
										
										
										
											2015-08-20 13:51:48 +02:00
										 |  |  |         viewResolver.setView(SomeComponent, new ViewMetadata({template: 'overridden template'})); | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         viewResolver.setInlineTemplate(SomeComponent, 'overridden template x 2'); | 
					
						
							|  |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         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', () => { | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         viewResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |         viewResolver.setInlineTemplate(SomeComponent, 'overridden template'); | 
					
						
							|  |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(view.template).toEqual('overridden template'); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe('Directive overriding', () => { | 
					
						
							| 
									
										
										
										
											2015-06-24 10:54:04 +02:00
										 |  |  |       it('should allow overriding a directive from the default view', () => { | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         viewResolver.overrideViewDirective(SomeComponent, SomeDirective, SomeOtherDirective); | 
					
						
							|  |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(view.directives.length).toEqual(1); | 
					
						
							|  |  |  |         expect(view.directives[0]).toBe(SomeOtherDirective); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 15:47:48 +08:00
										 |  |  |       it('should allow overriding a directive from an overridden @View', () => { | 
					
						
							| 
									
										
										
										
											2015-08-20 13:51:48 +02:00
										 |  |  |         viewResolver.setView(SomeComponent, new ViewMetadata({directives: [SomeOtherDirective]})); | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         viewResolver.overrideViewDirective(SomeComponent, SomeOtherDirective, SomeComponent); | 
					
						
							|  |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(view.directives.length).toEqual(1); | 
					
						
							|  |  |  |         expect(view.directives[0]).toBe(SomeComponent); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should throw when the overridden directive is not present', () => { | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         viewResolver.overrideViewDirective(SomeComponent, SomeOtherDirective, SomeDirective); | 
					
						
							|  |  |  |         expect(() => { viewResolver.resolve(SomeComponent); }) | 
					
						
							| 
									
										
										
										
											2015-06-02 17:41:44 -07:00
										 |  |  |             .toThrowError( | 
					
						
							|  |  |  |                 `Overriden directive ${stringify(SomeOtherDirective)} not found in the template of ${stringify(SomeComponent)}`); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |       it('should allow overriding a directive after its view has been resolved', () => { | 
					
						
							| 
									
										
										
										
											2015-06-24 11:10:29 +02:00
										 |  |  |         viewResolver.resolve(SomeComponent); | 
					
						
							| 
									
										
										
										
											2016-06-24 08:46:43 -07:00
										 |  |  |         viewResolver.overrideViewDirective(SomeComponent, SomeDirective, SomeOtherDirective); | 
					
						
							|  |  |  |         var view = viewResolver.resolve(SomeComponent); | 
					
						
							|  |  |  |         expect(view.directives.length).toEqual(1); | 
					
						
							|  |  |  |         expect(view.directives[0]).toBe(SomeOtherDirective); | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-02 17:41:44 -07:00
										 |  |  | class SomeDirective {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-08 13:36:48 -08:00
										 |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'cmp', | 
					
						
							| 
									
										
										
										
											2015-04-09 21:20:11 +02:00
										 |  |  |   template: 'template', | 
					
						
							| 
									
										
										
										
											2015-03-30 15:45:03 +02:00
										 |  |  |   directives: [SomeDirective], | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | class SomeComponent { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-02 17:41:44 -07:00
										 |  |  | class SomeOtherDirective {} |