From 8a9e9c7bd3f889de07b21e95698e0aa2d465af02 Mon Sep 17 00:00:00 2001 From: Julie Ralph Date: Thu, 23 Jun 2016 17:10:22 -0700 Subject: [PATCH] fix(core/testing): clean up the core testing public API (#9466) Previously, we were exporting internal mocks and helpers. Move these to core/testing/testing_internal or remove them if they were never used. Remove deprecated items - injectAsync, clearPendingTimers. BREAKING CHANGE: Remove the following APIs from `@angular/core/testing`, which have been deprecated or were never intended to be publicly exported: ``` injectAsync clearPendingTimers Log MockAppliacationHref MockNgZone clearPendingTimers getTypeOf instantiateType ``` Instead of `injectAsync`, use `async(inject())`. `clearPendingTimers` is no longer required. --- .../test/forms-deprecated/directives_spec.ts | 2 +- .../test/forms-deprecated/model_spec.ts | 2 +- .../test/forms-deprecated/validators_spec.ts | 2 +- .../directive_lifecycle_integration_spec.ts | 12 +++--- modules/@angular/core/test/fake_async_spec.ts | 4 +- .../change_detection_integration_spec.ts | 2 +- .../core/test/linker/integration_spec.ts | 4 +- .../linker/view_injector_integration_spec.ts | 4 +- .../@angular/core/test/zone/ng_zone_spec.ts | 10 ++--- modules/@angular/core/testing.ts | 5 +-- modules/@angular/core/testing/async.ts | 5 +++ modules/@angular/core/testing/fake_async.ts | 11 ------ .../@angular/core/testing/test_injector.ts | 34 ---------------- modules/@angular/core/testing/testing.ts | 6 +-- .../@angular/core/testing/testing_internal.ts | 3 ++ .../examples/testing/ts/fake_async.ts | 8 ++-- .../@angular/forms/test/directives_spec.ts | 4 +- modules/@angular/forms/test/model_spec.ts | 9 +++-- .../@angular/forms/test/validators_spec.ts | 2 +- .../test/testing_public_browser_spec.ts | 2 +- .../test/xhr/xhr_cache_spec.ts | 2 +- .../test/browser/bootstrap_spec.ts | 5 ++- .../web_workers/shared/message_bus_spec.ts | 15 +++---- .../platform-browser/testing/browser.ts | 3 +- .../platform-server/testing/server.ts | 3 +- .../test/integration/bootstrap_spec.ts | 24 ++++++------ tools/public_api_guard/core/testing.d.ts | 39 ------------------- 27 files changed, 71 insertions(+), 151 deletions(-) diff --git a/modules/@angular/common/test/forms-deprecated/directives_spec.ts b/modules/@angular/common/test/forms-deprecated/directives_spec.ts index e21df4c9d3..64ac6b934b 100644 --- a/modules/@angular/common/test/forms-deprecated/directives_spec.ts +++ b/modules/@angular/common/test/forms-deprecated/directives_spec.ts @@ -8,7 +8,7 @@ import {afterEach, beforeEach, ddescribe, describe, expect, iit, inject, it, xit} from '@angular/core/testing/testing_internal'; -import {fakeAsync, flushMicrotasks, Log, tick,} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick,} from '@angular/core/testing'; import {SpyNgControl, SpyValueAccessor} from '../spies'; diff --git a/modules/@angular/common/test/forms-deprecated/model_spec.ts b/modules/@angular/common/test/forms-deprecated/model_spec.ts index 8a26465ac0..71c76adf07 100644 --- a/modules/@angular/common/test/forms-deprecated/model_spec.ts +++ b/modules/@angular/common/test/forms-deprecated/model_spec.ts @@ -7,7 +7,7 @@ */ import {ddescribe, describe, it, iit, xit, expect, beforeEach, afterEach, inject,} from '@angular/core/testing/testing_internal'; -import {fakeAsync, flushMicrotasks, Log, tick} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick} from '@angular/core/testing'; import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; import {ControlGroup, Control, ControlArray, Validators} from '@angular/common/src/forms-deprecated'; import {IS_DART, isPresent} from '../../src/facade/lang'; diff --git a/modules/@angular/common/test/forms-deprecated/validators_spec.ts b/modules/@angular/common/test/forms-deprecated/validators_spec.ts index 60775ba3a7..4926007b80 100644 --- a/modules/@angular/common/test/forms-deprecated/validators_spec.ts +++ b/modules/@angular/common/test/forms-deprecated/validators_spec.ts @@ -7,7 +7,7 @@ */ import {AbstractControl, Control, ControlArray, ControlGroup, Validators} from '@angular/common/src/forms-deprecated'; -import {Log, fakeAsync, flushMicrotasks, tick} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick} from '@angular/core/testing'; import {afterEach, beforeEach, ddescribe, describe, expect, iit, it, xit} from '@angular/core/testing/testing_internal'; import {EventEmitter, ObservableWrapper, TimerWrapper} from '../../src/facade/async'; diff --git a/modules/@angular/core/test/directive_lifecycle_integration_spec.ts b/modules/@angular/core/test/directive_lifecycle_integration_spec.ts index 243040b210..6232e04a44 100644 --- a/modules/@angular/core/test/directive_lifecycle_integration_spec.ts +++ b/modules/@angular/core/test/directive_lifecycle_integration_spec.ts @@ -6,17 +6,17 @@ * found in the LICENSE file at https://angular.io/license */ -import {beforeEach, ddescribe, describe, expect, iit, inject, it, xdescribe, xit,} from '@angular/core/testing/testing_internal'; -import {Log} from '@angular/core/testing'; -import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; import {TestComponentBuilder} from '@angular/compiler/testing'; - -import {OnChanges, OnInit, DoCheck, AfterContentInit, AfterContentChecked, AfterViewInit, AfterViewChecked} from '@angular/core'; -import {Directive, Component, ViewMetadata} from '@angular/core/src/metadata'; +import {AfterContentChecked, AfterContentInit, AfterViewChecked, AfterViewInit, DoCheck, OnChanges, OnInit} from '@angular/core'; +import {Component, Directive, ViewMetadata} from '@angular/core/src/metadata'; +import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; +import {Log, beforeEach, beforeEachProviders, ddescribe, describe, expect, iit, inject, it, xdescribe, xit} from '@angular/core/testing/testing_internal'; export function main() { describe('directive lifecycle integration spec', () => { + beforeEachProviders(() => { return [Log]; }); + it('should invoke lifecycle methods ngOnChanges > ngOnInit > ngDoCheck > ngAfterContentChecked', inject( [TestComponentBuilder, Log, AsyncTestCompleter], diff --git a/modules/@angular/core/test/fake_async_spec.ts b/modules/@angular/core/test/fake_async_spec.ts index d8abff2727..58f06e146c 100644 --- a/modules/@angular/core/test/fake_async_spec.ts +++ b/modules/@angular/core/test/fake_async_spec.ts @@ -6,8 +6,8 @@ * found in the LICENSE file at https://angular.io/license */ -import {beforeEach, ddescribe, describe, expect, iit, inject, it, xit} from '@angular/core/testing/testing_internal'; -import {fakeAsync, flushMicrotasks, Log, tick, discardPeriodicTasks,} from '@angular/core/testing'; +import {Log, beforeEach, ddescribe, describe, expect, iit, inject, it, xit} from '@angular/core/testing/testing_internal'; +import {fakeAsync, flushMicrotasks, tick, discardPeriodicTasks,} from '@angular/core/testing'; import {TimerWrapper, PromiseWrapper} from '../../router-deprecated/src/facade/async'; import {BaseException} from '../../router-deprecated/src/facade/exceptions'; import {Parser} from '../../compiler/src/expression_parser/parser'; diff --git a/modules/@angular/core/test/linker/change_detection_integration_spec.ts b/modules/@angular/core/test/linker/change_detection_integration_spec.ts index f460ebd719..20b672f871 100644 --- a/modules/@angular/core/test/linker/change_detection_integration_spec.ts +++ b/modules/@angular/core/test/linker/change_detection_integration_spec.ts @@ -8,7 +8,7 @@ import {afterEach, beforeEach, beforeEachProviders, ddescribe, describe, expect, iit, inject, it, xit} from '@angular/core/testing/testing_internal'; -import {fakeAsync, flushMicrotasks, Log, tick,} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick,} from '@angular/core/testing'; import {TestComponentBuilder, ComponentFixture} from '@angular/compiler/testing'; import {isBlank, NumberWrapper,} from '../../src/facade/lang'; diff --git a/modules/@angular/core/test/linker/integration_spec.ts b/modules/@angular/core/test/linker/integration_spec.ts index 1210c356fb..67f7b83858 100644 --- a/modules/@angular/core/test/linker/integration_spec.ts +++ b/modules/@angular/core/test/linker/integration_spec.ts @@ -7,7 +7,7 @@ */ import {beforeEach, ddescribe, xdescribe, describe, expect, iit, inject, beforeEachProviders, it, xit,} from '@angular/core/testing/testing_internal'; -import {fakeAsync, tick, clearPendingTimers} from '@angular/core/testing'; +import {fakeAsync, tick} from '@angular/core/testing'; import {TestComponentBuilder, ComponentFixture} from '@angular/compiler/testing'; import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; import {getDOM} from '@angular/platform-browser/src/dom/dom_adapter'; @@ -1630,8 +1630,6 @@ function declareTests({useJit}: {useJit: boolean}) { try { tc.injector.get(DirectiveEmittingEvent).fireEvent('boom'); } catch (e) { - clearPendingTimers(); - var c = e.context; expect(getDOM().nodeName(c.renderNode).toUpperCase()).toEqual('SPAN'); expect(getDOM().nodeName(c.componentRenderElement).toUpperCase()).toEqual('DIV'); diff --git a/modules/@angular/core/test/linker/view_injector_integration_spec.ts b/modules/@angular/core/test/linker/view_injector_integration_spec.ts index 804fdcf920..67d7c22d63 100644 --- a/modules/@angular/core/test/linker/view_injector_integration_spec.ts +++ b/modules/@angular/core/test/linker/view_injector_integration_spec.ts @@ -7,7 +7,7 @@ */ import {describe, ddescribe, it, iit, xit, xdescribe, expect, beforeEach, beforeEachProviders, inject,} from '@angular/core/testing/testing_internal'; -import {fakeAsync, flushMicrotasks, Log, tick} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick} from '@angular/core/testing'; import {TestComponentBuilder, ComponentFixture} from '@angular/compiler/testing'; import {isBlank} from '../../src/facade/lang'; import {Type, ViewContainerRef, TemplateRef, ElementRef, ChangeDetectorRef, ChangeDetectionStrategy, Directive, Component, DebugElement, forwardRef, Input, PipeTransform, Attribute, ViewMetadata, provide, Optional, Inject, Self, InjectMetadata, Pipe, Host, SkipSelfMetadata} from '@angular/core'; @@ -713,4 +713,4 @@ export function main() { class TestValue { constructor(public value: string) {} -} \ No newline at end of file +} diff --git a/modules/@angular/core/test/zone/ng_zone_spec.ts b/modules/@angular/core/test/zone/ng_zone_spec.ts index 2d588a47fc..d25d3f42c3 100644 --- a/modules/@angular/core/test/zone/ng_zone_spec.ts +++ b/modules/@angular/core/test/zone/ng_zone_spec.ts @@ -6,16 +6,16 @@ * found in the LICENSE file at https://angular.io/license */ -import {beforeEach, ddescribe, describe, expect, iit, inject, it, xdescribe, xit,} from '@angular/core/testing/testing_internal'; -import {Log} from '@angular/core/testing'; +import {Log, beforeEach, ddescribe, describe, expect, iit, inject, it, xdescribe, xit,} from '@angular/core/testing/testing_internal'; -import {PromiseCompleter, PromiseWrapper, TimerWrapper, ObservableWrapper} from '../../src/facade/async'; -import {BaseException} from '../../src/facade/exceptions'; -import {IS_DART, scheduleMicroTask, isPresent} from '../../src/facade/lang'; import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; import {NgZone, NgZoneError} from '@angular/core/src/zone/ng_zone'; import {browserDetection} from '@angular/platform-browser/testing/browser_util'; +import {ObservableWrapper, PromiseCompleter, PromiseWrapper, TimerWrapper} from '../../src/facade/async'; +import {BaseException} from '../../src/facade/exceptions'; +import {IS_DART, isPresent, scheduleMicroTask} from '../../src/facade/lang'; + var needsLongerTimers = browserDetection.isSlow || browserDetection.isEdge; var resultTimer = 1000; var testTimeout = browserDetection.isEdge ? 1200 : 500; diff --git a/modules/@angular/core/testing.ts b/modules/@angular/core/testing.ts index 2bd9f362ff..48b9b3d21e 100644 --- a/modules/@angular/core/testing.ts +++ b/modules/@angular/core/testing.ts @@ -6,10 +6,7 @@ * found in the LICENSE file at https://angular.io/license */ +export * from './testing/async'; export * from './testing/fake_async'; -export * from './testing/lang_utils'; -export * from './testing/logger'; -export * from './testing/ng_zone_mock'; export * from './testing/test_injector'; export * from './testing/testing'; -export * from './testing/mock_application_ref'; diff --git a/modules/@angular/core/testing/async.ts b/modules/@angular/core/testing/async.ts index d7dfbde38a..8905cb6052 100644 --- a/modules/@angular/core/testing/async.ts +++ b/modules/@angular/core/testing/async.ts @@ -24,6 +24,11 @@ export function async(fn: Function): Function { return () => new Promise((finishCallback, failCallback) => { var AsyncTestZoneSpec = (Zone as any /** TODO #9100 */)['AsyncTestZoneSpec']; + if (AsyncTestZoneSpec === undefined) { + throw new Error( + 'AsyncTestZoneSpec is needed for the async() test helper but could not be found. ' + + 'Please make sure that your environment includes zone.js/dist/async-test.js'); + } var testZoneSpec = new AsyncTestZoneSpec(finishCallback, failCallback, 'test'); var testZone = Zone.current.fork(testZoneSpec); return testZone.run(fn); diff --git a/modules/@angular/core/testing/fake_async.ts b/modules/@angular/core/testing/fake_async.ts index 92fe9a4fd9..d4676f5afb 100644 --- a/modules/@angular/core/testing/fake_async.ts +++ b/modules/@angular/core/testing/fake_async.ts @@ -7,7 +7,6 @@ */ import {BaseException} from '../index'; -import {getTestInjector} from './test_injector'; let _FakeAsyncTestZoneSpecType = (Zone as any /** TODO #9100 */)['FakeAsyncTestZoneSpec']; @@ -64,16 +63,6 @@ function _getFakeAsyncZoneSpec(): any { return zoneSpec; } -/** - * Clear the queue of pending timers and microtasks. - * Tests no longer need to call this explicitly. - * - * @deprecated - */ -export function clearPendingTimers(): void { - // Do nothing. -} - /** * Simulates the asynchronous passage of time for the timers in the fakeAsync zone. * diff --git a/modules/@angular/core/testing/test_injector.ts b/modules/@angular/core/testing/test_injector.ts index 47a0ef3253..1af863b844 100644 --- a/modules/@angular/core/testing/test_injector.ts +++ b/modules/@angular/core/testing/test_injector.ts @@ -11,12 +11,8 @@ import {lockRunMode} from '../src/application_ref'; import {ListWrapper} from '../src/facade/collection'; import {BaseException} from '../src/facade/exceptions'; import {FunctionWrapper, isPresent} from '../src/facade/lang'; - -import {async} from './async'; import {AsyncTestCompleter} from './async_test_completer'; -export {async} from './async'; - export class TestInjector { private _instantiated: boolean = false; @@ -168,42 +164,12 @@ export class InjectSetupWrapper { return inject_impl(tokens, fn)(); }; } - - /** @deprecated {use async(withProviders().inject())} */ - injectAsync(tokens: any[], fn: Function): Function { - return () => { - this._addProviders(); - return injectAsync_impl(tokens, fn)(); - }; - } } export function withProviders(providers: () => any) { return new InjectSetupWrapper(providers); } -/** - * @deprecated {use async(inject())} - * - * Allows injecting dependencies in `beforeEach()` and `it()`. The test must return - * a promise which will resolve when all asynchronous activity is complete. - * - * Example: - * - * ``` - * it('...', injectAsync([AClass], (object) => { - * return object.doSomething().then(() => { - * expect(...); - * }); - * }) - * ``` - * - */ -export function injectAsync(tokens: any[], fn: Function): Function { - return async(inject(tokens, fn)); -} - // This is to ensure inject(Async) within InjectSetupWrapper doesn't call itself // when transpiled to Dart. var inject_impl = inject; -var injectAsync_impl = injectAsync; diff --git a/modules/@angular/core/testing/testing.ts b/modules/@angular/core/testing/testing.ts index 3159083f95..99864707b8 100644 --- a/modules/@angular/core/testing/testing.ts +++ b/modules/@angular/core/testing/testing.ts @@ -12,9 +12,7 @@ */ import {isPromise, isString} from '../src/facade/lang'; -import {TestInjector, async, getTestInjector, inject, injectAsync} from './test_injector'; - -export {async, inject, injectAsync} from './test_injector'; +import {TestInjector, getTestInjector} from './test_injector'; declare var global: any; @@ -79,6 +77,8 @@ var jsmIt = _global.it; var jsmIIt = _global.fit; var jsmXIt = _global.xit; +// TODO(juliemr): override the globals and make them throw with a useful message. + var testInjector: TestInjector = getTestInjector(); // Reset the test providers before each test. diff --git a/modules/@angular/core/testing/testing_internal.ts b/modules/@angular/core/testing/testing_internal.ts index 49948ba863..2a600bdd50 100644 --- a/modules/@angular/core/testing/testing_internal.ts +++ b/modules/@angular/core/testing/testing_internal.ts @@ -18,6 +18,9 @@ export {MockAnimationPlayer} from './animation/mock_animation_player'; export {AsyncTestCompleter} from './async_test_completer'; export {inject} from './test_injector'; export {expect} from './testing'; +export * from './logger'; +export * from './ng_zone_mock'; +export * from './mock_application_ref'; export var proxy: ClassDecorator = (t: any /** TODO #9100 */) => t; diff --git a/modules/@angular/examples/testing/ts/fake_async.ts b/modules/@angular/examples/testing/ts/fake_async.ts index fe856d8aae..14837fbbd6 100644 --- a/modules/@angular/examples/testing/ts/fake_async.ts +++ b/modules/@angular/examples/testing/ts/fake_async.ts @@ -6,7 +6,7 @@ * found in the LICENSE file at https://angular.io/license */ -import {clearPendingTimers, describe, expect, fakeAsync, it, tick} from '@angular/core/testing'; +import {describe, discardPeriodicTasks, expect, fakeAsync, it, tick} from '@angular/core/testing'; // #docregion basic @@ -25,14 +25,14 @@ describe('this test', () => { // #docregion pending describe('this test', () => { - it('aborts a timer', fakeAsync((): void => { + it('aborts a periodic timer', fakeAsync((): void => { // This timer is scheduled but doesn't need to complete for the // test to pass (maybe it's a timeout for some operation). // Leaving it will cause the test to fail... - setTimeout(() => {}, 100); + setInterval(() => {}, 100); // Unless we clean it up first. - clearPendingTimers(); + discardPeriodicTasks(); })); }); // #enddocregion diff --git a/modules/@angular/forms/test/directives_spec.ts b/modules/@angular/forms/test/directives_spec.ts index 5d70b81e6b..9219e3533e 100644 --- a/modules/@angular/forms/test/directives_spec.ts +++ b/modules/@angular/forms/test/directives_spec.ts @@ -6,9 +6,9 @@ * found in the LICENSE file at https://angular.io/license */ -import {afterEach, beforeEach, ddescribe, describe, expect, iit, inject, it, xit} from '@angular/core/testing/testing_internal'; +import {Log, afterEach, beforeEach, ddescribe, describe, expect, iit, inject, it, xit} from '@angular/core/testing/testing_internal'; -import {fakeAsync, flushMicrotasks, Log, tick,} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick,} from '@angular/core/testing'; import {SpyNgControl, SpyValueAccessor} from './spies'; diff --git a/modules/@angular/forms/test/model_spec.ts b/modules/@angular/forms/test/model_spec.ts index d5af3d67a8..d16d1ab8a7 100644 --- a/modules/@angular/forms/test/model_spec.ts +++ b/modules/@angular/forms/test/model_spec.ts @@ -6,13 +6,14 @@ * found in the LICENSE file at https://angular.io/license */ -import {ddescribe, describe, it, iit, xit, expect, beforeEach, afterEach, inject,} from '@angular/core/testing/testing_internal'; -import {fakeAsync, flushMicrotasks, Log, tick} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick} from '@angular/core/testing'; +import {afterEach, beforeEach, ddescribe, describe, expect, iit, inject, it, xit} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; -import {FormGroup, FormControl, FormArray, Validators} from '@angular/forms'; +import {FormArray, FormControl, FormGroup, Validators} from '@angular/forms'; + +import {EventEmitter, ObservableWrapper, TimerWrapper} from '../src/facade/async'; import {IS_DART, isPresent} from '../src/facade/lang'; import {PromiseWrapper} from '../src/facade/promise'; -import {TimerWrapper, ObservableWrapper, EventEmitter} from '../src/facade/async'; export function main() { function asyncValidator(expected: any /** TODO #9100 */, timeouts = /*@ts2dart_const*/ {}) { diff --git a/modules/@angular/forms/test/validators_spec.ts b/modules/@angular/forms/test/validators_spec.ts index e3c8e5d9b1..9b341b0ab6 100644 --- a/modules/@angular/forms/test/validators_spec.ts +++ b/modules/@angular/forms/test/validators_spec.ts @@ -6,7 +6,7 @@ * found in the LICENSE file at https://angular.io/license */ -import {Log, fakeAsync, flushMicrotasks, tick} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick} from '@angular/core/testing'; import {afterEach, beforeEach, ddescribe, describe, expect, iit, it, xit} from '@angular/core/testing/testing_internal'; import {AbstractControl, FormControl, Validators} from '@angular/forms'; diff --git a/modules/@angular/platform-browser-dynamic/test/testing_public_browser_spec.ts b/modules/@angular/platform-browser-dynamic/test/testing_public_browser_spec.ts index 4ed910afbe..5b1a38dc2f 100644 --- a/modules/@angular/platform-browser-dynamic/test/testing_public_browser_spec.ts +++ b/modules/@angular/platform-browser-dynamic/test/testing_public_browser_spec.ts @@ -7,7 +7,7 @@ */ import {it, iit, xit, describe, ddescribe, xdescribe, expect, beforeEach, beforeEachProviders, inject,} from '@angular/core/testing'; -import {async, fakeAsync, flushMicrotasks, Log, tick,} from '@angular/core/testing'; +import {async, fakeAsync, flushMicrotasks, tick,} from '@angular/core/testing'; import {ROUTER_DIRECTIVES, Route} from '@angular/router-deprecated'; diff --git a/modules/@angular/platform-browser-dynamic/test/xhr/xhr_cache_spec.ts b/modules/@angular/platform-browser-dynamic/test/xhr/xhr_cache_spec.ts index 28fb326d4b..e791ed07be 100644 --- a/modules/@angular/platform-browser-dynamic/test/xhr/xhr_cache_spec.ts +++ b/modules/@angular/platform-browser-dynamic/test/xhr/xhr_cache_spec.ts @@ -11,7 +11,7 @@ import {Component, provide} from '@angular/core'; import {beforeEach, beforeEachProviders, ddescribe, describe, iit, inject, it, xit} from '@angular/core/testing/testing_internal'; import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; -import {fakeAsync, flushMicrotasks, Log, tick,} from '@angular/core/testing'; +import {fakeAsync, flushMicrotasks, tick,} from '@angular/core/testing'; import {TestComponentBuilder, ComponentFixture} from '@angular/compiler/testing'; import {expect} from '@angular/platform-browser/testing/matchers'; import {BaseException} from '../../src/facade/exceptions'; diff --git a/modules/@angular/platform-browser/test/browser/bootstrap_spec.ts b/modules/@angular/platform-browser/test/browser/bootstrap_spec.ts index 29a12d7864..59cce51848 100644 --- a/modules/@angular/platform-browser/test/browser/bootstrap_spec.ts +++ b/modules/@angular/platform-browser/test/browser/bootstrap_spec.ts @@ -11,8 +11,7 @@ import {ApplicationRef, disposePlatform} from '@angular/core/src/application_ref import {Console} from '@angular/core/src/console'; import {ComponentRef} from '@angular/core/src/linker/component_factory'; import {Testability, TestabilityRegistry} from '@angular/core/src/testability/testability'; -import {Log} from '@angular/core/testing'; -import {AsyncTestCompleter, afterEach, beforeEach, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; +import {AsyncTestCompleter, Log, afterEach, beforeEach, beforeEachProviders, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; import {BROWSER_APP_PROVIDERS, BROWSER_PLATFORM_PROVIDERS} from '@angular/platform-browser'; import {BROWSER_APP_COMPILER_PROVIDERS, bootstrap} from '@angular/platform-browser-dynamic'; import {getDOM} from '@angular/platform-browser/src/dom/dom_adapter'; @@ -89,6 +88,8 @@ export function main() { testProviders: any /** TODO #9100 */, lightDom: any /** TODO #9100 */; describe('bootstrap factory method', () => { + beforeEachProviders(() => { return [Log]; }); + beforeEach(() => { disposePlatform(); diff --git a/modules/@angular/platform-browser/test/web_workers/shared/message_bus_spec.ts b/modules/@angular/platform-browser/test/web_workers/shared/message_bus_spec.ts index fd93b6b677..275046c793 100644 --- a/modules/@angular/platform-browser/test/web_workers/shared/message_bus_spec.ts +++ b/modules/@angular/platform-browser/test/web_workers/shared/message_bus_spec.ts @@ -6,14 +6,15 @@ * found in the LICENSE file at https://angular.io/license */ -import {inject, describe, it, expect, beforeEach, beforeEachProviders,} from '@angular/core/testing/testing_internal'; -import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; -import {ObservableWrapper, TimerWrapper} from '../../../src/facade/async'; -import {MessageBus} from '@angular/platform-browser/src/web_workers/shared/message_bus'; -import {createConnectedMessageBus} from './message_bus_util'; -import {MockNgZone} from '@angular/core/testing'; -import {provide, NgZone} from '@angular/core'; +import {NgZone, provide} from '@angular/core'; import {withProviders} from '@angular/core/testing/test_injector'; +import {MockNgZone, beforeEach, beforeEachProviders, describe, expect, inject, it} from '@angular/core/testing/testing_internal'; +import {AsyncTestCompleter} from '@angular/core/testing/testing_internal'; +import {MessageBus} from '@angular/platform-browser/src/web_workers/shared/message_bus'; + +import {ObservableWrapper, TimerWrapper} from '../../../src/facade/async'; + +import {createConnectedMessageBus} from './message_bus_util'; export function main() { /** diff --git a/modules/@angular/platform-browser/testing/browser.ts b/modules/@angular/platform-browser/testing/browser.ts index 518d171846..3de89f9373 100644 --- a/modules/@angular/platform-browser/testing/browser.ts +++ b/modules/@angular/platform-browser/testing/browser.ts @@ -9,7 +9,6 @@ import {LocationStrategy} from '@angular/common'; import {MockLocationStrategy} from '@angular/common/testing'; import {APP_ID, NgZone, PLATFORM_COMMON_PROVIDERS, PLATFORM_INITIALIZER} from '@angular/core'; -import {Log} from '@angular/core/testing'; import {AnimationDriver, NoOpAnimationDriver} from '../core_private'; import {BROWSER_APP_PROVIDERS} from '../src/browser'; @@ -28,7 +27,7 @@ const TEST_BROWSER_STATIC_PLATFORM_PROVIDERS: Array = [ - {provide: APP_ID, useValue: 'a'}, ELEMENT_PROBE_PROVIDERS, Log, + {provide: APP_ID, useValue: 'a'}, ELEMENT_PROBE_PROVIDERS, {provide: NgZone, useFactory: createNgZone}, {provide: LocationStrategy, useClass: MockLocationStrategy}, {provide: AnimationDriver, useClass: NoOpAnimationDriver} diff --git a/modules/@angular/platform-server/testing/server.ts b/modules/@angular/platform-server/testing/server.ts index 26171d5f51..319940ce27 100644 --- a/modules/@angular/platform-server/testing/server.ts +++ b/modules/@angular/platform-server/testing/server.ts @@ -18,7 +18,6 @@ import {Parse5DomAdapter} from '../src/parse5_adapter'; import {DOCUMENT, BROWSER_SANITIZATION_PROVIDERS, EventManager, EVENT_MANAGER_PLUGINS, ELEMENT_PROBE_PROVIDERS, DomEventsPlugin,} from '@angular/platform-browser'; import {getDOM, DomRootRenderer, DomRootRenderer_, DomSharedStylesHost, SharedStylesHost} from '../platform_browser_private'; import {LocationStrategy} from '@angular/common'; -import {Log} from '@angular/core/testing'; function initServerTests() { Parse5DomAdapter.makeCurrent(); @@ -74,7 +73,7 @@ export const TEST_SERVER_APPLICATION_PROVIDERS: Array Array): void; -export declare function clearPendingTimers(): void; - export declare var ddescribe: Function; export declare var describe: Function; @@ -26,54 +24,17 @@ export declare function flushMicrotasks(): void; export declare function getTestInjector(): TestInjector; -export declare function getTypeOf(instance: any): any; - export declare function iit(name: string, fn: Function, timeOut?: number): void; export declare function inject(tokens: any[], fn: Function): Function; -export declare function injectAsync(tokens: any[], fn: Function): Function; - export declare class InjectSetupWrapper { constructor(_providers: () => any); inject(tokens: any[], fn: Function): Function; - injectAsync(tokens: any[], fn: Function): Function; } -export declare function instantiateType(type: Function, params?: any[]): any; - export declare function it(name: string, fn: Function, timeOut?: number): void; -export declare class Log { - logItems: any[]; - constructor(); - add(value: any): void; - fn(value: any): (a1?: any, a2?: any, a3?: any, a4?: any, a5?: any) => void; - clear(): void; - result(): string; -} - -export declare class MockApplicationRef extends ApplicationRef { - registerBootstrapListener(listener: (ref: ComponentRef) => void): void; - registerDisposeListener(dispose: () => void): void; - bootstrap(componentFactory: ComponentFactory): ComponentRef; - injector: Injector; - zone: NgZone; - run(callback: Function): any; - waitForAsyncInitializers(): Promise; - dispose(): void; - tick(): void; - componentTypes: Type[]; -} - -export declare class MockNgZone extends NgZone { - constructor(); - onStable: EventEmitter; - run(fn: Function): any; - runOutsideAngular(fn: Function): any; - simulateZoneExit(): void; -} - export declare function resetBaseTestProviders(): void; export declare function setBaseTestProviders(platformProviders: Array, applicationProviders: Array): void;