Looks like this is some old leftover code from the times when Rx didn't distribute typings via npm. Closes #5287
		
			
				
	
	
		
			379 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			379 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {
 | |
|   AsyncTestCompleter,
 | |
|   afterEach,
 | |
|   beforeEach,
 | |
|   ddescribe,
 | |
|   describe,
 | |
|   expect,
 | |
|   iit,
 | |
|   inject,
 | |
|   it,
 | |
|   xit,
 | |
|   SpyObject
 | |
| } from 'angular2/testing_internal';
 | |
| import {Injector, provide} from 'angular2/core';
 | |
| import {MockBackend, MockConnection} from 'angular2/src/http/backends/mock_backend';
 | |
| import {
 | |
|   BaseRequestOptions,
 | |
|   ConnectionBackend,
 | |
|   Request,
 | |
|   RequestMethods,
 | |
|   RequestOptions,
 | |
|   Response,
 | |
|   ResponseOptions,
 | |
|   URLSearchParams,
 | |
|   JSONP_PROVIDERS,
 | |
|   HTTP_PROVIDERS,
 | |
|   XHRBackend,
 | |
|   JSONPBackend,
 | |
|   Http,
 | |
|   Jsonp
 | |
| } from 'angular2/http';
 | |
| import {Observable, Subject} from '@reactivex/rxjs/dist/cjs/Rx';
 | |
| 
 | |
| class SpyObserver extends SpyObject {
 | |
|   onNext: Function;
 | |
|   onError: Function;
 | |
|   onCompleted: Function;
 | |
|   constructor() {
 | |
|     super();
 | |
|     this.onNext = this.spy('onNext');
 | |
|     this.onError = this.spy('onError');
 | |
|     this.onCompleted = this.spy('onCompleted');
 | |
|   }
 | |
| }
 | |
| 
 | |
| export function main() {
 | |
|   describe('injectables', () => {
 | |
|     var url = 'http://foo.bar';
 | |
|     var http: Http;
 | |
|     var parentInjector: Injector;
 | |
|     var childInjector: Injector;
 | |
|     var jsonpBackend: MockBackend;
 | |
|     var xhrBackend: MockBackend;
 | |
|     var jsonp: Jsonp;
 | |
| 
 | |
|     it('should allow using jsonpInjectables and httpInjectables in same injector',
 | |
|        inject([AsyncTestCompleter], (async) => {
 | |
|          parentInjector = Injector.resolveAndCreate([
 | |
|            provide(XHRBackend, {useClass: MockBackend}),
 | |
|            provide(JSONPBackend, {useClass: MockBackend})
 | |
|          ]);
 | |
| 
 | |
|          childInjector = parentInjector.resolveAndCreateChild([
 | |
|            HTTP_PROVIDERS,
 | |
|            JSONP_PROVIDERS,
 | |
|            provide(XHRBackend, {useClass: MockBackend}),
 | |
|            provide(JSONPBackend, {useClass: MockBackend})
 | |
|          ]);
 | |
| 
 | |
|          http = childInjector.get(Http);
 | |
|          jsonp = childInjector.get(Jsonp);
 | |
|          jsonpBackend = childInjector.get(JSONPBackend);
 | |
|          xhrBackend = childInjector.get(XHRBackend);
 | |
| 
 | |
|          var xhrCreatedConnections = 0;
 | |
|          var jsonpCreatedConnections = 0;
 | |
| 
 | |
| 
 | |
|          xhrBackend.connections.subscribe(() => {
 | |
|            xhrCreatedConnections++;
 | |
|            expect(xhrCreatedConnections).toEqual(1);
 | |
|            if (jsonpCreatedConnections) {
 | |
|              async.done();
 | |
|            }
 | |
|          });
 | |
| 
 | |
|          http.get(url).subscribe(() => {});
 | |
| 
 | |
|          jsonpBackend.connections.subscribe(() => {
 | |
|            jsonpCreatedConnections++;
 | |
|            expect(jsonpCreatedConnections).toEqual(1);
 | |
|            if (xhrCreatedConnections) {
 | |
|              async.done();
 | |
|            }
 | |
|          });
 | |
| 
 | |
|          jsonp.request(url).subscribe(() => {});
 | |
|        }));
 | |
|   });
 | |
| 
 | |
|   describe('http', () => {
 | |
|     var url = 'http://foo.bar';
 | |
|     var http: Http;
 | |
|     var injector: Injector;
 | |
|     var backend: MockBackend;
 | |
|     var baseResponse;
 | |
|     var jsonp: Jsonp;
 | |
|     beforeEach(() => {
 | |
|       injector = Injector.resolveAndCreate([
 | |
|         BaseRequestOptions,
 | |
|         MockBackend,
 | |
|         provide(
 | |
|             Http,
 | |
|             {
 | |
|               useFactory: function(backend: ConnectionBackend, defaultOptions: BaseRequestOptions) {
 | |
|                 return new Http(backend, defaultOptions);
 | |
|               },
 | |
|               deps: [MockBackend, BaseRequestOptions]
 | |
|             }),
 | |
|         provide(
 | |
|             Jsonp,
 | |
|             {
 | |
|               useFactory: function(backend: ConnectionBackend, defaultOptions: BaseRequestOptions) {
 | |
|                 return new Jsonp(backend, defaultOptions);
 | |
|               },
 | |
|               deps: [MockBackend, BaseRequestOptions]
 | |
|             })
 | |
|       ]);
 | |
|       http = injector.get(Http);
 | |
|       jsonp = injector.get(Jsonp);
 | |
|       backend = injector.get(MockBackend);
 | |
|       baseResponse = new Response(new ResponseOptions({body: 'base response'}));
 | |
|     });
 | |
| 
 | |
|     afterEach(() => backend.verifyNoPendingRequests());
 | |
| 
 | |
|     describe('Http', () => {
 | |
|       describe('.request()', () => {
 | |
|         it('should return an Observable',
 | |
|            () => { expect(http.request(url)).toBeAnInstanceOf(Observable); });
 | |
| 
 | |
| 
 | |
|         it('should accept a fully-qualified request as its only parameter',
 | |
|            inject([AsyncTestCompleter], (async) => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.url).toBe('https://google.com');
 | |
|                c.mockRespond(new Response(new ResponseOptions({body: 'Thank you'})));
 | |
|                async.done();
 | |
|              });
 | |
|              http.request(new Request(new RequestOptions({url: 'https://google.com'})))
 | |
|                  .subscribe((res) => {});
 | |
|            }));
 | |
| 
 | |
| 
 | |
|         it('should perform a get request for given url if only passed a string',
 | |
|            inject([AsyncTestCompleter], (async) => {
 | |
|              backend.connections.subscribe(c => c.mockRespond(baseResponse));
 | |
|              http.request('http://basic.connection')
 | |
|                  .subscribe(res => {
 | |
|                    expect(res.text()).toBe('base response');
 | |
|                    async.done();
 | |
|                  });
 | |
|            }));
 | |
| 
 | |
|         it('should perform a get request and complete the response',
 | |
|            inject([AsyncTestCompleter], (async) => {
 | |
|              backend.connections.subscribe(c => c.mockRespond(baseResponse));
 | |
|              http.request('http://basic.connection')
 | |
|                  .subscribe(res => { expect(res.text()).toBe('base response'); }, null,
 | |
|                             () => { async.done(); });
 | |
|            }));
 | |
| 
 | |
|         it('should perform multiple get requests and complete the responses',
 | |
|            inject([AsyncTestCompleter], (async) => {
 | |
|              backend.connections.subscribe(c => c.mockRespond(baseResponse));
 | |
| 
 | |
|              http.request('http://basic.connection')
 | |
|                  .subscribe(res => { expect(res.text()).toBe('base response'); });
 | |
|              http.request('http://basic.connection')
 | |
|                  .subscribe(res => { expect(res.text()).toBe('base response'); }, null,
 | |
|                             () => { async.done(); });
 | |
|            }));
 | |
|         // TODO: make dart not complain about "argument type 'Map' cannot be assigned to the
 | |
|         // parameter type 'IRequestOptions'"
 | |
|         // xit('should perform a get request for given url if passed a dictionary',
 | |
|         //     inject([AsyncTestCompleter], async => {
 | |
|         //       ObservableWrapper.subscribe(backend.connections, c => c.mockRespond(baseResponse));
 | |
|         //       ObservableWrapper.subscribe(http.request(url, {method: RequestMethods.GET}), res =>
 | |
|         //       {
 | |
|         //         expect(res.text()).toBe('base response');
 | |
|         //         async.done();
 | |
|         //       });
 | |
|         //     }));
 | |
| 
 | |
| 
 | |
|         it('should throw if url is not a string or Request', () => {
 | |
|           var req = <Request>{};
 | |
|           expect(() => http.request(req))
 | |
|               .toThrowError('First argument must be a url string or Request instance.');
 | |
|         });
 | |
|       });
 | |
| 
 | |
| 
 | |
|       describe('.get()', () => {
 | |
|         it('should perform a get request for given url', inject([AsyncTestCompleter], async => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.method).toBe(RequestMethods.Get);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.get(url).subscribe(res => {});
 | |
|            }));
 | |
|       });
 | |
| 
 | |
| 
 | |
|       describe('.post()', () => {
 | |
|         it('should perform a post request for given url', inject([AsyncTestCompleter], async => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.method).toBe(RequestMethods.Post);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.post(url, 'post me').subscribe(res => {});
 | |
|            }));
 | |
| 
 | |
| 
 | |
|         it('should attach the provided body to the request', inject([AsyncTestCompleter], async => {
 | |
|              var body = 'this is my post body';
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.text()).toBe(body);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.post(url, body).subscribe(res => {});
 | |
|            }));
 | |
|       });
 | |
| 
 | |
| 
 | |
|       describe('.put()', () => {
 | |
|         it('should perform a put request for given url', inject([AsyncTestCompleter], async => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.method).toBe(RequestMethods.Put);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.put(url, 'put me').subscribe(res => {});
 | |
|            }));
 | |
| 
 | |
|         it('should attach the provided body to the request', inject([AsyncTestCompleter], async => {
 | |
|              var body = 'this is my put body';
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.text()).toBe(body);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.put(url, body).subscribe(res => {});
 | |
|            }));
 | |
|       });
 | |
| 
 | |
| 
 | |
|       describe('.delete()', () => {
 | |
|         it('should perform a delete request for given url', inject([AsyncTestCompleter], async => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.method).toBe(RequestMethods.Delete);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.delete(url).subscribe(res => {});
 | |
|            }));
 | |
|       });
 | |
| 
 | |
| 
 | |
|       describe('.patch()', () => {
 | |
|         it('should perform a patch request for given url', inject([AsyncTestCompleter], async => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.method).toBe(RequestMethods.Patch);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.patch(url, 'this is my patch body').subscribe(res => {});
 | |
|            }));
 | |
| 
 | |
|         it('should attach the provided body to the request', inject([AsyncTestCompleter], async => {
 | |
|              var body = 'this is my patch body';
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.text()).toBe(body);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.patch(url, body).subscribe(res => {});
 | |
|            }));
 | |
|       });
 | |
| 
 | |
| 
 | |
|       describe('.head()', () => {
 | |
|         it('should perform a head request for given url', inject([AsyncTestCompleter], async => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.method).toBe(RequestMethods.Head);
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.head(url).subscribe(res => {});
 | |
|            }));
 | |
|       });
 | |
| 
 | |
| 
 | |
|       describe('searchParams', () => {
 | |
|         it('should append search params to url', inject([AsyncTestCompleter], async => {
 | |
|              var params = new URLSearchParams();
 | |
|              params.append('q', 'puppies');
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.url).toEqual('https://www.google.com?q=puppies');
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.get('https://www.google.com', new RequestOptions({search: params}))
 | |
|                  .subscribe(res => {});
 | |
|            }));
 | |
| 
 | |
| 
 | |
|         it('should append string search params to url', inject([AsyncTestCompleter], async => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.url).toEqual('https://www.google.com?q=piggies');
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.get('https://www.google.com', new RequestOptions({search: 'q=piggies'}))
 | |
|                  .subscribe(res => {});
 | |
|            }));
 | |
| 
 | |
| 
 | |
|         it('should produce valid url when url already contains a query',
 | |
|            inject([AsyncTestCompleter], async => {
 | |
|              backend.connections.subscribe(c => {
 | |
|                expect(c.request.url).toEqual('https://www.google.com?q=angular&as_eq=1.x');
 | |
|                backend.resolveAllConnections();
 | |
|                async.done();
 | |
|              });
 | |
|              http.get('https://www.google.com?q=angular', new RequestOptions({search: 'as_eq=1.x'}))
 | |
|                  .subscribe(res => {});
 | |
|            }));
 | |
|       });
 | |
| 
 | |
|       describe('string method names', () => {
 | |
|         it('should allow case insensitive strings for method names', () => {
 | |
|           inject([AsyncTestCompleter], (async) => {
 | |
|             backend.connections.subscribe(c => {
 | |
|               expect(c.request.method)
 | |
|                   .toBe(RequestMethods.Post)
 | |
|                       c.mockRespond(new Response(new ResponseOptions({body: 'Thank you'})));
 | |
|               async.done();
 | |
|             });
 | |
|             http.request(
 | |
|                     new Request(new RequestOptions({url: 'https://google.com', method: 'PosT'})))
 | |
|                 .subscribe((res) => {});
 | |
|           });
 | |
|         });
 | |
| 
 | |
|         it('should throw when invalid string parameter is passed for method name', () => {
 | |
|           expect(() => {
 | |
|             http.request(
 | |
|                 new Request(new RequestOptions({url: 'https://google.com', method: 'Invalid'})));
 | |
|           }).toThrowError('Invalid request method. The method "Invalid" is not supported.');
 | |
|         });
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     describe('Jsonp', () => {
 | |
|       describe('.request()', () => {
 | |
|         it('should throw if url is not a string or Request', () => {
 | |
|           var req = <Request>{};
 | |
|           expect(() => jsonp.request(req))
 | |
|               .toThrowError('First argument must be a url string or Request instance.');
 | |
|         });
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| }
 |