8515f7e2b5
* Also always test for isWriteAccess and isDefinition
50 lines
2.2 KiB
TypeScript
50 lines
2.2 KiB
TypeScript
/// <reference path='fourslash.ts'/>
|
|
|
|
////interface A {
|
|
//// a: number;
|
|
//// [|{| "isWriteAccess": true, "isDefinition": true |}common|]: string;
|
|
////}
|
|
////
|
|
////interface B {
|
|
//// b: number;
|
|
//// [|{| "isWriteAccess": true, "isDefinition": true |}common|]: number;
|
|
////}
|
|
////
|
|
////// Assignment
|
|
////var v1: A | B = { a: 0, [|{| "isWriteAccess": true, "isDefinition": true, "type": "string" |}common|]: "" };
|
|
////var v2: A | B = { b: 0, [|{| "isWriteAccess": true, "isDefinition": true, "type": "number" |}common|]: 3 };
|
|
////
|
|
////// Function call
|
|
////function consumer(f: A | B) { }
|
|
////consumer({ a: 0, b: 0, [|{| "isWriteAccess": true, "isDefinition": true, "type": "number" |}common|]: 1 });
|
|
////
|
|
////// Type cast
|
|
////var c = <A | B> { [|{| "isWriteAccess": true, "isDefinition": true, "type": "number" |}common|]: 0, b: 0 };
|
|
////
|
|
////// Array literal
|
|
////var ar: Array<A|B> = [{ a: 0, [|{| "isWriteAccess": true, "isDefinition": true, "type": "string" |}common|]: "" }, { b: 0, [|{| "isWriteAccess": true, "isDefinition": true, "type": "number" |}common|]: 0 }];
|
|
////
|
|
////// Nested object literal
|
|
////var ob: { aorb: A|B } = { aorb: { b: 0, [|{| "isWriteAccess": true, "isDefinition": true, "type": "number" |}common|]: 0 } };
|
|
////
|
|
////// Widened type
|
|
////var w: A|B = { a:0, [|{| "isWriteAccess": true, "isDefinition": true, "type": "undefined" |}common|]: undefined };
|
|
////
|
|
////// Untped -- should not be included
|
|
////var u1 = { a: 0, b: 0, common: "" };
|
|
////var u2 = { b: 0, common: 0 };
|
|
|
|
const all = test.ranges();
|
|
const [aCommon, bCommon, ...unionRefs] = all;
|
|
verify.referenceGroups(aCommon, [{ definition: "(property) A.common: string", ranges: [aCommon, ...unionRefs] }]);
|
|
verify.referenceGroups(bCommon, [{ definition: "(property) B.common: number", ranges: [bCommon, ...unionRefs] }]);
|
|
|
|
unionRefs.forEach((unionRef, idx) => {
|
|
const type = unionRef.marker.data.type;
|
|
verify.referenceGroups(unionRef, [
|
|
{ definition: "(property) A.common: string", ranges: all.filter(x => x !== bCommon && x !== unionRef) },
|
|
{ definition: "(property) B.common: number", ranges: [bCommon] },
|
|
{ definition: `(property) common: ${type}`, ranges: [unionRef] }
|
|
]);
|
|
});
|