parent
019cb41dd8
commit
d59c20c315
|
@ -1,18 +1,20 @@
|
||||||
import {NgZone} from 'angular2/src/core/zone/ng_zone';
|
import {NgZone} from 'angular2/src/core/zone/ng_zone';
|
||||||
|
import {EventEmitter, ObservableWrapper} from 'angular2/src/facade/async';
|
||||||
|
|
||||||
export class MockNgZone extends NgZone {
|
export class MockNgZone extends NgZone {
|
||||||
/** @internal */
|
/** @internal */
|
||||||
_onEventDone: () => void;
|
_mockOnEventDone: EventEmitter<any>;
|
||||||
|
|
||||||
constructor() { super({enableLongStackTrace: false}); }
|
constructor() {
|
||||||
|
super({enableLongStackTrace: false});
|
||||||
|
this._mockOnEventDone = new EventEmitter<any>(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
get onEventDone() { return this._mockOnEventDone; }
|
||||||
|
|
||||||
run(fn: Function): any { return fn(); }
|
run(fn: Function): any { return fn(); }
|
||||||
|
|
||||||
runOutsideAngular(fn: Function): any { return fn(); }
|
runOutsideAngular(fn: Function): any { return fn(); }
|
||||||
|
|
||||||
overrideOnEventDone(fn: () => void, opt_waitForAsync: boolean = false): void {
|
simulateZoneExit(): void { ObservableWrapper.callNext(this.onEventDone, null); }
|
||||||
this._onEventDone = fn;
|
|
||||||
}
|
|
||||||
|
|
||||||
simulateZoneExit(): void { this._onEventDone(); }
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,12 +45,14 @@ abstract class GenericMessageBusSink implements MessageBusSink {
|
||||||
|
|
||||||
void attachToZone(NgZone zone) {
|
void attachToZone(NgZone zone) {
|
||||||
_zone = zone;
|
_zone = zone;
|
||||||
_zone.overrideOnEventDone(() {
|
_zone.runOutsideAngular(() {
|
||||||
if (_messageBuffer.length > 0) {
|
_zone.onEventDone.listen((_) {
|
||||||
sendMessages(_messageBuffer);
|
if (_messageBuffer.length > 0) {
|
||||||
_messageBuffer.clear();
|
sendMessages(_messageBuffer);
|
||||||
}
|
_messageBuffer.clear();
|
||||||
}, false);
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void initChannel(String channelName, [bool runInZone = true]) {
|
void initChannel(String channelName, [bool runInZone = true]) {
|
||||||
|
|
|
@ -4,7 +4,7 @@ import {
|
||||||
MessageBusSink
|
MessageBusSink
|
||||||
} from "angular2/src/web_workers/shared/message_bus";
|
} from "angular2/src/web_workers/shared/message_bus";
|
||||||
import {BaseException, WrappedException} from 'angular2/src/facade/exceptions';
|
import {BaseException, WrappedException} from 'angular2/src/facade/exceptions';
|
||||||
import {EventEmitter} from 'angular2/src/facade/async';
|
import {EventEmitter, ObservableWrapper} from 'angular2/src/facade/async';
|
||||||
import {StringMapWrapper} from 'angular2/src/facade/collection';
|
import {StringMapWrapper} from 'angular2/src/facade/collection';
|
||||||
import {Injectable} from "angular2/src/core/di";
|
import {Injectable} from "angular2/src/core/di";
|
||||||
import {NgZone} from 'angular2/src/core/zone/ng_zone';
|
import {NgZone} from 'angular2/src/core/zone/ng_zone';
|
||||||
|
@ -41,7 +41,9 @@ export class PostMessageBusSink implements MessageBusSink {
|
||||||
|
|
||||||
attachToZone(zone: NgZone): void {
|
attachToZone(zone: NgZone): void {
|
||||||
this._zone = zone;
|
this._zone = zone;
|
||||||
this._zone.overrideOnEventDone(() => this._handleOnEventDone(), false);
|
this._zone.runOutsideAngular(() => {
|
||||||
|
ObservableWrapper.subscribe(this._zone.onEventDone, (_) => { this._handleOnEventDone(); });
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
initChannel(channel: string, runInZone: boolean = true): void {
|
initChannel(channel: string, runInZone: boolean = true): void {
|
||||||
|
|
Loading…
Reference in New Issue