mirror of
https://github.com/microsoft/TypeScript.git
synced 2025-11-18 17:21:48 +00:00
Fix Awaited<T> for onfulfilled callbacks with more than one argument
This commit is contained in:
Vendored
+1
-1
@@ -1495,7 +1495,7 @@ interface Promise<T> {
|
||||
type Awaited<T> =
|
||||
T extends null | undefined ? T : // special case for `null | undefined` when not in `--strictNullChecks` mode
|
||||
T extends object & { then(onfulfilled: infer F): any } ? // `await` only unwraps object types with a callable `then`. Non-object types are not unwrapped
|
||||
F extends ((value: infer V) => any) ? // if the argument to `then` is callable, extracts the argument
|
||||
F extends ((value: infer V, ...args: any) => any) ? // if the argument to `then` is callable, extracts the first argument
|
||||
Awaited<V> : // recursively unwrap the value
|
||||
never : // the argument to `then` was not callable
|
||||
T; // non-object or non-thenable
|
||||
|
||||
@@ -30,6 +30,9 @@ tests/cases/compiler/awaitedType.ts(22,12): error TS2589: Type instantiation is
|
||||
~~~~~~~~~~~~~~~~~~~~
|
||||
!!! error TS2589: Type instantiation is excessively deep and possibly infinite.
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
declare function MaybePromise<T>(value: T): MaybePromise<T>;
|
||||
|
||||
@@ -22,6 +22,9 @@ interface BadPromise1 { then(cb: (value: BadPromise2) => void): void; }
|
||||
interface BadPromise2 { then(cb: (value: BadPromise1) => void): void; }
|
||||
type T17 = Awaited<BadPromise1>; // error
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
declare function MaybePromise<T>(value: T): MaybePromise<T>;
|
||||
|
||||
@@ -60,21 +60,21 @@ type T12 = Awaited<Promise<Promise<number>>>;
|
||||
|
||||
type T13 = _Expect<Awaited<Promise<Promise<number>> | string | null>, /*expected*/ string | number | null>; // otherwise just prints T13 in types tests, which isn't very helpful
|
||||
>T13 : Symbol(T13, Decl(awaitedType.ts, 11, 45))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedType.ts, 153, 1))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedType.ts, 156, 1))
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
|
||||
type T14 = _Expect<Awaited<Promise<Promise<number>> | string | undefined>, /*expected*/ string | number | undefined>; // otherwise just prints T14 in types tests, which isn't very helpful
|
||||
>T14 : Symbol(T14, Decl(awaitedType.ts, 12, 107))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedType.ts, 153, 1))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedType.ts, 156, 1))
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
|
||||
type T15 = _Expect<Awaited<Promise<Promise<number>> | string | null | undefined>, /*expected*/ string | number | null | undefined>; // otherwise just prints T15 in types tests, which isn't very helpful
|
||||
>T15 : Symbol(T15, Decl(awaitedType.ts, 13, 117))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedType.ts, 153, 1))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedType.ts, 156, 1))
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
@@ -110,39 +110,48 @@ type T17 = Awaited<BadPromise1>; // error
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>BadPromise1 : Symbol(BadPromise1, Decl(awaitedType.ts, 17, 31))
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
>T18 : Symbol(T18, Decl(awaitedType.ts, 21, 32))
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>then : Symbol(then, Decl(awaitedType.ts, 24, 20))
|
||||
>cb : Symbol(cb, Decl(awaitedType.ts, 24, 26))
|
||||
>value : Symbol(value, Decl(awaitedType.ts, 24, 31))
|
||||
>other : Symbol(other, Decl(awaitedType.ts, 24, 45))
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 24, 54), Decl(awaitedType.ts, 21, 32))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 24, 18))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 24, 18))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 27, 54), Decl(awaitedType.ts, 24, 69))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 27, 18))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 27, 18))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 24, 18))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 27, 18))
|
||||
>PromiseLike : Symbol(PromiseLike, Decl(lib.es5.d.ts, --, --))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 24, 18))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 27, 18))
|
||||
|
||||
declare function MaybePromise<T>(value: T): MaybePromise<T>;
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 24, 54), Decl(awaitedType.ts, 21, 32))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 25, 30))
|
||||
>value : Symbol(value, Decl(awaitedType.ts, 25, 33))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 25, 30))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 24, 54), Decl(awaitedType.ts, 21, 32))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 25, 30))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 27, 54), Decl(awaitedType.ts, 24, 69))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 28, 30))
|
||||
>value : Symbol(value, Decl(awaitedType.ts, 28, 33))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 28, 30))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 27, 54), Decl(awaitedType.ts, 24, 69))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 28, 30))
|
||||
|
||||
async function main() {
|
||||
>main : Symbol(main, Decl(awaitedType.ts, 25, 60))
|
||||
>main : Symbol(main, Decl(awaitedType.ts, 28, 60))
|
||||
|
||||
let aaa: number;
|
||||
>aaa : Symbol(aaa, Decl(awaitedType.ts, 28, 7))
|
||||
>aaa : Symbol(aaa, Decl(awaitedType.ts, 31, 7))
|
||||
|
||||
let bbb: string;
|
||||
>bbb : Symbol(bbb, Decl(awaitedType.ts, 29, 7))
|
||||
>bbb : Symbol(bbb, Decl(awaitedType.ts, 32, 7))
|
||||
|
||||
[
|
||||
aaa,
|
||||
>aaa : Symbol(aaa, Decl(awaitedType.ts, 28, 7))
|
||||
>aaa : Symbol(aaa, Decl(awaitedType.ts, 31, 7))
|
||||
|
||||
bbb,
|
||||
>bbb : Symbol(bbb, Decl(awaitedType.ts, 29, 7))
|
||||
>bbb : Symbol(bbb, Decl(awaitedType.ts, 32, 7))
|
||||
|
||||
] = await Promise.all([
|
||||
>Promise.all : Symbol(PromiseConstructor.all, Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --))
|
||||
@@ -150,88 +159,88 @@ async function main() {
|
||||
>all : Symbol(PromiseConstructor.all, Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --))
|
||||
|
||||
MaybePromise(1),
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 24, 54), Decl(awaitedType.ts, 21, 32))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 27, 54), Decl(awaitedType.ts, 24, 69))
|
||||
|
||||
MaybePromise('2'),
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 24, 54), Decl(awaitedType.ts, 21, 32))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 27, 54), Decl(awaitedType.ts, 24, 69))
|
||||
|
||||
MaybePromise(true),
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 24, 54), Decl(awaitedType.ts, 21, 32))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedType.ts, 27, 54), Decl(awaitedType.ts, 24, 69))
|
||||
|
||||
])
|
||||
}
|
||||
|
||||
// non-generic
|
||||
async function f1(x: string) {
|
||||
>f1 : Symbol(f1, Decl(awaitedType.ts, 38, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 41, 18))
|
||||
>f1 : Symbol(f1, Decl(awaitedType.ts, 41, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 44, 18))
|
||||
|
||||
// y: string
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 43, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 41, 18))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 46, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 44, 18))
|
||||
}
|
||||
|
||||
async function f2(x: unknown) {
|
||||
>f2 : Symbol(f2, Decl(awaitedType.ts, 44, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 46, 18))
|
||||
>f2 : Symbol(f2, Decl(awaitedType.ts, 47, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 49, 18))
|
||||
|
||||
// y: unknown
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 48, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 46, 18))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 51, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 49, 18))
|
||||
}
|
||||
|
||||
async function f3(x: object) {
|
||||
>f3 : Symbol(f3, Decl(awaitedType.ts, 49, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 51, 18))
|
||||
>f3 : Symbol(f3, Decl(awaitedType.ts, 52, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 54, 18))
|
||||
|
||||
// y: object
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 53, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 51, 18))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 56, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 54, 18))
|
||||
}
|
||||
|
||||
async function f4(x: Promise<string>) {
|
||||
>f4 : Symbol(f4, Decl(awaitedType.ts, 54, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 56, 18))
|
||||
>f4 : Symbol(f4, Decl(awaitedType.ts, 57, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 59, 18))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
|
||||
// y: string
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 58, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 56, 18))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 61, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 59, 18))
|
||||
}
|
||||
|
||||
async function f5(x: Promise<unknown>) {
|
||||
>f5 : Symbol(f5, Decl(awaitedType.ts, 59, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 61, 18))
|
||||
>f5 : Symbol(f5, Decl(awaitedType.ts, 62, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 64, 18))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
|
||||
// y: unknown
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 63, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 61, 18))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 66, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 64, 18))
|
||||
}
|
||||
|
||||
async function f6(x: Promise<object>) {
|
||||
>f6 : Symbol(f6, Decl(awaitedType.ts, 64, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 66, 18))
|
||||
>f6 : Symbol(f6, Decl(awaitedType.ts, 67, 1))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 69, 18))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
|
||||
// y: object
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 68, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 66, 18))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 71, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 69, 18))
|
||||
}
|
||||
|
||||
// generic
|
||||
|
||||
async function f7<T>(x: T) {
|
||||
>f7 : Symbol(f7, Decl(awaitedType.ts, 69, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 73, 18))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 73, 21))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 73, 18))
|
||||
>f7 : Symbol(f7, Decl(awaitedType.ts, 72, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 76, 18))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 76, 21))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 76, 18))
|
||||
|
||||
// NOTE: T does not belong solely to the domain of primitive types and either does
|
||||
// not have a base constraint, its base constraint is `any`, `unknown`, `{}`, or `object`,
|
||||
@@ -239,15 +248,15 @@ async function f7<T>(x: T) {
|
||||
|
||||
// y: Awaited<T>
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 79, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 73, 21))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 82, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 76, 21))
|
||||
}
|
||||
|
||||
async function f8<T extends any>(x: T) {
|
||||
>f8 : Symbol(f8, Decl(awaitedType.ts, 80, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 82, 18))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 82, 33))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 82, 18))
|
||||
>f8 : Symbol(f8, Decl(awaitedType.ts, 83, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 85, 18))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 85, 33))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 85, 18))
|
||||
|
||||
// NOTE: T does not belong solely to the domain of primitive types and either does
|
||||
// not have a base constraint, its base constraint is `any`, `unknown`, `{}`, or `object`,
|
||||
@@ -255,15 +264,15 @@ async function f8<T extends any>(x: T) {
|
||||
|
||||
// y: Awaited<T>
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 88, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 82, 33))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 91, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 85, 33))
|
||||
}
|
||||
|
||||
async function f9<T extends unknown>(x: T) {
|
||||
>f9 : Symbol(f9, Decl(awaitedType.ts, 89, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 91, 18))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 91, 37))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 91, 18))
|
||||
>f9 : Symbol(f9, Decl(awaitedType.ts, 92, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 94, 18))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 94, 37))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 94, 18))
|
||||
|
||||
// NOTE: T does not belong solely to the domain of primitive types and either does
|
||||
// not have a base constraint, its base constraint is `any`, `unknown`, `{}`, or `object`,
|
||||
@@ -271,15 +280,15 @@ async function f9<T extends unknown>(x: T) {
|
||||
|
||||
// y: Awaited<T>
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 97, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 91, 37))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 100, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 94, 37))
|
||||
}
|
||||
|
||||
async function f10<T extends {}>(x: T) {
|
||||
>f10 : Symbol(f10, Decl(awaitedType.ts, 98, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 100, 19))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 100, 33))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 100, 19))
|
||||
>f10 : Symbol(f10, Decl(awaitedType.ts, 101, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 103, 19))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 103, 33))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 103, 19))
|
||||
|
||||
// NOTE: T does not belong solely to the domain of primitive types and either does
|
||||
// not have a base constraint, its base constraint is `any`, `unknown`, `{}`, or `object`,
|
||||
@@ -287,18 +296,18 @@ async function f10<T extends {}>(x: T) {
|
||||
|
||||
// y: Awaited<T>
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 106, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 100, 33))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 109, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 103, 33))
|
||||
}
|
||||
|
||||
async function f11<T extends { then(onfulfilled: (value: unknown) => void): void }>(x: T) {
|
||||
>f11 : Symbol(f11, Decl(awaitedType.ts, 107, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 109, 19))
|
||||
>then : Symbol(then, Decl(awaitedType.ts, 109, 30))
|
||||
>onfulfilled : Symbol(onfulfilled, Decl(awaitedType.ts, 109, 36))
|
||||
>value : Symbol(value, Decl(awaitedType.ts, 109, 50))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 109, 84))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 109, 19))
|
||||
>f11 : Symbol(f11, Decl(awaitedType.ts, 110, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 112, 19))
|
||||
>then : Symbol(then, Decl(awaitedType.ts, 112, 30))
|
||||
>onfulfilled : Symbol(onfulfilled, Decl(awaitedType.ts, 112, 36))
|
||||
>value : Symbol(value, Decl(awaitedType.ts, 112, 50))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 112, 84))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 112, 19))
|
||||
|
||||
// NOTE: T does not belong solely to the domain of primitive types and either does
|
||||
// not have a base constraint, its base constraint is `any`, `unknown`, `{}`, or `object`,
|
||||
@@ -306,15 +315,15 @@ async function f11<T extends { then(onfulfilled: (value: unknown) => void): void
|
||||
|
||||
// y: Awaited<T>
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 115, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 109, 84))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 118, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 112, 84))
|
||||
}
|
||||
|
||||
async function f12<T extends string | object>(x: T) {
|
||||
>f12 : Symbol(f12, Decl(awaitedType.ts, 116, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 118, 19))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 118, 46))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 118, 19))
|
||||
>f12 : Symbol(f12, Decl(awaitedType.ts, 119, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 121, 19))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 121, 46))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 121, 19))
|
||||
|
||||
// NOTE: T does not belong solely to the domain of primitive types and either does
|
||||
// not have a base constraint, its base constraint is `any`, `unknown`, `{}`, or `object`,
|
||||
@@ -322,75 +331,75 @@ async function f12<T extends string | object>(x: T) {
|
||||
|
||||
// y: Awaited<T>
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 124, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 118, 46))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 127, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 121, 46))
|
||||
}
|
||||
|
||||
async function f13<T extends string>(x: T) {
|
||||
>f13 : Symbol(f13, Decl(awaitedType.ts, 125, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 127, 19))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 127, 37))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 127, 19))
|
||||
>f13 : Symbol(f13, Decl(awaitedType.ts, 128, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 130, 19))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 130, 37))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 130, 19))
|
||||
|
||||
// NOTE: T belongs to the domain of primitive types
|
||||
|
||||
// y: T
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 131, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 127, 37))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 134, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 130, 37))
|
||||
}
|
||||
|
||||
async function f14<T extends { x: number }>(x: T) {
|
||||
>f14 : Symbol(f14, Decl(awaitedType.ts, 132, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 134, 19))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 134, 30))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 134, 44))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 134, 19))
|
||||
>f14 : Symbol(f14, Decl(awaitedType.ts, 135, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 137, 19))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 137, 30))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 137, 44))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 137, 19))
|
||||
|
||||
// NOTE: T has a non-primitive base constraint without a callable `then`.
|
||||
|
||||
// y: T
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 138, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 134, 44))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 141, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 137, 44))
|
||||
}
|
||||
|
||||
async function f15<T extends { then: number }>(x: T) {
|
||||
>f15 : Symbol(f15, Decl(awaitedType.ts, 139, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 141, 19))
|
||||
>then : Symbol(then, Decl(awaitedType.ts, 141, 30))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 141, 47))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 141, 19))
|
||||
>f15 : Symbol(f15, Decl(awaitedType.ts, 142, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 144, 19))
|
||||
>then : Symbol(then, Decl(awaitedType.ts, 144, 30))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 144, 47))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 144, 19))
|
||||
|
||||
// NOTE: T has a non-primitive base constraint without a callable `then`.
|
||||
|
||||
// y: T
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 145, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 141, 47))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 148, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 144, 47))
|
||||
}
|
||||
|
||||
async function f16<T extends number & { then(): void }>(x: T) {
|
||||
>f16 : Symbol(f16, Decl(awaitedType.ts, 146, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 148, 19))
|
||||
>then : Symbol(then, Decl(awaitedType.ts, 148, 39))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 148, 56))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 148, 19))
|
||||
>f16 : Symbol(f16, Decl(awaitedType.ts, 149, 1))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 151, 19))
|
||||
>then : Symbol(then, Decl(awaitedType.ts, 151, 39))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 151, 56))
|
||||
>T : Symbol(T, Decl(awaitedType.ts, 151, 19))
|
||||
|
||||
// NOTE: T belongs to the domain of primitive types (regardless of `then`)
|
||||
|
||||
// y: T
|
||||
const y = await x;
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 152, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 148, 56))
|
||||
>y : Symbol(y, Decl(awaitedType.ts, 155, 9))
|
||||
>x : Symbol(x, Decl(awaitedType.ts, 151, 56))
|
||||
}
|
||||
|
||||
|
||||
// helps with tests where '.types' just prints out the type alias name
|
||||
type _Expect<TActual extends TExpected, TExpected> = TActual;
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedType.ts, 153, 1))
|
||||
>TActual : Symbol(TActual, Decl(awaitedType.ts, 157, 13))
|
||||
>TExpected : Symbol(TExpected, Decl(awaitedType.ts, 157, 39))
|
||||
>TExpected : Symbol(TExpected, Decl(awaitedType.ts, 157, 39))
|
||||
>TActual : Symbol(TActual, Decl(awaitedType.ts, 157, 13))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedType.ts, 156, 1))
|
||||
>TActual : Symbol(TActual, Decl(awaitedType.ts, 160, 13))
|
||||
>TExpected : Symbol(TExpected, Decl(awaitedType.ts, 160, 39))
|
||||
>TExpected : Symbol(TExpected, Decl(awaitedType.ts, 160, 39))
|
||||
>TActual : Symbol(TActual, Decl(awaitedType.ts, 160, 13))
|
||||
|
||||
|
||||
@@ -75,6 +75,14 @@ interface BadPromise2 { then(cb: (value: BadPromise1) => void): void; }
|
||||
type T17 = Awaited<BadPromise1>; // error
|
||||
>T17 : any
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
>T18 : number
|
||||
>then : (cb: (value: number, other: {}) => void) => any
|
||||
>cb : (value: number, other: {}) => void
|
||||
>value : number
|
||||
>other : {}
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
>MaybePromise : MaybePromise<T>
|
||||
@@ -105,9 +113,9 @@ async function main() {
|
||||
] = await Promise.all([
|
||||
>await Promise.all([ MaybePromise(1), MaybePromise('2'), MaybePromise(true), ]) : [number, string, boolean]
|
||||
>Promise.all([ MaybePromise(1), MaybePromise('2'), MaybePromise(true), ]) : Promise<[number, string, boolean]>
|
||||
>Promise.all : { <T>(values: Iterable<T | PromiseLike<T>>): Promise<Awaited<T>[]>; <T extends readonly unknown[] | []>(values: T): Promise<{ -readonly [P in keyof T]: Awaited<T[P]>; }>; }
|
||||
>Promise.all : { <T>(values: Iterable<T | PromiseLike<T>>): Promise<Awaited<T>[]>; <T extends [] | readonly unknown[]>(values: T): Promise<{ -readonly [P in keyof T]: Awaited<T[P]>; }>; }
|
||||
>Promise : PromiseConstructor
|
||||
>all : { <T>(values: Iterable<T | PromiseLike<T>>): Promise<Awaited<T>[]>; <T extends readonly unknown[] | []>(values: T): Promise<{ -readonly [P in keyof T]: Awaited<T[P]>; }>; }
|
||||
>all : { <T>(values: Iterable<T | PromiseLike<T>>): Promise<Awaited<T>[]>; <T extends [] | readonly unknown[]>(values: T): Promise<{ -readonly [P in keyof T]: Awaited<T[P]>; }>; }
|
||||
>[ MaybePromise(1), MaybePromise('2'), MaybePromise(true), ] : [number | Promise<1> | PromiseLike<1>, string | Promise<"2"> | PromiseLike<"2">, MaybePromise<true>]
|
||||
|
||||
MaybePromise(1),
|
||||
|
||||
@@ -30,6 +30,9 @@ tests/cases/compiler/awaitedTypeStrictNull.ts(22,12): error TS2589: Type instant
|
||||
~~~~~~~~~~~~~~~~~~~~
|
||||
!!! error TS2589: Type instantiation is excessively deep and possibly infinite.
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
declare function MaybePromise<T>(value: T): MaybePromise<T>;
|
||||
|
||||
@@ -22,6 +22,9 @@ interface BadPromise1 { then(cb: (value: BadPromise2) => void): void; }
|
||||
interface BadPromise2 { then(cb: (value: BadPromise1) => void): void; }
|
||||
type T17 = Awaited<BadPromise1>; // error
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
declare function MaybePromise<T>(value: T): MaybePromise<T>;
|
||||
|
||||
@@ -60,21 +60,21 @@ type T12 = Awaited<Promise<Promise<number>>>;
|
||||
|
||||
type T13 = _Expect<Awaited<Promise<Promise<number>> | string | null>, /*expected*/ string | number | null>; // otherwise just prints T13 in types tests, which isn't very helpful
|
||||
>T13 : Symbol(T13, Decl(awaitedTypeStrictNull.ts, 11, 45))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedTypeStrictNull.ts, 54, 1))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedTypeStrictNull.ts, 57, 1))
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
|
||||
type T14 = _Expect<Awaited<Promise<Promise<number>> | string | undefined>, /*expected*/ string | number | undefined>; // otherwise just prints T14 in types tests, which isn't very helpful
|
||||
>T14 : Symbol(T14, Decl(awaitedTypeStrictNull.ts, 12, 107))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedTypeStrictNull.ts, 54, 1))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedTypeStrictNull.ts, 57, 1))
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
|
||||
type T15 = _Expect<Awaited<Promise<Promise<number>> | string | null | undefined>, /*expected*/ string | number | null | undefined>; // otherwise just prints T15 in types tests, which isn't very helpful
|
||||
>T15 : Symbol(T15, Decl(awaitedTypeStrictNull.ts, 13, 117))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedTypeStrictNull.ts, 54, 1))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedTypeStrictNull.ts, 57, 1))
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
@@ -110,39 +110,48 @@ type T17 = Awaited<BadPromise1>; // error
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>BadPromise1 : Symbol(BadPromise1, Decl(awaitedTypeStrictNull.ts, 17, 31))
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
>T18 : Symbol(T18, Decl(awaitedTypeStrictNull.ts, 21, 32))
|
||||
>Awaited : Symbol(Awaited, Decl(lib.es5.d.ts, --, --))
|
||||
>then : Symbol(then, Decl(awaitedTypeStrictNull.ts, 24, 20))
|
||||
>cb : Symbol(cb, Decl(awaitedTypeStrictNull.ts, 24, 26))
|
||||
>value : Symbol(value, Decl(awaitedTypeStrictNull.ts, 24, 31))
|
||||
>other : Symbol(other, Decl(awaitedTypeStrictNull.ts, 24, 45))
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 24, 54), Decl(awaitedTypeStrictNull.ts, 21, 32))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 24, 18))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 24, 18))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 27, 54), Decl(awaitedTypeStrictNull.ts, 24, 69))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 27, 18))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 27, 18))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 24, 18))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 27, 18))
|
||||
>PromiseLike : Symbol(PromiseLike, Decl(lib.es5.d.ts, --, --))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 24, 18))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 27, 18))
|
||||
|
||||
declare function MaybePromise<T>(value: T): MaybePromise<T>;
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 24, 54), Decl(awaitedTypeStrictNull.ts, 21, 32))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 25, 30))
|
||||
>value : Symbol(value, Decl(awaitedTypeStrictNull.ts, 25, 33))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 25, 30))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 24, 54), Decl(awaitedTypeStrictNull.ts, 21, 32))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 25, 30))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 27, 54), Decl(awaitedTypeStrictNull.ts, 24, 69))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 28, 30))
|
||||
>value : Symbol(value, Decl(awaitedTypeStrictNull.ts, 28, 33))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 28, 30))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 27, 54), Decl(awaitedTypeStrictNull.ts, 24, 69))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 28, 30))
|
||||
|
||||
async function main() {
|
||||
>main : Symbol(main, Decl(awaitedTypeStrictNull.ts, 25, 60))
|
||||
>main : Symbol(main, Decl(awaitedTypeStrictNull.ts, 28, 60))
|
||||
|
||||
let aaa: number;
|
||||
>aaa : Symbol(aaa, Decl(awaitedTypeStrictNull.ts, 28, 7))
|
||||
>aaa : Symbol(aaa, Decl(awaitedTypeStrictNull.ts, 31, 7))
|
||||
|
||||
let bbb: string;
|
||||
>bbb : Symbol(bbb, Decl(awaitedTypeStrictNull.ts, 29, 7))
|
||||
>bbb : Symbol(bbb, Decl(awaitedTypeStrictNull.ts, 32, 7))
|
||||
|
||||
[
|
||||
aaa,
|
||||
>aaa : Symbol(aaa, Decl(awaitedTypeStrictNull.ts, 28, 7))
|
||||
>aaa : Symbol(aaa, Decl(awaitedTypeStrictNull.ts, 31, 7))
|
||||
|
||||
bbb,
|
||||
>bbb : Symbol(bbb, Decl(awaitedTypeStrictNull.ts, 29, 7))
|
||||
>bbb : Symbol(bbb, Decl(awaitedTypeStrictNull.ts, 32, 7))
|
||||
|
||||
] = await Promise.all([
|
||||
>Promise.all : Symbol(PromiseConstructor.all, Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --))
|
||||
@@ -150,71 +159,71 @@ async function main() {
|
||||
>all : Symbol(PromiseConstructor.all, Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --))
|
||||
|
||||
MaybePromise(1),
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 24, 54), Decl(awaitedTypeStrictNull.ts, 21, 32))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 27, 54), Decl(awaitedTypeStrictNull.ts, 24, 69))
|
||||
|
||||
MaybePromise('2'),
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 24, 54), Decl(awaitedTypeStrictNull.ts, 21, 32))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 27, 54), Decl(awaitedTypeStrictNull.ts, 24, 69))
|
||||
|
||||
MaybePromise(true),
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 24, 54), Decl(awaitedTypeStrictNull.ts, 21, 32))
|
||||
>MaybePromise : Symbol(MaybePromise, Decl(awaitedTypeStrictNull.ts, 27, 54), Decl(awaitedTypeStrictNull.ts, 24, 69))
|
||||
|
||||
])
|
||||
}
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/45924
|
||||
class Api<D = {}> {
|
||||
>Api : Symbol(Api, Decl(awaitedTypeStrictNull.ts, 38, 1))
|
||||
>D : Symbol(D, Decl(awaitedTypeStrictNull.ts, 41, 10))
|
||||
>Api : Symbol(Api, Decl(awaitedTypeStrictNull.ts, 41, 1))
|
||||
>D : Symbol(D, Decl(awaitedTypeStrictNull.ts, 44, 10))
|
||||
|
||||
// Should result in `Promise<T>` instead of `Promise<Awaited<T>>`.
|
||||
async post<T = D>() { return this.request<T>(); }
|
||||
>post : Symbol(Api.post, Decl(awaitedTypeStrictNull.ts, 41, 19))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 43, 12))
|
||||
>D : Symbol(D, Decl(awaitedTypeStrictNull.ts, 41, 10))
|
||||
>this.request : Symbol(Api.request, Decl(awaitedTypeStrictNull.ts, 43, 50))
|
||||
>this : Symbol(Api, Decl(awaitedTypeStrictNull.ts, 38, 1))
|
||||
>request : Symbol(Api.request, Decl(awaitedTypeStrictNull.ts, 43, 50))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 43, 12))
|
||||
>post : Symbol(Api.post, Decl(awaitedTypeStrictNull.ts, 44, 19))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 46, 12))
|
||||
>D : Symbol(D, Decl(awaitedTypeStrictNull.ts, 44, 10))
|
||||
>this.request : Symbol(Api.request, Decl(awaitedTypeStrictNull.ts, 46, 50))
|
||||
>this : Symbol(Api, Decl(awaitedTypeStrictNull.ts, 41, 1))
|
||||
>request : Symbol(Api.request, Decl(awaitedTypeStrictNull.ts, 46, 50))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 46, 12))
|
||||
|
||||
async request<D>(): Promise<D> { throw new Error(); }
|
||||
>request : Symbol(Api.request, Decl(awaitedTypeStrictNull.ts, 43, 50))
|
||||
>D : Symbol(D, Decl(awaitedTypeStrictNull.ts, 44, 15))
|
||||
>request : Symbol(Api.request, Decl(awaitedTypeStrictNull.ts, 46, 50))
|
||||
>D : Symbol(D, Decl(awaitedTypeStrictNull.ts, 47, 15))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>D : Symbol(D, Decl(awaitedTypeStrictNull.ts, 44, 15))
|
||||
>D : Symbol(D, Decl(awaitedTypeStrictNull.ts, 47, 15))
|
||||
>Error : Symbol(Error, Decl(lib.es5.d.ts, --, --), Decl(lib.es5.d.ts, --, --))
|
||||
}
|
||||
|
||||
declare const api: Api;
|
||||
>api : Symbol(api, Decl(awaitedTypeStrictNull.ts, 47, 13))
|
||||
>Api : Symbol(Api, Decl(awaitedTypeStrictNull.ts, 38, 1))
|
||||
>api : Symbol(api, Decl(awaitedTypeStrictNull.ts, 50, 13))
|
||||
>Api : Symbol(Api, Decl(awaitedTypeStrictNull.ts, 41, 1))
|
||||
|
||||
interface Obj { x: number }
|
||||
>Obj : Symbol(Obj, Decl(awaitedTypeStrictNull.ts, 47, 23))
|
||||
>x : Symbol(Obj.x, Decl(awaitedTypeStrictNull.ts, 48, 15))
|
||||
>Obj : Symbol(Obj, Decl(awaitedTypeStrictNull.ts, 50, 23))
|
||||
>x : Symbol(Obj.x, Decl(awaitedTypeStrictNull.ts, 51, 15))
|
||||
|
||||
async function fn<T>(): Promise<T extends object ? { [K in keyof T]: Obj } : Obj> {
|
||||
>fn : Symbol(fn, Decl(awaitedTypeStrictNull.ts, 48, 27))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 50, 18))
|
||||
>fn : Symbol(fn, Decl(awaitedTypeStrictNull.ts, 51, 27))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 53, 18))
|
||||
>Promise : Symbol(Promise, Decl(lib.es5.d.ts, --, --), Decl(lib.es2015.iterable.d.ts, --, --), Decl(lib.es2015.promise.d.ts, --, --), Decl(lib.es2015.symbol.wellknown.d.ts, --, --), Decl(lib.es2018.promise.d.ts, --, --))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 50, 18))
|
||||
>K : Symbol(K, Decl(awaitedTypeStrictNull.ts, 50, 54))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 50, 18))
|
||||
>Obj : Symbol(Obj, Decl(awaitedTypeStrictNull.ts, 47, 23))
|
||||
>Obj : Symbol(Obj, Decl(awaitedTypeStrictNull.ts, 47, 23))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 53, 18))
|
||||
>K : Symbol(K, Decl(awaitedTypeStrictNull.ts, 53, 54))
|
||||
>T : Symbol(T, Decl(awaitedTypeStrictNull.ts, 53, 18))
|
||||
>Obj : Symbol(Obj, Decl(awaitedTypeStrictNull.ts, 50, 23))
|
||||
>Obj : Symbol(Obj, Decl(awaitedTypeStrictNull.ts, 50, 23))
|
||||
|
||||
// Per #45924, this was failing due to incorrect inference both above and here.
|
||||
// Should not error.
|
||||
return api.post();
|
||||
>api.post : Symbol(Api.post, Decl(awaitedTypeStrictNull.ts, 41, 19))
|
||||
>api : Symbol(api, Decl(awaitedTypeStrictNull.ts, 47, 13))
|
||||
>post : Symbol(Api.post, Decl(awaitedTypeStrictNull.ts, 41, 19))
|
||||
>api.post : Symbol(Api.post, Decl(awaitedTypeStrictNull.ts, 44, 19))
|
||||
>api : Symbol(api, Decl(awaitedTypeStrictNull.ts, 50, 13))
|
||||
>post : Symbol(Api.post, Decl(awaitedTypeStrictNull.ts, 44, 19))
|
||||
}
|
||||
|
||||
// helps with tests where '.types' just prints out the type alias name
|
||||
type _Expect<TActual extends TExpected, TExpected> = TActual;
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedTypeStrictNull.ts, 54, 1))
|
||||
>TActual : Symbol(TActual, Decl(awaitedTypeStrictNull.ts, 57, 13))
|
||||
>TExpected : Symbol(TExpected, Decl(awaitedTypeStrictNull.ts, 57, 39))
|
||||
>TExpected : Symbol(TExpected, Decl(awaitedTypeStrictNull.ts, 57, 39))
|
||||
>TActual : Symbol(TActual, Decl(awaitedTypeStrictNull.ts, 57, 13))
|
||||
>_Expect : Symbol(_Expect, Decl(awaitedTypeStrictNull.ts, 57, 1))
|
||||
>TActual : Symbol(TActual, Decl(awaitedTypeStrictNull.ts, 60, 13))
|
||||
>TExpected : Symbol(TExpected, Decl(awaitedTypeStrictNull.ts, 60, 39))
|
||||
>TExpected : Symbol(TExpected, Decl(awaitedTypeStrictNull.ts, 60, 39))
|
||||
>TActual : Symbol(TActual, Decl(awaitedTypeStrictNull.ts, 60, 13))
|
||||
|
||||
|
||||
@@ -75,6 +75,14 @@ interface BadPromise2 { then(cb: (value: BadPromise1) => void): void; }
|
||||
type T17 = Awaited<BadPromise1>; // error
|
||||
>T17 : any
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
>T18 : number
|
||||
>then : (cb: (value: number, other: {}) => void) => any
|
||||
>cb : (value: number, other: {}) => void
|
||||
>value : number
|
||||
>other : {}
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
>MaybePromise : MaybePromise<T>
|
||||
@@ -105,9 +113,9 @@ async function main() {
|
||||
] = await Promise.all([
|
||||
>await Promise.all([ MaybePromise(1), MaybePromise('2'), MaybePromise(true), ]) : [number, string, boolean]
|
||||
>Promise.all([ MaybePromise(1), MaybePromise('2'), MaybePromise(true), ]) : Promise<[number, string, boolean]>
|
||||
>Promise.all : { <T>(values: Iterable<T | PromiseLike<T>>): Promise<Awaited<T>[]>; <T extends readonly unknown[] | []>(values: T): Promise<{ -readonly [P in keyof T]: Awaited<T[P]>; }>; }
|
||||
>Promise.all : { <T>(values: Iterable<T | PromiseLike<T>>): Promise<Awaited<T>[]>; <T extends [] | readonly unknown[]>(values: T): Promise<{ -readonly [P in keyof T]: Awaited<T[P]>; }>; }
|
||||
>Promise : PromiseConstructor
|
||||
>all : { <T>(values: Iterable<T | PromiseLike<T>>): Promise<Awaited<T>[]>; <T extends readonly unknown[] | []>(values: T): Promise<{ -readonly [P in keyof T]: Awaited<T[P]>; }>; }
|
||||
>all : { <T>(values: Iterable<T | PromiseLike<T>>): Promise<Awaited<T>[]>; <T extends [] | readonly unknown[]>(values: T): Promise<{ -readonly [P in keyof T]: Awaited<T[P]>; }>; }
|
||||
>[ MaybePromise(1), MaybePromise('2'), MaybePromise(true), ] : [number | Promise<1> | PromiseLike<1>, string | Promise<"2"> | PromiseLike<"2">, MaybePromise<true>]
|
||||
|
||||
MaybePromise(1),
|
||||
|
||||
@@ -24,6 +24,9 @@ interface BadPromise1 { then(cb: (value: BadPromise2) => void): void; }
|
||||
interface BadPromise2 { then(cb: (value: BadPromise1) => void): void; }
|
||||
type T17 = Awaited<BadPromise1>; // error
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
declare function MaybePromise<T>(value: T): MaybePromise<T>;
|
||||
|
||||
@@ -24,6 +24,9 @@ interface BadPromise1 { then(cb: (value: BadPromise2) => void): void; }
|
||||
interface BadPromise2 { then(cb: (value: BadPromise1) => void): void; }
|
||||
type T17 = Awaited<BadPromise1>; // error
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/46934
|
||||
type T18 = Awaited<{ then(cb: (value: number, other: { }) => void)}>; // number
|
||||
|
||||
// https://github.com/microsoft/TypeScript/issues/33562
|
||||
type MaybePromise<T> = T | Promise<T> | PromiseLike<T>
|
||||
declare function MaybePromise<T>(value: T): MaybePromise<T>;
|
||||
|
||||
Reference in New Issue
Block a user