UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

226 lines 29.1 kB
'use strict';"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var core_1 = require('angular2/core'); var compiler_1 = require('angular2/compiler'); var lang_1 = require('angular2/src/facade/lang'); var async_1 = require('angular2/src/facade/async'); var collection_1 = require('angular2/src/facade/collection'); var utils_1 = require('./utils'); var dom_tokens_1 = require('angular2/src/platform/dom/dom_tokens'); var dom_adapter_1 = require('angular2/src/platform/dom/dom_adapter'); var debug_node_1 = require('angular2/src/core/debug/debug_node'); var fake_async_1 = require('./fake_async'); /** * Fixture for debugging and testing a component. */ var ComponentFixture = (function () { function ComponentFixture(componentRef) { this.changeDetectorRef = componentRef.changeDetectorRef; this.elementRef = componentRef.location; this.debugElement = debug_node_1.getDebugNode(this.elementRef.nativeElement); this.componentInstance = componentRef.instance; this.nativeElement = this.elementRef.nativeElement; this.componentRef = componentRef; } /** * Trigger a change detection cycle for the component. */ ComponentFixture.prototype.detectChanges = function (checkNoChanges) { if (checkNoChanges === void 0) { checkNoChanges = true; } this.changeDetectorRef.detectChanges(); if (checkNoChanges) { this.checkNoChanges(); } }; ComponentFixture.prototype.checkNoChanges = function () { this.changeDetectorRef.checkNoChanges(); }; /** * Trigger component destruction. */ ComponentFixture.prototype.destroy = function () { this.componentRef.destroy(); }; return ComponentFixture; }()); exports.ComponentFixture = ComponentFixture; var _nextRootElementId = 0; /** * Builds a ComponentFixture for use in component level tests. */ var TestComponentBuilder = (function () { function TestComponentBuilder(_injector) { this._injector = _injector; /** @internal */ this._bindingsOverrides = new Map(); /** @internal */ this._directiveOverrides = new Map(); /** @internal */ this._templateOverrides = new Map(); /** @internal */ this._viewBindingsOverrides = new Map(); /** @internal */ this._viewOverrides = new Map(); } /** @internal */ TestComponentBuilder.prototype._clone = function () { var clone = new TestComponentBuilder(this._injector); clone._viewOverrides = collection_1.MapWrapper.clone(this._viewOverrides); clone._directiveOverrides = collection_1.MapWrapper.clone(this._directiveOverrides); clone._templateOverrides = collection_1.MapWrapper.clone(this._templateOverrides); clone._bindingsOverrides = collection_1.MapWrapper.clone(this._bindingsOverrides); clone._viewBindingsOverrides = collection_1.MapWrapper.clone(this._viewBindingsOverrides); return clone; }; /** * Overrides only the html of a {@link ComponentMetadata}. * All the other properties of the component's {@link ViewMetadata} are preserved. * * @param {Type} component * @param {string} html * * @return {TestComponentBuilder} */ TestComponentBuilder.prototype.overrideTemplate = function (componentType, template) { var clone = this._clone(); clone._templateOverrides.set(componentType, template); return clone; }; /** * Overrides a component's {@link ViewMetadata}. * * @param {Type} component * @param {view} View * * @return {TestComponentBuilder} */ TestComponentBuilder.prototype.overrideView = function (componentType, view) { var clone = this._clone(); clone._viewOverrides.set(componentType, view); return clone; }; /** * Overrides the directives from the component {@link ViewMetadata}. * * @param {Type} component * @param {Type} from * @param {Type} to * * @return {TestComponentBuilder} */ TestComponentBuilder.prototype.overrideDirective = function (componentType, from, to) { var clone = this._clone(); var overridesForComponent = clone._directiveOverrides.get(componentType); if (!lang_1.isPresent(overridesForComponent)) { clone._directiveOverrides.set(componentType, new Map()); overridesForComponent = clone._directiveOverrides.get(componentType); } overridesForComponent.set(from, to); return clone; }; /** * Overrides one or more injectables configured via `providers` metadata property of a directive * or * component. * Very useful when certain providers need to be mocked out. * * The providers specified via this method are appended to the existing `providers` causing the * duplicated providers to * be overridden. * * @param {Type} component * @param {any[]} providers * * @return {TestComponentBuilder} */ TestComponentBuilder.prototype.overrideProviders = function (type, providers) { var clone = this._clone(); clone._bindingsOverrides.set(type, providers); return clone; }; /** * @deprecated */ TestComponentBuilder.prototype.overrideBindings = function (type, providers) { return this.overrideProviders(type, providers); }; /** * Overrides one or more injectables configured via `providers` metadata property of a directive * or * component. * Very useful when certain providers need to be mocked out. * * The providers specified via this method are appended to the existing `providers` causing the * duplicated providers to * be overridden. * * @param {Type} component * @param {any[]} providers * * @return {TestComponentBuilder} */ TestComponentBuilder.prototype.overrideViewProviders = function (type, providers) { var clone = this._clone(); clone._viewBindingsOverrides.set(type, providers); return clone; }; /** * @deprecated */ TestComponentBuilder.prototype.overrideViewBindings = function (type, providers) { return this.overrideViewProviders(type, providers); }; /** * Builds and returns a ComponentFixture. * * @return {Promise<ComponentFixture>} */ TestComponentBuilder.prototype.createAsync = function (rootComponentType) { var mockDirectiveResolver = this._injector.get(compiler_1.DirectiveResolver); var mockViewResolver = this._injector.get(compiler_1.ViewResolver); this._viewOverrides.forEach(function (view, type) { return mockViewResolver.setView(type, view); }); this._templateOverrides.forEach(function (template, type) { return mockViewResolver.setInlineTemplate(type, template); }); this._directiveOverrides.forEach(function (overrides, component) { overrides.forEach(function (to, from) { mockViewResolver.overrideViewDirective(component, from, to); }); }); this._bindingsOverrides.forEach(function (bindings, type) { return mockDirectiveResolver.setBindingsOverride(type, bindings); }); this._viewBindingsOverrides.forEach(function (bindings, type) { return mockDirectiveResolver.setViewBindingsOverride(type, bindings); }); var rootElId = "root" + _nextRootElementId++; var rootEl = utils_1.el("<div id=\"" + rootElId + "\"></div>"); var doc = this._injector.get(dom_tokens_1.DOCUMENT); // TODO(juliemr): can/should this be optional? var oldRoots = dom_adapter_1.DOM.querySelectorAll(doc, '[id^=root]'); for (var i = 0; i < oldRoots.length; i++) { dom_adapter_1.DOM.remove(oldRoots[i]); } dom_adapter_1.DOM.appendChild(doc.body, rootEl); var promise = this._injector.get(core_1.DynamicComponentLoader) .loadAsRoot(rootComponentType, "#" + rootElId, this._injector); return promise.then(function (componentRef) { return new ComponentFixture(componentRef); }); }; TestComponentBuilder.prototype.createFakeAsync = function (rootComponentType) { var result; var error; async_1.PromiseWrapper.then(this.createAsync(rootComponentType), function (_result) { result = _result; }, function (_error) { error = _error; }); fake_async_1.tick(); if (lang_1.isPresent(error)) { throw error; } return result; }; TestComponentBuilder = __decorate([ core_1.Injectable(), __metadata('design:paramtypes', [core_1.Injector]) ], TestComponentBuilder); return TestComponentBuilder; }()); exports.TestComponentBuilder = TestComponentBuilder; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test_component_builder.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-tsQuqjvF.tmp/angular2/src/testing/test_component_builder.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  DynamicComponentLoader,\n  Injector,\n  Injectable,\n  ViewMetadata,\n  ElementRef,\n  EmbeddedViewRef,\n  ChangeDetectorRef,\n  provide\n} from 'angular2/core';\nimport {DirectiveResolver, ViewResolver} from 'angular2/compiler';\n\nimport {Type, isPresent, isBlank} from 'angular2/src/facade/lang';\nimport {PromiseWrapper} from 'angular2/src/facade/async';\nimport {ListWrapper, MapWrapper} from 'angular2/src/facade/collection';\n\nimport {el} from './utils';\n\nimport {DOCUMENT} from 'angular2/src/platform/dom/dom_tokens';\nimport {DOM} from 'angular2/src/platform/dom/dom_adapter';\n\nimport {DebugNode, DebugElement, getDebugNode} from 'angular2/src/core/debug/debug_node';\n\nimport {tick} from './fake_async';\n\n/**\n * Fixture for debugging and testing a component.\n */\nexport class ComponentFixture {\n  /**\n   * The DebugElement associated with the root element of this component.\n   */\n  debugElement: DebugElement;\n\n  /**\n   * The instance of the root component class.\n   */\n  componentInstance: any;\n\n  /**\n   * The native element at the root of the component.\n   */\n  nativeElement: any;\n\n  /**\n   * The ElementRef for the element at the root of the component.\n   */\n  elementRef: ElementRef;\n\n  /**\n   * The ComponentRef for the component\n   */\n  componentRef: ComponentRef;\n\n  /**\n   * The ChangeDetectorRef for the component\n   */\n  changeDetectorRef: ChangeDetectorRef;\n\n  constructor(componentRef: ComponentRef) {\n    this.changeDetectorRef = componentRef.changeDetectorRef;\n    this.elementRef = componentRef.location;\n    this.debugElement = <DebugElement>getDebugNode(this.elementRef.nativeElement);\n    this.componentInstance = componentRef.instance;\n    this.nativeElement = this.elementRef.nativeElement;\n    this.componentRef = componentRef;\n  }\n\n  /**\n   * Trigger a change detection cycle for the component.\n   */\n  detectChanges(checkNoChanges: boolean = true): void {\n    this.changeDetectorRef.detectChanges();\n    if (checkNoChanges) {\n      this.checkNoChanges();\n    }\n  }\n\n  checkNoChanges(): void { this.changeDetectorRef.checkNoChanges(); }\n\n  /**\n   * Trigger component destruction.\n   */\n  destroy(): void { this.componentRef.destroy(); }\n}\n\nvar _nextRootElementId = 0;\n\n/**\n * Builds a ComponentFixture for use in component level tests.\n */\n@Injectable()\nexport class TestComponentBuilder {\n  /** @internal */\n  _bindingsOverrides = new Map<Type, any[]>();\n  /** @internal */\n  _directiveOverrides = new Map<Type, Map<Type, Type>>();\n  /** @internal */\n  _templateOverrides = new Map<Type, string>();\n  /** @internal */\n  _viewBindingsOverrides = new Map<Type, any[]>();\n  /** @internal */\n  _viewOverrides = new Map<Type, ViewMetadata>();\n\n\n  constructor(private _injector: Injector) {}\n\n  /** @internal */\n  _clone(): TestComponentBuilder {\n    var clone = new TestComponentBuilder(this._injector);\n    clone._viewOverrides = MapWrapper.clone(this._viewOverrides);\n    clone._directiveOverrides = MapWrapper.clone(this._directiveOverrides);\n    clone._templateOverrides = MapWrapper.clone(this._templateOverrides);\n    clone._bindingsOverrides = MapWrapper.clone(this._bindingsOverrides);\n    clone._viewBindingsOverrides = MapWrapper.clone(this._viewBindingsOverrides);\n    return clone;\n  }\n\n  /**\n   * Overrides only the html of a {@link ComponentMetadata}.\n   * All the other properties of the component's {@link ViewMetadata} are preserved.\n   *\n   * @param {Type} component\n   * @param {string} html\n   *\n   * @return {TestComponentBuilder}\n   */\n  overrideTemplate(componentType: Type, template: string): TestComponentBuilder {\n    var clone = this._clone();\n    clone._templateOverrides.set(componentType, template);\n    return clone;\n  }\n\n  /**\n   * Overrides a component's {@link ViewMetadata}.\n   *\n   * @param {Type} component\n   * @param {view} View\n   *\n   * @return {TestComponentBuilder}\n   */\n  overrideView(componentType: Type, view: ViewMetadata): TestComponentBuilder {\n    var clone = this._clone();\n    clone._viewOverrides.set(componentType, view);\n    return clone;\n  }\n\n  /**\n   * Overrides the directives from the component {@link ViewMetadata}.\n   *\n   * @param {Type} component\n   * @param {Type} from\n   * @param {Type} to\n   *\n   * @return {TestComponentBuilder}\n   */\n  overrideDirective(componentType: Type, from: Type, to: Type): TestComponentBuilder {\n    var clone = this._clone();\n    var overridesForComponent = clone._directiveOverrides.get(componentType);\n    if (!isPresent(overridesForComponent)) {\n      clone._directiveOverrides.set(componentType, new Map<Type, Type>());\n      overridesForComponent = clone._directiveOverrides.get(componentType);\n    }\n    overridesForComponent.set(from, to);\n    return clone;\n  }\n\n  /**\n   * Overrides one or more injectables configured via `providers` metadata property of a directive\n   * or\n   * component.\n   * Very useful when certain providers need to be mocked out.\n   *\n   * The providers specified via this method are appended to the existing `providers` causing the\n   * duplicated providers to\n   * be overridden.\n   *\n   * @param {Type} component\n   * @param {any[]} providers\n   *\n   * @return {TestComponentBuilder}\n   */\n  overrideProviders(type: Type, providers: any[]): TestComponentBuilder {\n    var clone = this._clone();\n    clone._bindingsOverrides.set(type, providers);\n    return clone;\n  }\n\n  /**\n   * @deprecated\n   */\n  overrideBindings(type: Type, providers: any[]): TestComponentBuilder {\n    return this.overrideProviders(type, providers);\n  }\n\n  /**\n   * Overrides one or more injectables configured via `providers` metadata property of a directive\n   * or\n   * component.\n   * Very useful when certain providers need to be mocked out.\n   *\n   * The providers specified via this method are appended to the existing `providers` causing the\n   * duplicated providers to\n   * be overridden.\n   *\n   * @param {Type} component\n   * @param {any[]} providers\n   *\n   * @return {TestComponentBuilder}\n   */\n  overrideViewProviders(type: Type, providers: any[]): TestComponentBuilder {\n    var clone = this._clone();\n    clone._viewBindingsOverrides.set(type, providers);\n    return clone;\n  }\n\n  /**\n   * @deprecated\n   */\n  overrideViewBindings(type: Type, providers: any[]): TestComponentBuilder {\n    return this.overrideViewProviders(type, providers);\n  }\n\n  /**\n   * Builds and returns a ComponentFixture.\n   *\n   * @return {Promise<ComponentFixture>}\n   */\n  createAsync(rootComponentType: Type): Promise<ComponentFixture> {\n    var mockDirectiveResolver = this._injector.get(DirectiveResolver);\n    var mockViewResolver = this._injector.get(ViewResolver);\n    this._viewOverrides.forEach((view, type) => mockViewResolver.setView(type, view));\n    this._templateOverrides.forEach((template, type) =>\n                                        mockViewResolver.setInlineTemplate(type, template));\n    this._directiveOverrides.forEach((overrides, component) => {\n      overrides.forEach(\n          (to, from) => { mockViewResolver.overrideViewDirective(component, from, to); });\n    });\n    this._bindingsOverrides.forEach((bindings, type) =>\n                                        mockDirectiveResolver.setBindingsOverride(type, bindings));\n    this._viewBindingsOverrides.forEach(\n        (bindings, type) => mockDirectiveResolver.setViewBindingsOverride(type, bindings));\n\n    var rootElId = `root${_nextRootElementId++}`;\n    var rootEl = el(`<div id=\"${rootElId}\"></div>`);\n    var doc = this._injector.get(DOCUMENT);\n\n    // TODO(juliemr): can/should this be optional?\n    var oldRoots = DOM.querySelectorAll(doc, '[id^=root]');\n    for (var i = 0; i < oldRoots.length; i++) {\n      DOM.remove(oldRoots[i]);\n    }\n    DOM.appendChild(doc.body, rootEl);\n\n    var promise: Promise<ComponentRef> =\n        this._injector.get(DynamicComponentLoader)\n            .loadAsRoot(rootComponentType, `#${rootElId}`, this._injector);\n    return promise.then((componentRef) => { return new ComponentFixture(componentRef); });\n  }\n\n  createFakeAsync(rootComponentType: Type): ComponentFixture {\n    var result;\n    var error;\n    PromiseWrapper.then(this.createAsync(rootComponentType), (_result) => { result = _result; },\n                        (_error) => { error = _error; });\n    tick();\n    if (isPresent(error)) {\n      throw error;\n    }\n    return result;\n  }\n}\n"]}