From ab7121c1bf8a05c3fa99ef61decb2838b03ff579 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mladen=20Jakovljevi=C4=87?= Date: Wed, 26 Oct 2022 22:30:00 +0200 Subject: [PATCH] feat(sequenceEqual): compareTo should support ObservableInput --- api_guard/dist/types/index.d.ts | 2 +- api_guard/dist/types/operators/index.d.ts | 2 +- spec-dtslint/operators/sequenceEqual-spec.ts | 6 ++++++ src/internal/operators/sequenceEqual.ts | 21 ++++++++++---------- 4 files changed, 19 insertions(+), 12 deletions(-) diff --git a/api_guard/dist/types/index.d.ts b/api_guard/dist/types/index.d.ts index 387e385a6b..199bba7d11 100644 --- a/api_guard/dist/types/index.d.ts +++ b/api_guard/dist/types/index.d.ts @@ -622,7 +622,7 @@ export interface SchedulerLike extends TimestampProvider { schedule(work: (this: SchedulerAction, state?: T) => void, delay?: number, state?: T): Subscription; } -export declare function sequenceEqual(compareTo: Observable, comparator?: (a: T, b: T) => boolean): OperatorFunction; +export declare function sequenceEqual(compareTo: ObservableInput, comparator?: (a: T, b: T) => boolean): OperatorFunction; export interface SequenceError extends Error { } diff --git a/api_guard/dist/types/operators/index.d.ts b/api_guard/dist/types/operators/index.d.ts index 4d673c5b08..113b8b9add 100644 --- a/api_guard/dist/types/operators/index.d.ts +++ b/api_guard/dist/types/operators/index.d.ts @@ -252,7 +252,7 @@ export declare function scan(accumulator: (acc: A | V, value: V, index export declare function scan(accumulator: (acc: A, value: V, index: number) => A, seed: A): OperatorFunction; export declare function scan(accumulator: (acc: A | S, value: V, index: number) => A, seed: S): OperatorFunction; -export declare function sequenceEqual(compareTo: Observable, comparator?: (a: T, b: T) => boolean): OperatorFunction; +export declare function sequenceEqual(compareTo: ObservableInput, comparator?: (a: T, b: T) => boolean): OperatorFunction; export declare function share(): MonoTypeOperatorFunction; export declare function share(options: ShareConfig): MonoTypeOperatorFunction; diff --git a/spec-dtslint/operators/sequenceEqual-spec.ts b/spec-dtslint/operators/sequenceEqual-spec.ts index abf228acdf..0130d56fef 100644 --- a/spec-dtslint/operators/sequenceEqual-spec.ts +++ b/spec-dtslint/operators/sequenceEqual-spec.ts @@ -16,3 +16,9 @@ it('should enforce compareTo to be the same type of Observable', () => { it('should infer correctly given comparator parameter', () => { const a = of(1, 2, 3).pipe(sequenceEqual(of(1), (val1, val2) => val1 === val2)); // $ExpectType Observable }); + +it('should support Promises', () => { + of(1, 2, 3).pipe(sequenceEqual(Promise.resolve(1))); // $ExpectType Observable + // Enforce the same types produced by Promise and source observable + of(1, 2, 3).pipe(sequenceEqual(Promise.resolve('foo'))); // $ExpectError +}); diff --git a/src/internal/operators/sequenceEqual.ts b/src/internal/operators/sequenceEqual.ts index ba514440e0..a6f9bec308 100644 --- a/src/internal/operators/sequenceEqual.ts +++ b/src/internal/operators/sequenceEqual.ts @@ -1,8 +1,7 @@ -import { Observable } from '../Observable'; - -import { OperatorFunction } from '../types'; +import { OperatorFunction, ObservableInput } from '../types'; import { operate } from '../util/lift'; import { createOperatorSubscriber } from './OperatorSubscriber'; +import { innerFrom } from '../observable/innerFrom'; /** * Compares all values of two observables in sequence using an optional comparator function @@ -13,7 +12,8 @@ import { createOperatorSubscriber } from './OperatorSubscriber'; * * ![](sequenceEqual.png) * - * `sequenceEqual` subscribes to two observables and buffers incoming values from each observable. Whenever either + * `sequenceEqual` subscribes to source observable and `compareTo` `ObservableInput` (that internally + * gets converted to an observable) and buffers incoming values from each observable. Whenever either * observable emits a value, the value is buffered and the buffers are shifted and compared from the bottom * up; If any value pair doesn't match, the returned observable will emit `false` and complete. If one of the * observables completes, the operator will wait for the other observable to complete; If the other @@ -53,14 +53,15 @@ import { createOperatorSubscriber } from './OperatorSubscriber'; * @see {@link zip} * @see {@link withLatestFrom} * - * @param {Observable} compareTo The observable sequence to compare the source sequence to. - * @param {function} [comparator] An optional function to compare each value pair + * @param compareTo The `ObservableInput` sequence to compare the source sequence to. + * @param comparator An optional function to compare each value pair. + * * @return A function that returns an Observable that emits a single boolean * value representing whether or not the values emitted by the source - * Observable and provided Observable were equal in sequence. + * Observable and provided `ObservableInput` were equal in sequence. */ export function sequenceEqual( - compareTo: Observable, + compareTo: ObservableInput, comparator: (a: T, b: T) => boolean = (a, b) => a === b ): OperatorFunction { return operate((source, subscriber) => { @@ -94,7 +95,7 @@ export function sequenceEqual( // at the appropriate time. complete ? emit(false) : selfState.buffer.push(a); } else { - // If the other stream *does* have values in it's buffer, + // If the other stream *does* have values in its buffer, // pull the oldest one off so we can compare it to what we // just got. If it wasn't a match, emit `false` and complete. !comparator(a, buffer.shift()!) && emit(false); @@ -119,7 +120,7 @@ export function sequenceEqual( // Subscribe to each source. source.subscribe(createSubscriber(aState, bState)); - compareTo.subscribe(createSubscriber(bState, aState)); + innerFrom(compareTo).subscribe(createSubscriber(bState, aState)); }); }