83 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			83 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|  | import { | ||
|  |   AsyncTestCompleter, | ||
|  |   beforeEach, | ||
|  |   ddescribe, | ||
|  |   xdescribe, | ||
|  |   describe, | ||
|  |   expect, | ||
|  |   iit, | ||
|  |   inject, | ||
|  |   it, | ||
|  |   xit, | ||
|  |   beforeEachProviders | ||
|  | } from '@angular/core/testing/testing_internal'; | ||
|  | 
 | ||
|  | import {trigger, style, animate, group, sequence, transition, AnimationMetadata} from '@angular/core'; | ||
|  | 
 | ||
|  | import {AnimationCompiler, CompiledAnimation} from '../../src/animation/animation_compiler'; | ||
|  | import { | ||
|  |   CompileTemplateMetadata, | ||
|  |   CompileDirectiveMetadata, | ||
|  |   CompileTypeMetadata | ||
|  | } from '../../src/compile_metadata'; | ||
|  | 
 | ||
|  | import {CompileMetadataResolver} from '../../src/metadata_resolver'; | ||
|  | 
 | ||
|  | export function main() { | ||
|  |   describe('RuntimeAnimationCompiler', () => { | ||
|  |     var resolver; | ||
|  |     beforeEach(inject([CompileMetadataResolver], (res: CompileMetadataResolver) => { | ||
|  |       resolver = res; | ||
|  |     })); | ||
|  | 
 | ||
|  |     var compiler = new AnimationCompiler(); | ||
|  | 
 | ||
|  |     var compileAnimations = (component: CompileDirectiveMetadata): CompiledAnimation => { | ||
|  |       return compiler.compileComponent(component)[0]; | ||
|  |     }; | ||
|  | 
 | ||
|  |     var compile = (seq: AnimationMetadata) => { | ||
|  |       var entry = trigger('myAnimation', [ | ||
|  |         transition('state1 => state2', seq) | ||
|  |       ]); | ||
|  | 
 | ||
|  |       var compiledAnimationEntry = resolver.getAnimationEntryMetadata(entry); | ||
|  |       var component = CompileDirectiveMetadata.create({ | ||
|  |         type: new CompileTypeMetadata({ | ||
|  |           name: 'something' | ||
|  |         }), | ||
|  |         template: new CompileTemplateMetadata({ | ||
|  |           animations: [compiledAnimationEntry] | ||
|  |         }) | ||
|  |       }); | ||
|  | 
 | ||
|  |       return compileAnimations(component); | ||
|  |     }; | ||
|  | 
 | ||
|  |     it('should throw an exception containing all the inner animation parser errors', () => { | ||
|  |       var animation = sequence([ | ||
|  |         style({"color": "red"}), | ||
|  |         animate(1000, style({"font-size": "100px"})), | ||
|  |         style({"color": "blue"}), | ||
|  |         animate(1000, style(":missing_state")), | ||
|  |         style({"color": "gold"}), | ||
|  |         animate(1000, style("broken_state")) | ||
|  |       ]); | ||
|  | 
 | ||
|  |       var capturedErrorMessage: string; | ||
|  |       try { | ||
|  |         compile(animation); | ||
|  |       } catch (e) { | ||
|  |         capturedErrorMessage = e.message; | ||
|  |       } | ||
|  | 
 | ||
|  |       expect(capturedErrorMessage) | ||
|  |           .toMatchPattern( | ||
|  |               /Unable to apply styles due to missing a state: "missing_state"/g); | ||
|  | 
 | ||
|  |       expect(capturedErrorMessage) | ||
|  |           .toMatchPattern(/Animation states via styles must be prefixed with a ":"/); | ||
|  |     }); | ||
|  |   }); | ||
|  | } |