Skip to content

Commit

Permalink
fix(delayWhen): Emit source value if duration selector completes sync…
Browse files Browse the repository at this point in the history
…hronously

This fixes an issue where delayWhen would not re-emit a source emission if the duration selector
completed synchronously.

fixes #3663
  • Loading branch information
Airblader committed May 21, 2018
1 parent fcbe278 commit d140498
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 9 deletions.
24 changes: 23 additions & 1 deletion spec/operators/delayWhen-spec.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { of } from 'rxjs';
import { of, EMPTY } from 'rxjs';
import { delayWhen } from 'rxjs/operators';
import { TestScheduler } from 'rxjs/testing';
import { hot, cold, expectObservable, expectSubscriptions } from '../helpers/marble-testing';
Expand Down Expand Up @@ -106,6 +106,28 @@ describe('delayWhen operator', () => {
expectObservable(result).toBe(expected);
expectSubscriptions(e1.subscriptions).toBe(subs);
expectSubscriptions(selector.subscriptions).toBe(selectorSubs);
});

it('should emit if the selector completes synchronously', () => {
const e1 = hot('a--|');
const expected = 'a--|';
const subs = '^ !';

const result = e1.pipe(delayWhen((x: any) => EMPTY));

expectObservable(result).toBe(expected);
expectSubscriptions(e1.subscriptions).toBe(subs);
});

it('should emit if the source completes synchronously and the selector completes synchronously', () => {
const e1 = hot('(a|)');
const expected = '(a|)';
const subs = '(^!)';

const result = e1.pipe(delayWhen((x: any) => EMPTY));

expectObservable(result).toBe(expected);
expectSubscriptions(e1.subscriptions).toBe(subs);
});

it('should not emit if selector never emits', () => {
Expand Down
9 changes: 1 addition & 8 deletions src/internal/operators/delayWhen.ts
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,6 @@ class DelayWhenOperator<T> implements Operator<T, T> {
class DelayWhenSubscriber<T, R> extends OuterSubscriber<T, R> {
private completed: boolean = false;
private delayNotifierSubscriptions: Array<Subscription> = [];
private values: Array<T> = [];

constructor(destination: Subscriber<T>,
private delayDurationSelector: (value: T) => Observable<any>) {
Expand Down Expand Up @@ -126,15 +125,11 @@ class DelayWhenSubscriber<T, R> extends OuterSubscriber<T, R> {
subscription.unsubscribe();

const subscriptionIdx = this.delayNotifierSubscriptions.indexOf(subscription);
let value: T = null;

if (subscriptionIdx !== -1) {
value = this.values[subscriptionIdx];
this.delayNotifierSubscriptions.splice(subscriptionIdx, 1);
this.values.splice(subscriptionIdx, 1);
}

return value;
return subscription.outerValue;
}

private tryDelay(delayNotifier: Observable<any>, value: T): void {
Expand All @@ -144,8 +139,6 @@ class DelayWhenSubscriber<T, R> extends OuterSubscriber<T, R> {
this.add(notifierSubscription);
this.delayNotifierSubscriptions.push(notifierSubscription);
}

this.values.push(value);
}

private tryComplete(): void {
Expand Down

0 comments on commit d140498

Please sign in to comment.