80 lines
3.1 KiB
TypeScript
80 lines
3.1 KiB
TypeScript
/**
|
|
* @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
|
|
*/
|
|
|
|
import {AnimationMetadata, animate, group, sequence, style, transition, trigger} from '@angular/core';
|
|
import {AsyncTestCompleter, beforeEach, beforeEachProviders, ddescribe, describe, expect, iit, inject, it, xdescribe, xit} from '@angular/core/testing/testing_internal';
|
|
|
|
import {StringMapWrapper} from '../../../platform-browser-dynamic/src/facade/collection';
|
|
import {AnimationCompiler, CompiledAnimationTriggerResult} from '../../src/animation/animation_compiler';
|
|
import {CompileAnimationEntryMetadata, CompileDirectiveMetadata, CompileTemplateMetadata, CompileTypeMetadata} from '../../src/compile_metadata';
|
|
import {CompileMetadataResolver} from '../../src/metadata_resolver';
|
|
|
|
export function main() {
|
|
describe('RuntimeAnimationCompiler', () => {
|
|
var resolver: any /** TODO #9100 */;
|
|
beforeEach(
|
|
inject([CompileMetadataResolver], (res: CompileMetadataResolver) => { resolver = res; }));
|
|
|
|
var compiler = new AnimationCompiler();
|
|
|
|
var compileAnimations =
|
|
(component: CompileDirectiveMetadata): CompiledAnimationTriggerResult => {
|
|
var result = compiler.compileComponent(component, []);
|
|
return result.triggers[0];
|
|
};
|
|
|
|
var compileTriggers = (input: any[]) => {
|
|
var entries: CompileAnimationEntryMetadata[] = input.map(entry => {
|
|
var animationTriggerData = trigger(entry[0], entry[1]);
|
|
return resolver.getAnimationEntryMetadata(animationTriggerData);
|
|
});
|
|
|
|
var component = CompileDirectiveMetadata.create({
|
|
type: new CompileTypeMetadata({name: 'myCmp'}),
|
|
template: new CompileTemplateMetadata({animations: entries})
|
|
});
|
|
|
|
return compileAnimations(component);
|
|
};
|
|
|
|
var compileSequence = (seq: AnimationMetadata) => {
|
|
return compileTriggers([['myAnimation', [transition('state1 => state2', seq)]]]);
|
|
};
|
|
|
|
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 {
|
|
compileSequence(animation);
|
|
} catch (e) {
|
|
capturedErrorMessage = e.message;
|
|
}
|
|
|
|
expect(capturedErrorMessage)
|
|
.toMatch(/Unable to apply styles due to missing a state: "missing_state"/g);
|
|
|
|
expect(capturedErrorMessage)
|
|
.toMatch(/Animation states via styles must be prefixed with a ":"/);
|
|
});
|
|
|
|
it('should throw an error when two or more animation triggers contain the same name', () => {
|
|
var t1Data: any[] = [];
|
|
var t2Data: any[] = [];
|
|
|
|
expect(() => {
|
|
compileTriggers([['myTrigger', t1Data], ['myTrigger', t2Data]]);
|
|
}).toThrowError(/The animation trigger "myTrigger" has already been registered on "myCmp"/);
|
|
});
|
|
});
|
|
}
|