Every test now has an implicit module. It can be configured via `configureModule` (from @angular/core/testing)
to add providers, directives, pipes, ...
The compiler now has to be configured separately via `configureCompiler` (from @angular/core/testing)
to add providers or define whether to use jit.
BREAKING CHANGE:
- Application providers can no longer inject compiler internals (i.e. everything
  from `@angular/compiler). Inject `Compiler` instead. This reflects the
  changes to `bootstrap` for module support (3f55aa609f60f130f1d69188ed057214b1267cb3).
- Compiler providers can no longer be added via `addProviders` / `withProviders`.
  Use the new method `configureCompiler` instead.
- Platform directives / pipes need to be provided via
  `configureModule` and can no longer be provided via the
  `PLATFORM_PIPES` / `PLATFORM_DIRECTIVES` tokens.
- `setBaseTestProviders()` was renamed into `initTestEnvironment` and 
  now takes a `PlatformRef` and a factory for a
  `Compiler`.
- E.g. for the browser platform:
  
  BEFORE:
  ```
  import {setBaseTestProviders} from ‘@angular/core/testing’;
  import {TEST_BROWSER_DYNAMIC_PLATFORM_PROVIDERS,
      TEST_BROWSER_DYNAMIC_APPLICATION_PROVIDERS} from ‘@angular/platform-browser-dynamic/testing’;
  
  setBaseTestProviders(TEST_BROWSER_DYNAMIC_PLATFORM_PROVIDERS,
      TEST_BROWSER_DYNAMIC_APPLICATION_PROVIDERS);   
  ```
  AFTER:
  ```
  import {setBaseTestProviders} from ‘@angular/core/testing’;
  import {browserTestCompiler, browserDynamicTestPlatform,
      BrowserDynamicTestModule} from ‘@angular/platform-browser-dynamic/testing’;
  
  initTestEnvironment(
      browserTestCompiler,
      browserDynamicTestPlatform(),
      BrowserDynamicTestModule);
  ```
- E.g. for the server platform:
  
  BEFORE:
  ```
  import {setBaseTestProviders} from ‘@angular/core/testing’;
  import {TEST_SERVER_PLATFORM_PROVIDERS,
      TEST_SERVER_APPLICATION_PROVIDERS} from ‘@angular/platform-server/testing/server’;
  
  setBaseTestProviders(TEST_SERVER_PLATFORM_PROVIDERS,
      TEST_SERVER_APPLICATION_PROVIDERS);   
  ```
  AFTER:
  ```
  import {setBaseTestProviders} from ‘@angular/core/testing’;
  import {serverTestCompiler, serverTestPlatform,
      ServerTestModule} from ‘@angular/platform-browser-dynamic/testing’;
  
  initTestEnvironment(
      serverTestCompiler,
      serverTestPlatform(),
      ServerTestModule);
  ```
Related to #9726
Closes #9846
		
	
			
		
			
				
	
	
		
			183 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			183 lines
		
	
	
		
			5.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
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * Public Test Library for unit testing Angular2 Applications. Assumes that you are running
 | 
						|
 * with Jasmine, Mocha, or a similar framework which exports a beforeEach function and
 | 
						|
 * allows tests to be asynchronous by either returning a promise or using a 'done' parameter.
 | 
						|
 */
 | 
						|
 | 
						|
import {TestInjector, getTestInjector} from './test_injector';
 | 
						|
 | 
						|
declare var global: any;
 | 
						|
 | 
						|
var _global = <any>(typeof window === 'undefined' ? global : window);
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var expect: Function = _global.expect;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var afterEach: Function = _global.afterEach;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var describe: Function = _global.describe;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var fdescribe = _global.fdescribe;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var ddescribe = _global.ddescribe;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var xdescribe: Function = _global.xdescribe;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var beforeEach = _global.beforeEach;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var it = _global.it;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var fit = _global.fit;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var iit = _global.fit;
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated you no longer need to import jasmine functions from @angular/core/testing. Simply use
 | 
						|
 * the globals.
 | 
						|
 *
 | 
						|
 * See http://jasmine.github.io/ for more details.
 | 
						|
 */
 | 
						|
export var xit = _global.xit;
 | 
						|
 | 
						|
 | 
						|
var testInjector: TestInjector = getTestInjector();
 | 
						|
 | 
						|
// Reset the test providers before each test.
 | 
						|
if (_global.beforeEach) {
 | 
						|
  beforeEach(() => { testInjector.reset(); });
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Allows overriding default providers of the test injector,
 | 
						|
 * which are defined in test_injector.js
 | 
						|
 *
 | 
						|
 * @stable
 | 
						|
 */
 | 
						|
export function addProviders(providers: Array<any>): void {
 | 
						|
  if (!providers) return;
 | 
						|
  try {
 | 
						|
    testInjector.configureModule({providers: providers});
 | 
						|
  } catch (e) {
 | 
						|
    throw new Error(
 | 
						|
        'addProviders can\'t be called after the injector has been already created for this test. ' +
 | 
						|
        'This is most likely because you\'ve already used the injector to inject a beforeEach or the ' +
 | 
						|
        'current `it` function.');
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Allows overriding default providers, directives, pipes, modules of the test injector,
 | 
						|
 * which are defined in test_injector.js
 | 
						|
 *
 | 
						|
 * @stable
 | 
						|
 */
 | 
						|
export function configureModule(moduleDef: {
 | 
						|
  providers?: any[],
 | 
						|
  directives?: any[],
 | 
						|
  pipes?: any[],
 | 
						|
  precompile?: any[],
 | 
						|
  modules?: any[]
 | 
						|
}): void {
 | 
						|
  if (!moduleDef) return;
 | 
						|
  try {
 | 
						|
    testInjector.configureModule(moduleDef);
 | 
						|
  } catch (e) {
 | 
						|
    throw new Error(
 | 
						|
        'configureModule can\'t be called after the injector has been already created for this test. ' +
 | 
						|
        'This is most likely because you\'ve already used the injector to inject a beforeEach or the ' +
 | 
						|
        'current `it` function.');
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Allows overriding default compiler providers and settings
 | 
						|
 * which are defined in test_injector.js
 | 
						|
 *
 | 
						|
 * @stable
 | 
						|
 */
 | 
						|
export function configureCompiler(config: {providers?: any[], useJit?: boolean}): void {
 | 
						|
  if (!config) return;
 | 
						|
  try {
 | 
						|
    testInjector.configureCompiler(config);
 | 
						|
  } catch (e) {
 | 
						|
    throw new Error(
 | 
						|
        'configureCompiler can\'t be called after the injector has been already created for this test. ' +
 | 
						|
        'This is most likely because you\'ve already used the injector to inject a beforeEach or the ' +
 | 
						|
        'current `it` function.');
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * @deprecated Use beforeEach(() => addProviders())
 | 
						|
 */
 | 
						|
export function beforeEachProviders(fn: () => Array<any>): void {
 | 
						|
  beforeEach(() => { addProviders(fn()); });
 | 
						|
}
 |