This change allows ReflectiveInjector to be tree shaken resulting
in not needed Reflect polyfil and smaller bundles.
Code savings for HelloWorld using Closure:
Reflective: bundle.js:  105,864(34,190 gzip)
    Static: bundle.js:  154,889(33,555 gzip)
                            645( 2%)
BREAKING CHANGE:
`platformXXXX()` no longer accepts providers which depend on reflection.
Specifically the method signature when from `Provider[]` to
`StaticProvider[]`.
Example:
Before:
```
[
  MyClass,
  {provide: ClassA, useClass: SubClassA}
]
```
After:
```
[
  {provide: MyClass, deps: [Dep1,...]},
  {provide: ClassA, useClass: SubClassA, deps: [Dep1,...]}
]
```
NOTE: This only applies to platform creation and providers for the JIT
compiler. It does not apply to `@Compotent` or `@NgModule` provides
declarations.
Benchpress note: Previously Benchpress also supported reflective
provides, which now require static providers.
DEPRECATION:
- `ReflectiveInjector` is now deprecated as it will be remove. Use
  `Injector.create` as a replacement.
closes #18496
		
	
			
		
			
				
	
	
		
			124 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			5.5 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 {Injector} from '@angular/core';
 | |
| import {AsyncTestCompleter, beforeEach, describe, inject, it, xit} from '@angular/core/testing/src/testing_internal';
 | |
| import {expect} from '@angular/platform-browser/testing/src/matchers';
 | |
| import {ReplaySubject} from 'rxjs/ReplaySubject';
 | |
| 
 | |
| import {BaseRequestOptions, RequestOptions} from '../../src/base_request_options';
 | |
| import {BaseResponseOptions, ResponseOptions} from '../../src/base_response_options';
 | |
| import {Request} from '../../src/static_request';
 | |
| import {Response} from '../../src/static_response';
 | |
| import {MockBackend, MockConnection} from '../../testing/src/mock_backend';
 | |
| 
 | |
| export function main() {
 | |
|   describe('MockBackend', () => {
 | |
| 
 | |
|     let backend: MockBackend;
 | |
|     let sampleRequest1: Request;
 | |
|     let sampleResponse1: Response;
 | |
|     let sampleRequest2: Request;
 | |
|     let sampleResponse2: Response;
 | |
| 
 | |
|     beforeEach(() => {
 | |
|       const injector = Injector.create([
 | |
|         {provide: ResponseOptions, useClass: BaseResponseOptions, deps: []},
 | |
|         {provide: MockBackend, deps: []}
 | |
|       ]);
 | |
|       backend = injector.get(MockBackend);
 | |
|       const base = new BaseRequestOptions();
 | |
|       sampleRequest1 =
 | |
|           new Request(base.merge(new RequestOptions({url: 'https://google.com'})) as any);
 | |
|       sampleResponse1 = new Response(new ResponseOptions({body: 'response1'}));
 | |
|       sampleRequest2 =
 | |
|           new Request(base.merge(new RequestOptions({url: 'https://google.com'})) as any);
 | |
|       sampleResponse2 = new Response(new ResponseOptions({body: 'response2'}));
 | |
|     });
 | |
| 
 | |
|     it('should create a new MockBackend', () => { expect(backend).toBeAnInstanceOf(MockBackend); });
 | |
| 
 | |
|     it('should create a new MockConnection', () => {
 | |
|       expect(backend.createConnection(sampleRequest1)).toBeAnInstanceOf(MockConnection);
 | |
|     });
 | |
| 
 | |
|     it('should create a new connection and allow subscription', () => {
 | |
|       const connection: MockConnection = backend.createConnection(sampleRequest1);
 | |
|       connection.response.subscribe(() => {});
 | |
|     });
 | |
| 
 | |
|     it('should allow responding after subscription',
 | |
|        inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
 | |
|          const connection: MockConnection = backend.createConnection(sampleRequest1);
 | |
|          connection.response.subscribe(() => { async.done(); });
 | |
|          connection.mockRespond(sampleResponse1);
 | |
|        }));
 | |
| 
 | |
|     it('should allow subscribing after responding',
 | |
|        inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
 | |
|          const connection: MockConnection = backend.createConnection(sampleRequest1);
 | |
|          connection.mockRespond(sampleResponse1);
 | |
|          connection.response.subscribe(() => { async.done(); });
 | |
|        }));
 | |
| 
 | |
|     it('should allow responding after subscription with an error',
 | |
|        inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
 | |
|          const connection: MockConnection = backend.createConnection(sampleRequest1);
 | |
|          connection.response.subscribe(null !, () => { async.done(); });
 | |
|          connection.mockError(new Error('nope'));
 | |
|        }));
 | |
| 
 | |
|     it('should not throw when there are no unresolved requests',
 | |
|        inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
 | |
|          const connection: MockConnection = backend.createConnection(sampleRequest1);
 | |
|          connection.response.subscribe(() => { async.done(); });
 | |
|          connection.mockRespond(sampleResponse1);
 | |
|          backend.verifyNoPendingRequests();
 | |
|        }));
 | |
| 
 | |
|     xit('should throw when there are unresolved requests',
 | |
|         inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
 | |
|           const connection: MockConnection = backend.createConnection(sampleRequest1);
 | |
|           connection.response.subscribe(() => { async.done(); });
 | |
|           backend.verifyNoPendingRequests();
 | |
|         }));
 | |
| 
 | |
|     it('should work when requests are resolved out of order',
 | |
|        inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
 | |
|          const connection1: MockConnection = backend.createConnection(sampleRequest1);
 | |
|          const connection2: MockConnection = backend.createConnection(sampleRequest1);
 | |
|          connection1.response.subscribe(() => { async.done(); });
 | |
|          connection2.response.subscribe(() => {});
 | |
|          connection2.mockRespond(sampleResponse1);
 | |
|          connection1.mockRespond(sampleResponse1);
 | |
|          backend.verifyNoPendingRequests();
 | |
|        }));
 | |
| 
 | |
|     xit('should allow double subscribing',
 | |
|         inject([AsyncTestCompleter], (async: AsyncTestCompleter) => {
 | |
|           const responses: Response[] = [sampleResponse1, sampleResponse2];
 | |
|           backend.connections.subscribe((c: MockConnection) => c.mockRespond(responses.shift() !));
 | |
|           const responseObservable: ReplaySubject<Response> =
 | |
|               backend.createConnection(sampleRequest1).response;
 | |
|           responseObservable.subscribe(res => expect(res.text()).toBe('response1'));
 | |
|           responseObservable.subscribe(
 | |
|               res => expect(res.text()).toBe('response2'), null !, async.done);
 | |
|         }));
 | |
| 
 | |
|     // TODO(robwormald): readyStates are leaving?
 | |
|     it('should allow resolution of requests manually', () => {
 | |
|       const connection1: MockConnection = backend.createConnection(sampleRequest1);
 | |
|       const connection2: MockConnection = backend.createConnection(sampleRequest1);
 | |
|       connection1.response.subscribe(() => {});
 | |
|       connection2.response.subscribe(() => {});
 | |
|       backend.resolveAllConnections();
 | |
|       backend.verifyNoPendingRequests();
 | |
|     });
 | |
|   });
 | |
| }
 |