80 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			80 lines
		
	
	
		
			2.7 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 {Observable, interval} from 'rxjs';
							 | 
						||
| 
								 | 
							
								import {audit, auditTime} from 'rxjs/operators';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								import {asyncTest} from '../test-util';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								xdescribe('Observable.audit', () => {
							 | 
						||
| 
								 | 
							
								  let log: any[];
							 | 
						||
| 
								 | 
							
								  let observable1: Observable<any>;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  beforeEach(() => { log = []; });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  it('audit func callback should run in the correct zone', asyncTest((done: any) => {
							 | 
						||
| 
								 | 
							
								       const constructorZone1: Zone = Zone.current.fork({name: 'Constructor Zone1'});
							 | 
						||
| 
								 | 
							
								       const subscriptionZone: Zone = Zone.current.fork({name: 'Subscription Zone'});
							 | 
						||
| 
								 | 
							
								       observable1 = constructorZone1.run(() => {
							 | 
						||
| 
								 | 
							
								         const source = interval(100);
							 | 
						||
| 
								 | 
							
								         return source.pipe(audit(ev => {
							 | 
						||
| 
								 | 
							
								           expect(Zone.current.name).toEqual(constructorZone1.name);
							 | 
						||
| 
								 | 
							
								           return interval(150);
							 | 
						||
| 
								 | 
							
								         }));
							 | 
						||
| 
								 | 
							
								       });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								       subscriptionZone.run(() => {
							 | 
						||
| 
								 | 
							
								         const subscriber = observable1.subscribe(
							 | 
						||
| 
								 | 
							
								             (result: any) => {
							 | 
						||
| 
								 | 
							
								               expect(Zone.current.name).toEqual(subscriptionZone.name);
							 | 
						||
| 
								 | 
							
								               log.push(result);
							 | 
						||
| 
								 | 
							
								               if (result >= 3) {
							 | 
						||
| 
								 | 
							
								                 subscriber.unsubscribe();
							 | 
						||
| 
								 | 
							
								               }
							 | 
						||
| 
								 | 
							
								             },
							 | 
						||
| 
								 | 
							
								             () => { fail('should not call error'); },
							 | 
						||
| 
								 | 
							
								             () => {
							 | 
						||
| 
								 | 
							
								               log.push('completed');
							 | 
						||
| 
								 | 
							
								               expect(Zone.current.name).toEqual(subscriptionZone.name);
							 | 
						||
| 
								 | 
							
								               expect(log).toEqual([1, 3, 'completed']);
							 | 
						||
| 
								 | 
							
								               done();
							 | 
						||
| 
								 | 
							
								             });
							 | 
						||
| 
								 | 
							
								       });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								       expect(log).toEqual([]);
							 | 
						||
| 
								 | 
							
								     }, Zone.root));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  xit('auditTime func callback should run in the correct zone', asyncTest((done: any) => {
							 | 
						||
| 
								 | 
							
								        const constructorZone1: Zone = Zone.current.fork({name: 'Constructor Zone1'});
							 | 
						||
| 
								 | 
							
								        const subscriptionZone: Zone = Zone.current.fork({name: 'Subscription Zone'});
							 | 
						||
| 
								 | 
							
								        observable1 = constructorZone1.run(() => {
							 | 
						||
| 
								 | 
							
								          const source = interval(100);
							 | 
						||
| 
								 | 
							
								          return source.pipe(auditTime(360));
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        subscriptionZone.run(() => {
							 | 
						||
| 
								 | 
							
								          const subscriber = observable1.subscribe(
							 | 
						||
| 
								 | 
							
								              (result: any) => {
							 | 
						||
| 
								 | 
							
								                expect(Zone.current.name).toEqual(subscriptionZone.name);
							 | 
						||
| 
								 | 
							
								                log.push(result);
							 | 
						||
| 
								 | 
							
								                if (result >= 7) {
							 | 
						||
| 
								 | 
							
								                  subscriber.unsubscribe();
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								              },
							 | 
						||
| 
								 | 
							
								              () => { fail('should not call error'); },
							 | 
						||
| 
								 | 
							
								              () => {
							 | 
						||
| 
								 | 
							
								                log.push('completed');
							 | 
						||
| 
								 | 
							
								                expect(Zone.current.name).toEqual(subscriptionZone.name);
							 | 
						||
| 
								 | 
							
								                expect(log).toEqual([3, 7, 'completed']);
							 | 
						||
| 
								 | 
							
								                done();
							 | 
						||
| 
								 | 
							
								              });
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        expect(log).toEqual([]);
							 | 
						||
| 
								 | 
							
								      }, Zone.root));
							 | 
						||
| 
								 | 
							
								});
							 |