Skip to content

Commit

Permalink
fix(skipUntil): stop listening to a synchronous notifier after its fi…
Browse files Browse the repository at this point in the history
…rst nexted value
  • Loading branch information
peaBerberian committed Aug 19, 2018
1 parent 1d14277 commit 1c257db
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 2 deletions.
23 changes: 22 additions & 1 deletion spec/operators/skipUntil-spec.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { expect } from 'chai';
import { hot, cold, expectObservable, expectSubscriptions } from '../helpers/marble-testing';
import { Observable, of, Subject } from 'rxjs';
import { concat, defer, Observable, of, Subject } from 'rxjs';
import { skipUntil, mergeMap } from 'rxjs/operators';

declare function asDiagram(arg: string): Function;
Expand Down Expand Up @@ -246,4 +246,25 @@ describe('skipUntil', () => {
expectObservable(result).toBe(expected);
expectSubscriptions(notifier.subscriptions).toBe(nSubs);
});

it('should stop listening to a synchronous notifier after its first nexted value', () => {
// const source = hot('-^-o---o---o---o---o---o---|');
const sideEffects: number[] = [];
const synchronousNotifer = concat(
defer(() => {
sideEffects.push(1);
return of(1);
}),
defer(() => {
sideEffects.push(2);
return of(2);
}),
defer(() => {
sideEffects.push(3);
return of(3);
})
);
of(null).pipe(skipUntil(synchronousNotifer)).subscribe(() => { /* noop */ });
expect(sideEffects).to.deep.equal([1]);
});
});
5 changes: 4 additions & 1 deletion src/internal/operators/skipUntil.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,10 @@ class SkipUntilSubscriber<T, R> extends OuterSubscriber<T, R> {

constructor(destination: Subscriber<R>, notifier: ObservableInput<any>) {
super(destination);
this.add(this.innerSubscription = subscribeToResult(this, notifier));
const innerSubscriber = new InnerSubscriber(this, undefined, undefined);
this.add(innerSubscriber);
this.innerSubscription = innerSubscriber;
subscribeToResult(this, notifier, undefined, undefined, innerSubscriber);
}

protected _next(value: T) {
Expand Down

0 comments on commit 1c257db

Please sign in to comment.