1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232
|
=== tests/cases/conformance/types/typeRelationships/assignmentCompatibility/constructSignatureAssignabilityInInheritance3.ts ===
// checking subtype relations for function types as it relates to contextual signature instantiation
// error cases
module Errors {
>Errors : typeof Errors
class Base { foo: string; }
>Base : Base
>foo : string
class Derived extends Base { bar: string; }
>Derived : Derived
>Base : Base
>bar : string
class Derived2 extends Derived { baz: string; }
>Derived2 : Derived2
>Derived : Derived
>baz : string
class OtherDerived extends Base { bing: string; }
>OtherDerived : OtherDerived
>Base : Base
>bing : string
module WithNonGenericSignaturesInBaseType {
// base type with non-generic call signatures
interface A {
a2: new (x: number) => string[];
>a2 : new (x: number) => string[]
>x : number
a7: new (x: (arg: Base) => Derived) => (r: Base) => Derived2;
>a7 : new (x: (arg: Base) => Derived) => (r: Base) => Derived2
>x : (arg: Base) => Derived
>arg : Base
>r : Base
a8: new (x: (arg: Base) => Derived, y: (arg2: Base) => Derived) => (r: Base) => Derived;
>a8 : new (x: (arg: Base) => Derived, y: (arg2: Base) => Derived) => (r: Base) => Derived
>x : (arg: Base) => Derived
>arg : Base
>y : (arg2: Base) => Derived
>arg2 : Base
>r : Base
a10: new (...x: Base[]) => Base;
>a10 : new (...x: Base[]) => Base
>x : Base[]
a11: new (x: { foo: string }, y: { foo: string; bar: string }) => Base;
>a11 : new (x: { foo: string; }, y: { foo: string; bar: string; }) => Base
>x : { foo: string; }
>foo : string
>y : { foo: string; bar: string; }
>foo : string
>bar : string
a12: new (x: Array<Base>, y: Array<Derived2>) => Array<Derived>;
>a12 : new (x: Base[], y: Derived2[]) => Derived[]
>x : Base[]
>y : Derived2[]
a14: {
>a14 : { new (x: number): number[]; new (x: string): string[]; }
new (x: number): number[];
>x : number
new (x: string): string[];
>x : string
};
a15: new (x: { a: string; b: number }) => number;
>a15 : new (x: { a: string; b: number; }) => number
>x : { a: string; b: number; }
>a : string
>b : number
a16: {
>a16 : { new (x: { new (a: number): number; new (a?: number): number; }): number[]; new (x: { new (a: boolean): boolean; new (a?: boolean): boolean; }): boolean[]; }
// type of parameter is overload set which means we can't do inference based on this type
new (x: {
>x : { new (a: number): number; new (a?: number): number; }
new (a: number): number;
>a : number
new (a?: number): number;
>a : number
}): number[];
new (x: {
>x : { new (a: boolean): boolean; new (a?: boolean): boolean; }
new (a: boolean): boolean;
>a : boolean
new (a?: boolean): boolean;
>a : boolean
}): boolean[];
};
}
interface I extends A {
a2: new <T, U>(x: T) => U[]; // error, contextual signature instantiation doesn't relate return types so U is {}, not a subtype of string[]
>a2 : new <T, U>(x: T) => U[]
>x : T
}
interface I2<T, U> extends A {
a2: new (x: T) => U[]; // error, no contextual signature instantiation since I2.a2 is not generic
>a2 : new (x: T) => U[]
>x : T
}
interface I3 extends A {
// valid, no inferences for V so it defaults to Derived2
a7: new <T extends Base, U extends Derived, V extends Derived2>(x: (arg: T) => U) => (r: T) => V;
>a7 : new <T extends Base, U extends Derived, V extends Derived2>(x: (arg: T) => U) => (r: T) => V
>x : (arg: T) => U
>arg : T
>r : T
}
interface I4 extends A {
a8: new <T extends Base, U extends Derived>(x: (arg: T) => U, y: (arg2: { foo: number; }) => U) => (r: T) => U; // error, type mismatch
>a8 : new <T extends Base, U extends Derived>(x: (arg: T) => U, y: (arg2: { foo: number; }) => U) => (r: T) => U
>x : (arg: T) => U
>arg : T
>y : (arg2: { foo: number; }) => U
>arg2 : { foo: number; }
>foo : number
>r : T
}
interface I4B extends A {
a10: new <T extends Derived>(...x: T[]) => T; // valid, parameter covariance works even after contextual signature instantiation
>a10 : new <T extends Derived>(...x: T[]) => T
>x : T[]
}
interface I4C extends A {
a11: new <T extends Derived>(x: T, y: T) => T; // valid, even though x is a Base, parameter covariance works even after contextual signature instantiation
>a11 : new <T extends Derived>(x: T, y: T) => T
>x : T
>y : T
}
interface I4E extends A {
a12: new <T extends Array<Derived2>>(x: Array<Base>, y: Array<Base>) => T; // valid, no inferences for T, defaults to Array<Derived2>
>a12 : new <T extends Derived2[]>(x: Base[], y: Base[]) => T
>x : Base[]
>y : Base[]
}
interface I6 extends A {
a15: new <T>(x: { a: T; b: T }) => T; // error, T is {} which isn't an acceptable return type
>a15 : new <T>(x: { a: T; b: T; }) => T
>x : { a: T; b: T; }
>a : T
>b : T
}
interface I7 extends A {
a15: new <T extends Base>(x: { a: T; b: T }) => number; // error, T defaults to Base, which is not compatible with number or string
>a15 : new <T extends Base>(x: { a: T; b: T; }) => number
>x : { a: T; b: T; }
>a : T
>b : T
}
interface I8 extends A {
// ok, we relate each signature of a16 to b16, and within that, we make inferences from two different signatures in the respective A.a16 signature
a16: new <T>(x: new (a: T) => T) => T[];
>a16 : new <T>(x: new (a: T) => T) => T[]
>x : new (a: T) => T
>a : T
}
}
module WithGenericSignaturesInBaseType {
// base type has generic call signature
interface B {
a2: new <T>(x: T) => T[];
>a2 : new <T>(x: T) => T[]
>x : T
}
interface I6 extends B {
a2: new <T>(x: T) => string[]; // error
>a2 : new <T>(x: T) => string[]
>x : T
}
// base type has generic call signature
interface C {
a2: new <T>(x: T) => string[];
>a2 : new <T>(x: T) => string[]
>x : T
}
interface I7 extends C {
a2: new <T>(x: T) => T[]; // error
>a2 : new <T>(x: T) => T[]
>x : T
}
// base type has a generic call signature with overloads
interface D {
a14: {
>a14 : { new <T extends Derived>(x: T): number[]; new <U extends Base>(x: U): number[]; }
new <T extends Derived>(x: T): number[];
>x : T
new <U extends Base>(x: U): number[];
>x : U
};
}
interface I8 extends D {
a14: new <T extends Base>(x: T) => number[];
>a14 : new <T extends Base>(x: T) => number[]
>x : T
}
}
}
|