refactor(ivy): cleanup the public API for core/testing (#25492)

PR Close #25492
This commit is contained in:
Victor Berchet 2018-08-14 16:27:04 -07:00 committed by Ben Lesh
parent 01ec5fd6b0
commit 1f1103913a
7 changed files with 260 additions and 191 deletions

View File

@ -229,13 +229,7 @@ describe('@angular/core ng_package', () => {
expect(shx.cat('testing.metadata.json')) expect(shx.cat('testing.metadata.json'))
.toContain(`"exports":[{"from":"./testing/testing"}],"flatModuleIndexRedirect":true`); .toContain(`"exports":[{"from":"./testing/testing"}],"flatModuleIndexRedirect":true`);
}); });
it('should have an \'actual\' metadata.json file', () => {
expect(shx.cat('testing/testing.metadata.json'))
.toContain(`"metadata":{"async":{"__symbolic":"function"},`);
}); });
});
describe('fesm2015', () => { describe('fesm2015', () => {
it('should have a fesm15 file in the /fesm2015 directory', it('should have a fesm15 file in the /fesm2015 directory',

View File

@ -11,7 +11,8 @@ import {Component, Directive, Injector, NgModule, Pipe, PlatformRef, Provider, R
import {ComponentFixture} from './component_fixture'; import {ComponentFixture} from './component_fixture';
import {MetadataOverride} from './metadata_override'; import {MetadataOverride} from './metadata_override';
import {ComponentResolver, DirectiveResolver, NgModuleResolver, PipeResolver, Resolver} from './resolvers'; import {ComponentResolver, DirectiveResolver, NgModuleResolver, PipeResolver, Resolver} from './resolvers';
import {ComponentFixtureAutoDetect, TestComponentRenderer, TestModuleMetadata} from './test_bed_common'; import {TestBed} from './test_bed';
import {ComponentFixtureAutoDetect, TestBedStatic, TestComponentRenderer, TestModuleMetadata} from './test_bed_common';
let _nextRootElementId = 0; let _nextRootElementId = 0;
@ -25,7 +26,7 @@ let _nextRootElementId = 0;
* Note: Use `TestBed` in tests. It will be set to either `TestBedViewEngine` or `TestBedRender3` * Note: Use `TestBed` in tests. It will be set to either `TestBedViewEngine` or `TestBedRender3`
* according to the compiler used. * according to the compiler used.
*/ */
export class TestBedRender3 { export class TestBedRender3 implements Injector, TestBed {
/** /**
* Initialize the environment for testing with a compiler factory, a PlatformRef, and an * Initialize the environment for testing with a compiler factory, a PlatformRef, and an
* angular module. These are common to every test in the suite. * angular module. These are common to every test in the suite.
@ -40,8 +41,7 @@ export class TestBedRender3 {
* @experimental * @experimental
*/ */
static initTestEnvironment( static initTestEnvironment(
ngModule: Type<any>|Type<any>[], platform: PlatformRef, ngModule: Type<any>|Type<any>[], platform: PlatformRef, aotSummaries?: () => any[]): TestBed {
aotSummaries?: () => any[]): TestBedRender3 {
const testBed = _getTestBedRender3(); const testBed = _getTestBedRender3();
testBed.initTestEnvironment(ngModule, platform, aotSummaries); testBed.initTestEnvironment(ngModule, platform, aotSummaries);
return testBed; return testBed;
@ -54,18 +54,18 @@ export class TestBedRender3 {
*/ */
static resetTestEnvironment(): void { _getTestBedRender3().resetTestEnvironment(); } static resetTestEnvironment(): void { _getTestBedRender3().resetTestEnvironment(); }
static configureCompiler(config: {providers?: any[]; useJit?: boolean;}): typeof TestBedRender3 { static configureCompiler(config: {providers?: any[]; useJit?: boolean;}): TestBedStatic {
_getTestBedRender3().configureCompiler(config); _getTestBedRender3().configureCompiler(config);
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
/** /**
* Allows overriding default providers, directives, pipes, modules of the test injector, * Allows overriding default providers, directives, pipes, modules of the test injector,
* which are defined in test_injector.js * which are defined in test_injector.js
*/ */
static configureTestingModule(moduleDef: TestModuleMetadata): typeof TestBedRender3 { static configureTestingModule(moduleDef: TestModuleMetadata): TestBedStatic {
_getTestBedRender3().configureTestingModule(moduleDef); _getTestBedRender3().configureTestingModule(moduleDef);
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
/** /**
@ -75,32 +75,31 @@ export class TestBedRender3 {
*/ */
static compileComponents(): Promise<any> { return _getTestBedRender3().compileComponents(); } static compileComponents(): Promise<any> { return _getTestBedRender3().compileComponents(); }
static overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): static overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): TestBedStatic {
typeof TestBedRender3 {
_getTestBedRender3().overrideModule(ngModule, override); _getTestBedRender3().overrideModule(ngModule, override);
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
static overrideComponent(component: Type<any>, override: MetadataOverride<Component>): static overrideComponent(component: Type<any>, override: MetadataOverride<Component>):
typeof TestBedRender3 { TestBedStatic {
_getTestBedRender3().overrideComponent(component, override); _getTestBedRender3().overrideComponent(component, override);
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
static overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): static overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>):
typeof TestBedRender3 { TestBedStatic {
_getTestBedRender3().overrideDirective(directive, override); _getTestBedRender3().overrideDirective(directive, override);
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
static overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): typeof TestBedRender3 { static overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): TestBedStatic {
_getTestBedRender3().overridePipe(pipe, override); _getTestBedRender3().overridePipe(pipe, override);
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
static overrideTemplate(component: Type<any>, template: string): typeof TestBedRender3 { static overrideTemplate(component: Type<any>, template: string): TestBedStatic {
_getTestBedRender3().overrideComponent(component, {set: {template, templateUrl: null !}}); _getTestBedRender3().overrideComponent(component, {set: {template, templateUrl: null !}});
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
/** /**
@ -109,10 +108,9 @@ export class TestBedRender3 {
* *
* Note: This works for JIT and AOTed components as well. * Note: This works for JIT and AOTed components as well.
*/ */
static overrideTemplateUsingTestingModule(component: Type<any>, template: string): static overrideTemplateUsingTestingModule(component: Type<any>, template: string): TestBedStatic {
typeof TestBedRender3 {
_getTestBedRender3().overrideTemplateUsingTestingModule(component, template); _getTestBedRender3().overrideTemplateUsingTestingModule(component, template);
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
overrideTemplateUsingTestingModule(component: Type<any>, template: string): void { overrideTemplateUsingTestingModule(component: Type<any>, template: string): void {
@ -122,15 +120,15 @@ export class TestBedRender3 {
static overrideProvider(token: any, provider: { static overrideProvider(token: any, provider: {
useFactory: Function, useFactory: Function,
deps: any[], deps: any[],
}): typeof TestBedRender3; }): TestBedStatic;
static overrideProvider(token: any, provider: {useValue: any;}): typeof TestBedRender3; static overrideProvider(token: any, provider: {useValue: any;}): TestBedStatic;
static overrideProvider(token: any, provider: { static overrideProvider(token: any, provider: {
useFactory?: Function, useFactory?: Function,
useValue?: any, useValue?: any,
deps?: any[], deps?: any[],
}): typeof TestBedRender3 { }): TestBedStatic {
_getTestBedRender3().overrideProvider(token, provider); _getTestBedRender3().overrideProvider(token, provider);
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
/** /**
@ -147,7 +145,7 @@ export class TestBedRender3 {
useFactory?: Function, useFactory?: Function,
useValue?: any, useValue?: any,
deps?: any[], deps?: any[],
}): typeof TestBedRender3 { }): TestBedStatic {
throw new Error('Render3TestBed.deprecatedOverrideProvider is not implemented'); throw new Error('Render3TestBed.deprecatedOverrideProvider is not implemented');
} }
@ -159,9 +157,9 @@ export class TestBedRender3 {
return _getTestBedRender3().createComponent(component); return _getTestBedRender3().createComponent(component);
} }
static resetTestingModule(): typeof TestBedRender3 { static resetTestingModule(): TestBedStatic {
_getTestBedRender3().resetTestingModule(); _getTestBedRender3().resetTestingModule();
return TestBedRender3; return TestBedRender3 as any as TestBedStatic;
} }
// Properties // Properties

View File

@ -12,7 +12,7 @@ import {AsyncTestCompleter} from './async_test_completer';
import {ComponentFixture} from './component_fixture'; import {ComponentFixture} from './component_fixture';
import {MetadataOverride} from './metadata_override'; import {MetadataOverride} from './metadata_override';
import {TestBedRender3, _getTestBedRender3} from './r3_test_bed'; import {TestBedRender3, _getTestBedRender3} from './r3_test_bed';
import {ComponentFixtureAutoDetect, ComponentFixtureNoNgZone, TestComponentRenderer, TestModuleMetadata} from './test_bed_common'; import {ComponentFixtureAutoDetect, ComponentFixtureNoNgZone, TestBedStatic, TestComponentRenderer, TestModuleMetadata} from './test_bed_common';
import {TestingCompiler, TestingCompilerFactory} from './test_compiler'; import {TestingCompiler, TestingCompilerFactory} from './test_compiler';
const UNDEFINED = new Object(); const UNDEFINED = new Object();
@ -20,6 +20,84 @@ const UNDEFINED = new Object();
let _nextRootElementId = 0; let _nextRootElementId = 0;
export interface TestBed {
platform: PlatformRef;
ngModule: Type<any>|Type<any>[];
/**
* Initialize the environment for testing with a compiler factory, a PlatformRef, and an
* angular module. These are common to every test in the suite.
*
* This may only be called once, to set up the common providers for the current test
* suite on the current platform. If you absolutely need to change the providers,
* first use `resetTestEnvironment`.
*
* Test modules and platforms for individual platforms are available from
* '@angular/<platform_name>/testing'.
*
* @experimental
*/
initTestEnvironment(
ngModule: Type<any>|Type<any>[], platform: PlatformRef, aotSummaries?: () => any[]): void;
/**
* Reset the providers for the test injector.
*
* @experimental
*/
resetTestEnvironment(): void;
resetTestingModule(): void;
configureCompiler(config: {providers?: any[], useJit?: boolean}): void;
configureTestingModule(moduleDef: TestModuleMetadata): void;
compileComponents(): Promise<any>;
get(token: any, notFoundValue?: any): any;
execute(tokens: any[], fn: Function, context?: any): any;
overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): void;
overrideComponent(component: Type<any>, override: MetadataOverride<Component>): void;
overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): void;
overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): void;
/**
* Overwrites all providers for the given token with the given provider definition.
*/
overrideProvider(token: any, provider: {
useFactory: Function,
deps: any[],
}): void;
overrideProvider(token: any, provider: {useValue: any;}): void;
overrideProvider(token: any, provider: {useFactory?: Function, useValue?: any, deps?: any[]}):
void;
/**
* Overwrites all providers for the given token with the given provider definition.
*
* @deprecated as it makes all NgModules lazy. Introduced only for migrating off of it.
*/
deprecatedOverrideProvider(token: any, provider: {
useFactory: Function,
deps: any[],
}): void;
deprecatedOverrideProvider(token: any, provider: {useValue: any;}): void;
deprecatedOverrideProvider(
token: any, provider: {useFactory?: Function, useValue?: any, deps?: any[]}): void;
overrideTemplateUsingTestingModule(component: Type<any>, template: string): void;
createComponent<T>(component: Type<T>): ComponentFixture<T>;
}
/** /**
* @description * @description
* Configures and initializes environment for unit testing and provides methods for * Configures and initializes environment for unit testing and provides methods for
@ -30,7 +108,7 @@ let _nextRootElementId = 0;
* Note: Use `TestBed` in tests. It will be set to either `TestBedViewEngine` or `TestBedRender3` * Note: Use `TestBed` in tests. It will be set to either `TestBedViewEngine` or `TestBedRender3`
* according to the compiler used. * according to the compiler used.
*/ */
export class TestBedViewEngine implements Injector { export class TestBedViewEngine implements Injector, TestBed {
/** /**
* Initialize the environment for testing with a compiler factory, a PlatformRef, and an * Initialize the environment for testing with a compiler factory, a PlatformRef, and an
* angular module. These are common to every test in the suite. * angular module. These are common to every test in the suite.
@ -59,27 +137,27 @@ export class TestBedViewEngine implements Injector {
*/ */
static resetTestEnvironment(): void { _getTestBedViewEngine().resetTestEnvironment(); } static resetTestEnvironment(): void { _getTestBedViewEngine().resetTestEnvironment(); }
static resetTestingModule(): typeof TestBed { static resetTestingModule(): TestBedStatic {
_getTestBedViewEngine().resetTestingModule(); _getTestBedViewEngine().resetTestingModule();
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
/** /**
* Allows overriding default compiler providers and settings * Allows overriding default compiler providers and settings
* which are defined in test_injector.js * which are defined in test_injector.js
*/ */
static configureCompiler(config: {providers?: any[]; useJit?: boolean;}): typeof TestBed { static configureCompiler(config: {providers?: any[]; useJit?: boolean;}): TestBedStatic {
_getTestBedViewEngine().configureCompiler(config); _getTestBedViewEngine().configureCompiler(config);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
/** /**
* Allows overriding default providers, directives, pipes, modules of the test injector, * Allows overriding default providers, directives, pipes, modules of the test injector,
* which are defined in test_injector.js * which are defined in test_injector.js
*/ */
static configureTestingModule(moduleDef: TestModuleMetadata): typeof TestBed { static configureTestingModule(moduleDef: TestModuleMetadata): TestBedStatic {
_getTestBedViewEngine().configureTestingModule(moduleDef); _getTestBedViewEngine().configureTestingModule(moduleDef);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
/** /**
@ -89,31 +167,31 @@ export class TestBedViewEngine implements Injector {
*/ */
static compileComponents(): Promise<any> { return getTestBed().compileComponents(); } static compileComponents(): Promise<any> { return getTestBed().compileComponents(); }
static overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): typeof TestBed { static overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): TestBedStatic {
_getTestBedViewEngine().overrideModule(ngModule, override); _getTestBedViewEngine().overrideModule(ngModule, override);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
static overrideComponent(component: Type<any>, override: MetadataOverride<Component>): static overrideComponent(component: Type<any>, override: MetadataOverride<Component>):
typeof TestBed { TestBedStatic {
_getTestBedViewEngine().overrideComponent(component, override); _getTestBedViewEngine().overrideComponent(component, override);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
static overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): static overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>):
typeof TestBed { TestBedStatic {
_getTestBedViewEngine().overrideDirective(directive, override); _getTestBedViewEngine().overrideDirective(directive, override);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
static overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): typeof TestBed { static overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): TestBedStatic {
_getTestBedViewEngine().overridePipe(pipe, override); _getTestBedViewEngine().overridePipe(pipe, override);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
static overrideTemplate(component: Type<any>, template: string): typeof TestBed { static overrideTemplate(component: Type<any>, template: string): TestBedStatic {
_getTestBedViewEngine().overrideComponent(component, {set: {template, templateUrl: null !}}); _getTestBedViewEngine().overrideComponent(component, {set: {template, templateUrl: null !}});
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
/** /**
@ -122,10 +200,9 @@ export class TestBedViewEngine implements Injector {
* *
* Note: This works for JIT and AOTed components as well. * Note: This works for JIT and AOTed components as well.
*/ */
static overrideTemplateUsingTestingModule(component: Type<any>, template: string): static overrideTemplateUsingTestingModule(component: Type<any>, template: string): TestBedStatic {
typeof TestBed {
_getTestBedViewEngine().overrideTemplateUsingTestingModule(component, template); _getTestBedViewEngine().overrideTemplateUsingTestingModule(component, template);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
/** /**
@ -136,15 +213,15 @@ export class TestBedViewEngine implements Injector {
static overrideProvider(token: any, provider: { static overrideProvider(token: any, provider: {
useFactory: Function, useFactory: Function,
deps: any[], deps: any[],
}): typeof TestBed; }): TestBedStatic;
static overrideProvider(token: any, provider: {useValue: any;}): typeof TestBed; static overrideProvider(token: any, provider: {useValue: any;}): TestBedStatic;
static overrideProvider(token: any, provider: { static overrideProvider(token: any, provider: {
useFactory?: Function, useFactory?: Function,
useValue?: any, useValue?: any,
deps?: any[], deps?: any[],
}): typeof TestBed { }): TestBedStatic {
_getTestBedViewEngine().overrideProvider(token, provider as any); _getTestBedViewEngine().overrideProvider(token, provider as any);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
/** /**
@ -161,9 +238,9 @@ export class TestBedViewEngine implements Injector {
useFactory?: Function, useFactory?: Function,
useValue?: any, useValue?: any,
deps?: any[], deps?: any[],
}): typeof TestBed { }): TestBedStatic {
_getTestBedViewEngine().deprecatedOverrideProvider(token, provider as any); _getTestBedViewEngine().deprecatedOverrideProvider(token, provider as any);
return TestBed; return TestBedViewEngine as any as TestBedStatic;
} }
static get(token: any, notFoundValue: any = Injector.THROW_IF_NOT_FOUND) { static get(token: any, notFoundValue: any = Injector.THROW_IF_NOT_FOUND) {
@ -559,7 +636,8 @@ export class TestBedViewEngine implements Injector {
* Note: Use `TestBed` in tests. It will be set to either `TestBedViewEngine` or `TestBedRender3` * Note: Use `TestBed` in tests. It will be set to either `TestBedViewEngine` or `TestBedRender3`
* according to the compiler used. * according to the compiler used.
*/ */
export const TestBed = ivyEnabled ? TestBedRender3 : TestBedViewEngine; export const TestBed: TestBedStatic =
ivyEnabled ? TestBedRender3 as any as TestBedStatic : TestBedViewEngine as any as TestBedStatic;
/** /**
* Returns a singleton of the applicable `TestBed`. * Returns a singleton of the applicable `TestBed`.
@ -568,8 +646,7 @@ export const TestBed = ivyEnabled ? TestBedRender3 : TestBedViewEngine;
* *
* @experimental * @experimental
*/ */
export const getTestBed: () => TestBedRender3 | TestBedViewEngine = export const getTestBed: () => TestBed = ivyEnabled ? _getTestBedRender3 : _getTestBedViewEngine;
ivyEnabled ? _getTestBedRender3 : _getTestBedViewEngine;
let testBed: TestBedViewEngine; let testBed: TestBedViewEngine;

View File

@ -6,7 +6,11 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {InjectionToken, SchemaMetadata} from '@angular/core'; import {Component, Directive, InjectionToken, NgModule, Pipe, PlatformRef, SchemaMetadata, Type} from '@angular/core';
import {ComponentFixture} from './component_fixture';
import {MetadataOverride} from './metadata_override';
import {TestBed} from './test_bed';
/** /**
* An abstract class for inserting the root test component element in a platform independent way. * An abstract class for inserting the root test component element in a platform independent way.
@ -38,3 +42,95 @@ export type TestModuleMetadata = {
schemas?: Array<SchemaMetadata|any[]>, schemas?: Array<SchemaMetadata|any[]>,
aotSummaries?: () => any[], aotSummaries?: () => any[],
}; };
/**
* Static methods implemented by the `TestBedViewEngine` and `TestBedRender3`
*/
export interface TestBedStatic {
new (...args: any[]): TestBed;
initTestEnvironment(
ngModule: Type<any>|Type<any>[], platform: PlatformRef, aotSummaries?: () => any[]): TestBed;
/**
* Reset the providers for the test injector.
*
* @experimental
*/
resetTestEnvironment(): void;
resetTestingModule(): TestBedStatic;
/**
* Allows overriding default compiler providers and settings
* which are defined in test_injector.js
*/
configureCompiler(config: {providers?: any[]; useJit?: boolean;}): TestBedStatic;
/**
* Allows overriding default providers, directives, pipes, modules of the test injector,
* which are defined in test_injector.js
*/
configureTestingModule(moduleDef: TestModuleMetadata): TestBedStatic;
/**
* Compile components with a `templateUrl` for the test's NgModule.
* It is necessary to call this function
* as fetching urls is asynchronous.
*/
compileComponents(): Promise<any>;
overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): TestBedStatic;
overrideComponent(component: Type<any>, override: MetadataOverride<Component>): TestBedStatic;
overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): TestBedStatic;
overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): TestBedStatic;
overrideTemplate(component: Type<any>, template: string): TestBedStatic;
/**
* Overrides the template of the given component, compiling the template
* in the context of the TestingModule.
*
* Note: This works for JIT and AOTed components as well.
*/
overrideTemplateUsingTestingModule(component: Type<any>, template: string): TestBedStatic;
/**
* Overwrites all providers for the given token with the given provider definition.
*
* Note: This works for JIT and AOTed components as well.
*/
overrideProvider(token: any, provider: {
useFactory: Function,
deps: any[],
}): TestBedStatic;
overrideProvider(token: any, provider: {useValue: any;}): TestBedStatic;
overrideProvider(token: any, provider: {
useFactory?: Function,
useValue?: any,
deps?: any[],
}): TestBedStatic;
/**
* Overwrites all providers for the given token with the given provider definition.
*
* @deprecated as it makes all NgModules lazy. Introduced only for migrating off of it.
*/
deprecatedOverrideProvider(token: any, provider: {
useFactory: Function,
deps: any[],
}): void;
deprecatedOverrideProvider(token: any, provider: {useValue: any;}): void;
deprecatedOverrideProvider(token: any, provider: {
useFactory?: Function,
useValue?: any,
deps?: any[],
}): TestBedStatic;
get(token: any, notFoundValue?: any): any;
createComponent<T>(component: Type<T>): ComponentFixture<T>;
}

View File

@ -15,10 +15,9 @@
export * from './async'; export * from './async';
export * from './component_fixture'; export * from './component_fixture';
export * from './fake_async'; export * from './fake_async';
export * from './test_bed'; export {TestBed, getTestBed, inject, InjectSetupWrapper, withModule} from './test_bed';
export * from './test_bed_common'; export * from './test_bed_common';
export * from './r3_test_bed';
export * from './before_each'; export * from './before_each';
export * from './metadata_override'; export * from './metadata_override';
export * from './metadata_overrider'; export {MetadataOverrider as ɵMetadataOverrider} from './metadata_overrider';
export * from './private_export_testing'; export * from './private_export_testing';

View File

@ -6,5 +6,5 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
// `MetadataOverrider` has been moved to core to allow using it from the render3 TestBed // `MetadataOverrider` has been moved to core/testing to allow using it from the render3 TestBed
export {MetadataOverrider} from '@angular/core/testing'; export {ɵMetadataOverrider as MetadataOverrider} from '@angular/core/testing';

View File

@ -1,5 +1,3 @@
export declare function _getTestBedRender3(): TestBedRender3;
export declare function async(fn: Function): (done: any) => any; export declare function async(fn: Function): (done: any) => any;
export declare class ComponentFixture<T> { export declare class ComponentFixture<T> {
@ -39,7 +37,7 @@ export declare function flush(maxTurns?: number): number;
export declare function flushMicrotasks(): void; export declare function flushMicrotasks(): void;
/** @experimental */ /** @experimental */
export declare const getTestBed: () => TestBedRender3 | TestBedViewEngine; export declare const getTestBed: () => TestBed;
export declare function inject(tokens: any[], fn: Function): () => any; export declare function inject(tokens: any[], fn: Function): () => any;
@ -56,27 +54,25 @@ export declare type MetadataOverride<T> = {
set?: Partial<T>; set?: Partial<T>;
}; };
export declare class MetadataOverrider {
overrideMetadata<C extends T, T>(metadataClass: {
new (options: T): C;
}, oldMetadata: C, override: MetadataOverride<T>): C;
}
/** @experimental */ /** @experimental */
export declare function resetFakeAsyncZone(): void; export declare function resetFakeAsyncZone(): void;
export declare const TestBed: typeof TestBedRender3 | typeof TestBedViewEngine; export declare const TestBed: TestBedStatic;
export declare class TestBedRender3 { export interface TestBedStatic {
ngModule: Type<any> | Type<any>[]; new (...args: any[]): TestBed;
platform: PlatformRef;
compileComponents(): Promise<any>; compileComponents(): Promise<any>;
configureCompiler(config: { configureCompiler(config: {
providers?: any[]; providers?: any[];
useJit?: boolean; useJit?: boolean;
}): void; }): TestBedStatic;
configureTestingModule(moduleDef: TestModuleMetadata): void; configureTestingModule(moduleDef: TestModuleMetadata): TestBedStatic;
createComponent<T>(type: Type<T>): ComponentFixture<T>; createComponent<T>(component: Type<T>): ComponentFixture<T>;
deprecatedOverrideProvider(token: any, provider: {
useFactory?: Function;
useValue?: any;
deps?: any[];
}): TestBedStatic;
deprecatedOverrideProvider(token: any, provider: { deprecatedOverrideProvider(token: any, provider: {
useValue: any; useValue: any;
}): void; }): void;
@ -84,119 +80,28 @@ export declare class TestBedRender3 {
useFactory: Function; useFactory: Function;
deps: any[]; deps: any[];
}): void; }): void;
execute(tokens: any[], fn: Function, context?: any): any;
get(token: any, notFoundValue?: any): any; get(token: any, notFoundValue?: any): any;
/** @experimental */ initTestEnvironment(ngModule: Type<any> | Type<any>[], platform: PlatformRef, aotSummaries?: () => any[]): void; initTestEnvironment(ngModule: Type<any> | Type<any>[], platform: PlatformRef, aotSummaries?: () => any[]): TestBed;
overrideComponent(component: Type<any>, override: MetadataOverride<Component>): void; overrideComponent(component: Type<any>, override: MetadataOverride<Component>): TestBedStatic;
overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): void; overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): TestBedStatic;
overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): void; overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): TestBedStatic;
overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): void; overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): TestBedStatic;
overrideProvider(token: any, provider: {
useValue: any;
}): TestBedStatic;
overrideProvider(token: any, provider: { overrideProvider(token: any, provider: {
useFactory?: Function; useFactory?: Function;
useValue?: any; useValue?: any;
deps?: any[]; deps?: any[];
}): void; }): TestBedStatic;
overrideTemplateUsingTestingModule(component: Type<any>, template: string): void;
/** @experimental */ resetTestEnvironment(): void;
resetTestingModule(): void;
static compileComponents(): Promise<any>;
static configureCompiler(config: {
providers?: any[];
useJit?: boolean;
}): typeof TestBedRender3;
static configureTestingModule(moduleDef: TestModuleMetadata): typeof TestBedRender3;
static createComponent<T>(component: Type<T>): ComponentFixture<T>;
static deprecatedOverrideProvider(token: any, provider: {
useValue: any;
}): void;
/** @deprecated */ static deprecatedOverrideProvider(token: any, provider: {
useFactory: Function;
deps: any[];
}): void;
static get(token: any, notFoundValue?: any): any;
/** @experimental */ static initTestEnvironment(ngModule: Type<any> | Type<any>[], platform: PlatformRef, aotSummaries?: () => any[]): TestBedRender3;
static overrideComponent(component: Type<any>, override: MetadataOverride<Component>): typeof TestBedRender3;
static overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): typeof TestBedRender3;
static overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): typeof TestBedRender3;
static overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): typeof TestBedRender3;
static overrideProvider(token: any, provider: {
useFactory: Function;
deps: any[];
}): typeof TestBedRender3;
static overrideProvider(token: any, provider: {
useValue: any;
}): typeof TestBedRender3;
static overrideTemplate(component: Type<any>, template: string): typeof TestBedRender3;
static overrideTemplateUsingTestingModule(component: Type<any>, template: string): typeof TestBedRender3;
/** @experimental */ static resetTestEnvironment(): void;
static resetTestingModule(): typeof TestBedRender3;
}
export declare class TestBedViewEngine implements Injector {
ngModule: Type<any> | Type<any>[];
platform: PlatformRef;
compileComponents(): Promise<any>;
configureCompiler(config: {
providers?: any[];
useJit?: boolean;
}): void;
configureTestingModule(moduleDef: TestModuleMetadata): void;
createComponent<T>(component: Type<T>): ComponentFixture<T>;
/** @deprecated */ deprecatedOverrideProvider(token: any, provider: {
useFactory: Function;
deps: any[];
}): void;
deprecatedOverrideProvider(token: any, provider: {
useValue: any;
}): void;
execute(tokens: any[], fn: Function, context?: any): any;
get(token: any, notFoundValue?: any): any;
/** @experimental */ initTestEnvironment(ngModule: Type<any> | Type<any>[], platform: PlatformRef, aotSummaries?: () => any[]): void;
overrideComponent(component: Type<any>, override: MetadataOverride<Component>): void;
overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): void;
overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): void;
overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): void;
overrideProvider(token: any, provider: { overrideProvider(token: any, provider: {
useFactory: Function; useFactory: Function;
deps: any[]; deps: any[];
}): void; }): TestBedStatic;
overrideProvider(token: any, provider: { overrideTemplate(component: Type<any>, template: string): TestBedStatic;
useValue: any; overrideTemplateUsingTestingModule(component: Type<any>, template: string): TestBedStatic;
}): void;
overrideTemplateUsingTestingModule(component: Type<any>, template: string): void;
/** @experimental */ resetTestEnvironment(): void; /** @experimental */ resetTestEnvironment(): void;
resetTestingModule(): void; resetTestingModule(): TestBedStatic;
static compileComponents(): Promise<any>;
static configureCompiler(config: {
providers?: any[];
useJit?: boolean;
}): typeof TestBed;
static configureTestingModule(moduleDef: TestModuleMetadata): typeof TestBed;
static createComponent<T>(component: Type<T>): ComponentFixture<T>;
static deprecatedOverrideProvider(token: any, provider: {
useValue: any;
}): void;
/** @deprecated */ static deprecatedOverrideProvider(token: any, provider: {
useFactory: Function;
deps: any[];
}): void;
static get(token: any, notFoundValue?: any): any;
/** @experimental */ static initTestEnvironment(ngModule: Type<any> | Type<any>[], platform: PlatformRef, aotSummaries?: () => any[]): TestBedViewEngine;
static overrideComponent(component: Type<any>, override: MetadataOverride<Component>): typeof TestBed;
static overrideDirective(directive: Type<any>, override: MetadataOverride<Directive>): typeof TestBed;
static overrideModule(ngModule: Type<any>, override: MetadataOverride<NgModule>): typeof TestBed;
static overridePipe(pipe: Type<any>, override: MetadataOverride<Pipe>): typeof TestBed;
static overrideProvider(token: any, provider: {
useValue: any;
}): typeof TestBed;
static overrideProvider(token: any, provider: {
useFactory: Function;
deps: any[];
}): typeof TestBed;
static overrideTemplate(component: Type<any>, template: string): typeof TestBed;
static overrideTemplateUsingTestingModule(component: Type<any>, template: string): typeof TestBed;
/** @experimental */ static resetTestEnvironment(): void;
static resetTestingModule(): typeof TestBed;
} }
/** @experimental */ /** @experimental */