diff --git a/spec-dtslint/operators/scan-spec.ts b/spec-dtslint/operators/scan-spec.ts index b41d7ae039..7f11324c9f 100644 --- a/spec-dtslint/operators/scan-spec.ts +++ b/spec-dtslint/operators/scan-spec.ts @@ -1,23 +1,19 @@ import { of } from 'rxjs'; import { scan } from 'rxjs/operators'; -it('should enforce accumulator function as parameter', () => { +it('should enforce parameter', () => { const a = of(1, 2, 3).pipe(scan()); // $ExpectError }); -it('should infer correctly with single T value', () => { - const a = of(1, 2, 3).pipe(scan((acc, val, i) => acc + val)); // $ExpectType Observable +it('should infer correctly ', () => { + const a = of(1, 2, 3).pipe(scan((x, y, z) => x + 1)); // $ExpectType Observable }); -it('should do a type check on seed parameter', () => { - const b = of(1, 2, 3).pipe(scan((acc, val, i) => acc + val, 0)); // $ExpectType Observable - const a = of(1, 2, 3).pipe(scan((acc, val, i) => acc + val, 'y')); // $ExpectError +it('should infer correctly for accumulator of type array', () => { + const a = of(1, 2, 3).pipe(scan((x: number[], y: number, i: number) => x, [])); // $ExpectType Observable }); -it('should infer correctly with Array of T value', () => { - const a = of(1, 2, 3).pipe(scan((acc: number[], val: number, i) => [...acc, val])); // $ExpectType Observable -}); - -it('should infer correctly with type change accumulator', () => { - const a = of(1, 2, 3).pipe(scan((acc: string, val: number, i) => `${acc} ' ' ${val}`)); // $ $expectType Observable +it('should accept seed parameter of the same type', () => { + const a = of(1, 2, 3).pipe(scan((x, y, z) => x + 1, 5)); // $ExpectType Observable + const b = of(1, 2, 3).pipe(scan((x, y, z) => x + 1, '5')); // $ExpectError });