TypeScript/tests/baselines/reference/recursiveTypeComparison.types

45 lines
2.3 KiB
Plaintext
Raw Normal View History

2014-11-17 19:46:02 +01:00
=== tests/cases/compiler/recursiveTypeComparison.ts ===
// Before fix this would take an exceeding long time to complete (#1170)
interface Observable<T> {
2015-04-13 23:01:57 +02:00
>Observable : Observable<T>, Symbol(Observable, Decl(recursiveTypeComparison.ts, 0, 0))
>T : T, Symbol(T, Decl(recursiveTypeComparison.ts, 2, 21))
2014-11-17 19:46:02 +01:00
// This member can't be of type T, Property<T>, or Observable<anything but T>
needThisOne: Observable<T>;
2015-04-13 23:01:57 +02:00
>needThisOne : Observable<T>, Symbol(needThisOne, Decl(recursiveTypeComparison.ts, 2, 25))
>Observable : Observable<T>, Symbol(Observable, Decl(recursiveTypeComparison.ts, 0, 0))
>T : T, Symbol(T, Decl(recursiveTypeComparison.ts, 2, 21))
2014-11-17 19:46:02 +01:00
// Add more to make it slower
expo1: Property<T[]>; // 0.31 seconds in check
2015-04-13 23:01:57 +02:00
>expo1 : Property<T[]>, Symbol(expo1, Decl(recursiveTypeComparison.ts, 4, 31))
>Property : Property<T>, Symbol(Property, Decl(recursiveTypeComparison.ts, 9, 1))
>T : T, Symbol(T, Decl(recursiveTypeComparison.ts, 2, 21))
2014-11-17 19:46:02 +01:00
expo2: Property<T[]>; // 3.11 seconds
2015-04-13 23:01:57 +02:00
>expo2 : Property<T[]>, Symbol(expo2, Decl(recursiveTypeComparison.ts, 6, 25))
>Property : Property<T>, Symbol(Property, Decl(recursiveTypeComparison.ts, 9, 1))
>T : T, Symbol(T, Decl(recursiveTypeComparison.ts, 2, 21))
2014-11-17 19:46:02 +01:00
expo3: Property<T[]>; // 82.28 seconds
2015-04-13 23:01:57 +02:00
>expo3 : Property<T[]>, Symbol(expo3, Decl(recursiveTypeComparison.ts, 7, 25))
>Property : Property<T>, Symbol(Property, Decl(recursiveTypeComparison.ts, 9, 1))
>T : T, Symbol(T, Decl(recursiveTypeComparison.ts, 2, 21))
2014-11-17 19:46:02 +01:00
}
interface Property<T> extends Observable<T> { }
2015-04-13 23:01:57 +02:00
>Property : Property<T>, Symbol(Property, Decl(recursiveTypeComparison.ts, 9, 1))
>T : T, Symbol(T, Decl(recursiveTypeComparison.ts, 10, 19))
>Observable : Observable<T>, Symbol(Observable, Decl(recursiveTypeComparison.ts, 0, 0))
>T : T, Symbol(T, Decl(recursiveTypeComparison.ts, 10, 19))
2014-11-17 19:46:02 +01:00
var p: Observable<{}>;
2015-04-13 23:01:57 +02:00
>p : Observable<{}>, Symbol(p, Decl(recursiveTypeComparison.ts, 12, 3))
>Observable : Observable<T>, Symbol(Observable, Decl(recursiveTypeComparison.ts, 0, 0))
2014-11-17 19:46:02 +01:00
var stuck: Property<number> = p;
2015-04-13 23:01:57 +02:00
>stuck : Property<number>, Symbol(stuck, Decl(recursiveTypeComparison.ts, 13, 3))
>Property : Property<T>, Symbol(Property, Decl(recursiveTypeComparison.ts, 9, 1))
>p : Observable<{}>, Symbol(p, Decl(recursiveTypeComparison.ts, 12, 3))
2014-11-17 19:46:02 +01:00