mirror of
https://github.com/microsoft/TypeScript.git
synced 2026-02-20 01:54:20 -06:00
Add additional tests for typeguard for class or object property
This commit is contained in:
parent
b1acce0e5f
commit
8899d5f056
@ -0,0 +1,37 @@
|
||||
tests/cases/conformance/expressions/typeGuards/typeGuardsOnClassProperty.ts(14,71): error TS2339: Property 'join' does not exist on type 'string | string[]'.
|
||||
tests/cases/conformance/expressions/typeGuards/typeGuardsOnClassProperty.ts(26,44): error TS2339: Property 'toLowerCase' does not exist on type 'string | number'.
|
||||
|
||||
|
||||
==== tests/cases/conformance/expressions/typeGuards/typeGuardsOnClassProperty.ts (2 errors) ====
|
||||
// Note that type guards affect types of variables and parameters only and
|
||||
// have no effect on members of objects such as properties.
|
||||
|
||||
// Note that the class's property must be copied to a local variable for
|
||||
// the type guard to have an affect
|
||||
class D {
|
||||
data: string | string[];
|
||||
getData() {
|
||||
var data = this.data;
|
||||
return typeof data === "string" ? data : data.join(" ");
|
||||
}
|
||||
|
||||
getData1() {
|
||||
return typeof this.data === "string" ? this.data : this. data.join(" ");
|
||||
~~~~
|
||||
!!! error TS2339: Property 'join' does not exist on type 'string | string[]'.
|
||||
}
|
||||
}
|
||||
|
||||
var o: {
|
||||
prop1: number|string;
|
||||
prop2: boolean|string;
|
||||
} = {
|
||||
prop1: "string" ,
|
||||
prop2: true
|
||||
}
|
||||
|
||||
if (typeof o.prop1 === "string" && o.prop1.toLowerCase()) {}
|
||||
~~~~~~~~~~~
|
||||
!!! error TS2339: Property 'toLowerCase' does not exist on type 'string | number'.
|
||||
var prop1 = o.prop1;
|
||||
if (typeof prop1 === "string" && prop1.toLocaleLowerCase()) { }
|
||||
54
tests/baselines/reference/typeGuardsOnClassProperty.js
Normal file
54
tests/baselines/reference/typeGuardsOnClassProperty.js
Normal file
@ -0,0 +1,54 @@
|
||||
//// [typeGuardsOnClassProperty.ts]
|
||||
// Note that type guards affect types of variables and parameters only and
|
||||
// have no effect on members of objects such as properties.
|
||||
|
||||
// Note that the class's property must be copied to a local variable for
|
||||
// the type guard to have an affect
|
||||
class D {
|
||||
data: string | string[];
|
||||
getData() {
|
||||
var data = this.data;
|
||||
return typeof data === "string" ? data : data.join(" ");
|
||||
}
|
||||
|
||||
getData1() {
|
||||
return typeof this.data === "string" ? this.data : this. data.join(" ");
|
||||
}
|
||||
}
|
||||
|
||||
var o: {
|
||||
prop1: number|string;
|
||||
prop2: boolean|string;
|
||||
} = {
|
||||
prop1: "string" ,
|
||||
prop2: true
|
||||
}
|
||||
|
||||
if (typeof o.prop1 === "string" && o.prop1.toLowerCase()) {}
|
||||
var prop1 = o.prop1;
|
||||
if (typeof prop1 === "string" && prop1.toLocaleLowerCase()) { }
|
||||
|
||||
//// [typeGuardsOnClassProperty.js]
|
||||
// Note that type guards affect types of variables and parameters only and
|
||||
// have no effect on members of objects such as properties.
|
||||
// Note that the class's property must be copied to a local variable for
|
||||
// the type guard to have an affect
|
||||
var D = (function () {
|
||||
function D() {
|
||||
}
|
||||
D.prototype.getData = function () {
|
||||
var data = this.data;
|
||||
return typeof data === "string" ? data : data.join(" ");
|
||||
};
|
||||
D.prototype.getData1 = function () {
|
||||
return typeof this.data === "string" ? this.data : this.data.join(" ");
|
||||
};
|
||||
return D;
|
||||
})();
|
||||
var o = {
|
||||
prop1: "string",
|
||||
prop2: true
|
||||
};
|
||||
if (typeof o.prop1 === "string" && o.prop1.toLowerCase()) { }
|
||||
var prop1 = o.prop1;
|
||||
if (typeof prop1 === "string" && prop1.toLocaleLowerCase()) { }
|
||||
@ -0,0 +1,28 @@
|
||||
// Note that type guards affect types of variables and parameters only and
|
||||
// have no effect on members of objects such as properties.
|
||||
|
||||
// Note that the class's property must be copied to a local variable for
|
||||
// the type guard to have an affect
|
||||
class D {
|
||||
data: string | string[];
|
||||
getData() {
|
||||
var data = this.data;
|
||||
return typeof data === "string" ? data : data.join(" ");
|
||||
}
|
||||
|
||||
getData1() {
|
||||
return typeof this.data === "string" ? this.data : this. data.join(" ");
|
||||
}
|
||||
}
|
||||
|
||||
var o: {
|
||||
prop1: number|string;
|
||||
prop2: boolean|string;
|
||||
} = {
|
||||
prop1: "string" ,
|
||||
prop2: true
|
||||
}
|
||||
|
||||
if (typeof o.prop1 === "string" && o.prop1.toLowerCase()) {}
|
||||
var prop1 = o.prop1;
|
||||
if (typeof prop1 === "string" && prop1.toLocaleLowerCase()) { }
|
||||
Loading…
x
Reference in New Issue
Block a user