Skip to content

Commit

Permalink
test(distinct): added tests for ObservableInput support
Browse files Browse the repository at this point in the history
  • Loading branch information
jeremymwells committed Oct 9, 2022
1 parent c7cd5e5 commit 60c32f0
Showing 1 changed file with 58 additions and 0 deletions.
58 changes: 58 additions & 0 deletions spec/operators/distinct-spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { distinct, mergeMap, take } from 'rxjs/operators';
import { TestScheduler } from 'rxjs/testing';
import { of, Observable } from 'rxjs';
import { observableMatcher } from '../helpers/observableMatcher';
import { asInteropObservable } from '../helpers/interop-helper';

/** @test {distinct} */
describe('distinct', () => {
Expand Down Expand Up @@ -218,6 +219,20 @@ describe('distinct', () => {
});
});

it('should support a flushing an interop observable stream', () => {
testScheduler.run(({ hot, expectObservable, expectSubscriptions }) => {
const e1 = hot(' --a--b--a--b--a--b--|');
const e1subs = ' ^-------------------!';
const e2 = hot(' -----------x--------|');
const e2subs = ' ^-------------------!';
const expected = '--a--b--------a--b--|';

expectObservable(e1.pipe(distinct(undefined, asInteropObservable(e2)))).toBe(expected);
expectSubscriptions(e1.subscriptions).toBe(e1subs);
expectSubscriptions(e2.subscriptions).toBe(e2subs);
});
});

it('should raise error if flush raises error', () => {
testScheduler.run(({ hot, expectObservable, expectSubscriptions }) => {
const e1 = hot(' --a--b--a--b--a--b--|');
Expand All @@ -232,6 +247,20 @@ describe('distinct', () => {
});
});

it('should raise error if interop flush raises error', () => {
testScheduler.run(({ hot, expectObservable, expectSubscriptions }) => {
const e1 = hot(' --a--b--a--b--a--b--|');
const e1subs = ' ^------------! ';
const e2 = hot(' -----------x-# ');
const e2subs = ' ^------------! ';
const expected = '--a--b-------# ';

expectObservable(e1.pipe(distinct(undefined, asInteropObservable(e2)))).toBe(expected);
expectSubscriptions(e1.subscriptions).toBe(e1subs);
expectSubscriptions(e2.subscriptions).toBe(e2subs);
});
});

it('should unsubscribe from the flushing stream when the main stream is unsubbed', () => {
testScheduler.run(({ hot, expectObservable, expectSubscriptions }) => {
const e1 = hot(' --a--b--a--b--a--b--|');
Expand All @@ -247,6 +276,21 @@ describe('distinct', () => {
});
});

it('should unsubscribe from the flushing interop stream when the main stream is unsubbed', () => {
testScheduler.run(({ hot, expectObservable, expectSubscriptions }) => {
const e1 = hot(' --a--b--a--b--a--b--|');
const e1subs = ' ^----------! ';
const e2 = hot(' -----------x--------|');
const e2subs = ' ^----------! ';
const unsub = ' -----------! ';
const expected = '--a--b------ ';

expectObservable(e1.pipe(distinct(undefined, asInteropObservable(e2))), unsub).toBe(expected);
expectSubscriptions(e1.subscriptions).toBe(e1subs);
expectSubscriptions(e2.subscriptions).toBe(e2subs);
});
});

it('should allow opting in to default comparator with flush', () => {
testScheduler.run(({ hot, expectObservable, expectSubscriptions }) => {
const e1 = hot(' --a--b--a--b--a--b--|');
Expand All @@ -261,6 +305,20 @@ describe('distinct', () => {
});
});

it('should allow opting in to default comparator with interop flush', () => {
testScheduler.run(({ hot, expectObservable, expectSubscriptions }) => {
const e1 = hot(' --a--b--a--b--a--b--|');
const e1subs = ' ^-------------------!';
const e2 = hot(' -----------x--------|');
const e2subs = ' ^-------------------!';
const expected = '--a--b--------a--b--|';

expectObservable(e1.pipe(distinct(undefined, asInteropObservable(e2)))).toBe(expected);
expectSubscriptions(e1.subscriptions).toBe(e1subs);
expectSubscriptions(e2.subscriptions).toBe(e2subs);
});
});

it('should stop listening to a synchronous observable when unsubscribed', () => {
const sideEffects: number[] = [];
const synchronousObservable = new Observable<number>((subscriber) => {
Expand Down

0 comments on commit 60c32f0

Please sign in to comment.