prettier/tests/flow/overload/__snapshots__/jsfmt.spec.js.snap

203 lines
4.9 KiB
Plaintext

// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`overload.js 1`] = `
/**
* tests of overload selection
*
* @flow
*/
var x1: number = "".match(0)[0];
var x2: number = "".match(/pattern/)[0];
var x3: string = "".replace(/pattern/,"...");
var x4: number = "".split(/pattern/)[0];
declare class C {
foo(x:number): number;
foo(x:string): string;
bar(x: { a: number }): number;
bar(x: { a: string }): string;
}
var a = new C();
a.foo(0); // ok
a.foo("hey"); // ok
a.foo(true); // error, function cannot be called on intersection type
a.bar({ a: 0 }); // ok
a.bar({ a: "hey" }); // ok
a.bar({ a: true }); // error, function cannot be called on intersection type
declare var x: { a: boolean; } & { b: string };
a.bar(x); // error with nested intersection info (outer for bar, inner for x)
/********** tests **************
interface Dummy<T> {
dumb(foo: (x:number) => number):number;
dumb(foo: (x:string) => string):string;
dumber<U>(bar: (x:T) => Array<U>):U;
dumber<U>(bar: (x:T) => U):Array<U>;
}
function foo(x:string):string { return x; }
var y:number = new Dummy().dumb(foo);
function bar1(x:number):Array<string> { return []; }
var z1:number = new Dummy().dumber(bar1);
function bar2(x:number):string { return "..."; }
var z2:Array<string> = new Dummy().dumber(bar2);
*/
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/**
* tests of overload selection
*
* @flow
*/
var x1: number = "".match(0)[0];
var x2: number = "".match(/pattern/)[0];
var x3: string = "".replace(/pattern/, "...");
var x4: number = "".split(/pattern/)[0];
declare class C {
foo(x: number): number;
foo(x: string): string;
bar(x: { a: number }): number;
bar(x: { a: string }): string;
}
var a = new C();
a.foo(0); // ok
a.foo("hey"); // ok
a.foo(true); // error, function cannot be called on intersection type
a.bar({ a: 0 }); // ok
a.bar({ a: "hey" }); // ok
a.bar({ a: true }); // error, function cannot be called on intersection type
declare var x: { a: boolean } & { b: string };
a.bar(x); // error with nested intersection info (outer for bar, inner for x)
/********** tests **************
interface Dummy<T> {
dumb(foo: (x:number) => number):number;
dumb(foo: (x:string) => string):string;
dumber<U>(bar: (x:T) => Array<U>):U;
dumber<U>(bar: (x:T) => U):Array<U>;
}
function foo(x:string):string { return x; }
var y:number = new Dummy().dumb(foo);
function bar1(x:number):Array<string> { return []; }
var z1:number = new Dummy().dumber(bar1);
function bar2(x:number):string { return "..."; }
var z2:Array<string> = new Dummy().dumber(bar2);
*/
`;
exports[`test.js 1`] = `
function foo() {
var output = new FakeUint8Array();
output.set(new FakeUint8Array(), 0); // matches one of the overloads of set
}
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
function foo() {
var output = new FakeUint8Array();
output.set(new FakeUint8Array(), 0); // matches one of the overloads of set
}
`;
exports[`test2.js 1`] = `
declare class Foo {
bar(x: 'hmm'): number;
bar(x: string): string;
}
var foo = new Foo;
(foo.bar('hmm'): number); // OK
(foo.bar('hmmm'): number); // error
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
declare class Foo {
bar(x: "hmm"): number;
bar(x: string): string;
}
var foo = new Foo();
(foo.bar("hmm"): number); // OK
(foo.bar("hmmm"): number); // error
`;
exports[`test3.js 1`] = `
// passing a union-like thing into an overload is ok
// if overload handles each branch of union-like thing
// unions
declare function f(x: string): void;
declare function f(x: number): void;
declare var x_f: string | number;
f(x_f); // ok
// maybe
declare function g(x: null): void;
declare function g(x: void): void;
declare function g(x: string): void;
declare var x_g: ?string;
g(x_g); // ok
// optional
declare function h(x: void): void;
declare function h(x: string): void;
declare var x_h: {p?: string};
h(x_h.p); // ok
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
// passing a union-like thing into an overload is ok
// if overload handles each branch of union-like thing
// unions
declare function f(x: string): void;
declare function f(x: number): void;
declare var x_f: string | number;
f(x_f); // ok
// maybe
declare function g(x: null): void;
declare function g(x: void): void;
declare function g(x: string): void;
declare var x_g: ?string;
g(x_g); // ok
// optional
declare function h(x: void): void;
declare function h(x: string): void;
declare var x_h: { p?: string };
h(x_h.p); // ok
`;
exports[`union.js 1`] = `
function foo<U> (x: $Either<Array<U>,U>): Array<U> { return []; }
var x1:number = foo(0)[0];
var x2:string = foo([""])[0];
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
function foo<U>(x: $Either<Array<U>, U>): Array<U> {
return [];
}
var x1: number = foo(0)[0];
var x2: string = foo([""])[0];
`;