File: tsxAttributeResolution3.types

package info (click to toggle)
node-typescript 3.3.3333-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 324,548 kB
  • sloc: makefile: 6; sh: 3
file content (115 lines) | stat: -rw-r--r-- 2,205 bytes parent folder | download | duplicates (5)
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
=== tests/cases/conformance/jsx/file.tsx ===
declare module JSX {
	interface Element { }
	interface IntrinsicElements {
		test1: Attribs1;
>test1 : Attribs1
	}
}
interface Attribs1 {
	x: string;
>x : string

	y?: number;
>y : number

	z?: string;
>z : string
}

// OK
var obj1 = { x: 'foo' };
>obj1 : { x: string; }
>{ x: 'foo' } : { x: string; }
>x : string
>'foo' : "foo"

<test1 {...obj1} />
><test1 {...obj1} /> : JSX.Element
>test1 : any
>obj1 : { x: string; }

// Error, x is not string
var obj2 = { x: 32 };
>obj2 : { x: number; }
>{ x: 32 } : { x: number; }
>x : number
>32 : 32

<test1 {...obj2} />
><test1 {...obj2} /> : JSX.Element
>test1 : any
>obj2 : { x: number; }

// Error, x is missing
var obj3 = { y: 32 };
>obj3 : { y: number; }
>{ y: 32 } : { y: number; }
>y : number
>32 : 32

<test1 {...obj3} />
><test1 {...obj3} /> : JSX.Element
>test1 : any
>obj3 : { y: number; }

// OK
var obj4 = { x: 32, y: 32 };
>obj4 : { x: number; y: number; }
>{ x: 32, y: 32 } : { x: number; y: number; }
>x : number
>32 : 32
>y : number
>32 : 32

<test1 {...obj4} x="ok" />
><test1 {...obj4} x="ok" /> : JSX.Element
>test1 : any
>obj4 : { x: number; y: number; }
>x : string

// Error
var obj5 = { x: 32, y: 32 };
>obj5 : { x: number; y: number; }
>{ x: 32, y: 32 } : { x: number; y: number; }
>x : number
>32 : 32
>y : number
>32 : 32

<test1 x="ok" {...obj5} />
><test1 x="ok" {...obj5} /> : JSX.Element
>test1 : any
>x : string
>obj5 : { x: number; y: number; }

// Ok
var obj6 = { x: 'ok', y: 32, extra: 100 };
>obj6 : { x: string; y: number; extra: number; }
>{ x: 'ok', y: 32, extra: 100 } : { x: string; y: number; extra: number; }
>x : string
>'ok' : "ok"
>y : number
>32 : 32
>extra : number
>100 : 100

<test1 {...obj6} />
><test1 {...obj6} /> : JSX.Element
>test1 : any
>obj6 : { x: string; y: number; extra: number; }

// OK (spread override)
var obj7 = { x: 'foo' };
>obj7 : { x: string; }
>{ x: 'foo' } : { x: string; }
>x : string
>'foo' : "foo"

<test1 x={32} {...obj7} />
><test1 x={32} {...obj7} /> : JSX.Element
>test1 : any
>x : number
>32 : 32
>obj7 : { x: string; }