1
1
import DataSet from '@antv/data-set' ;
2
- import { DataItem , wordCloud } from '../../../../src/utils/transform/word-cloud' ;
2
+ import { DataItem } from '../../../../src/plots/word-cloud/types' ;
3
+ import { processImageMask } from '../../../../src/plots/word-cloud/utils' ;
4
+ import { wordCloud , transform } from '../../../../src/utils/transform/word-cloud' ;
5
+
6
+ type Row = Pick < DataItem , 'text' | 'value' > ;
3
7
4
8
const { View } = DataSet ;
5
9
const options = {
6
10
type : 'tag-cloud' ,
7
11
fields : [ 'text' , 'value' ] ,
12
+ font : 'Impact' ,
8
13
fontSize : 10 ,
9
14
fontWeight : 'bold' ,
15
+ rotate : 90 ,
16
+ padding : 2 ,
10
17
size : [ 800 , 800 ] ,
11
- padding : 0 ,
18
+ spiral : 'archimedean' ,
12
19
timeInterval : 5000 ,
13
- rotate : 90 ,
14
20
} ;
15
21
const data = [ 'Hello' , 'world' , 'normally' , 'you' , 'want' , 'more' , 'words' , 'than' , 'this' ] . map ( ( d ) => {
16
22
return {
@@ -20,6 +26,22 @@ const data = ['Hello', 'world', 'normally', 'you', 'want', 'more', 'words', 'tha
20
26
} ;
21
27
} ) ;
22
28
29
+ function basicCommon ( v : DataItem ) {
30
+ expect ( v . hasText ) . toBe ( true ) ;
31
+ expect ( typeof v . text ) . toBe ( 'string' ) ;
32
+ expect ( typeof v . value ) . toBe ( 'number' ) ;
33
+ expect ( typeof v . font ) . toBe ( 'string' ) ;
34
+ expect ( typeof v . style ) . toBe ( 'string' ) ;
35
+ expect ( typeof v . weight === 'number' || typeof v . weight === 'string' ) . toBe ( true ) ;
36
+ expect ( typeof v . rotate ) . toBe ( 'number' ) ;
37
+ expect ( typeof v . size ) . toBe ( 'number' ) ;
38
+ expect ( typeof v . padding ) . toBe ( 'number' ) ;
39
+ expect ( typeof v . width ) . toBe ( 'number' ) ;
40
+ expect ( typeof v . height ) . toBe ( 'number' ) ;
41
+ expect ( typeof v . x ) . toBe ( 'number' ) ;
42
+ expect ( typeof v . y ) . toBe ( 'number' ) ;
43
+ }
44
+
23
45
describe ( 'word-cloud' , ( ) => {
24
46
it ( 'with data-set' , ( ) => {
25
47
const dv = new View ( ) ;
@@ -41,38 +63,31 @@ describe('word-cloud', () => {
41
63
42
64
it ( 'default' , ( ) => {
43
65
const result = wordCloud ( data ) ;
44
- const firstRow = result [ 0 ] ;
45
-
46
- expect ( firstRow . hasText ) . toBe ( true ) ;
47
- expect ( typeof firstRow . x ) . toBe ( 'number' ) ;
48
- expect ( typeof firstRow . y ) . toBe ( 'number' ) ;
49
- expect ( typeof firstRow . text ) . toBe ( 'string' ) ;
50
- expect ( typeof firstRow . size ) . toBe ( 'number' ) ;
51
- expect ( typeof firstRow . font ) . toBe ( 'string' ) ;
66
+ basicCommon ( result [ 0 ] ) ;
52
67
} ) ;
53
68
54
69
it ( 'callback' , ( ) => {
55
- const common = ( row : DataItem ) => {
70
+ const common = ( row : Row ) => {
56
71
expect ( typeof row . text ) . toBe ( 'string' ) ;
57
72
expect ( typeof row . value ) . toBe ( 'number' ) ;
58
73
} ;
59
- const font = ( row : DataItem ) => {
74
+ const font = ( row : Row ) => {
60
75
common ( row ) ;
61
76
return 'font-test' ;
62
77
} ;
63
- const fontWeight = ( row : DataItem ) : any => {
78
+ const fontWeight = ( row : Row ) : any => {
64
79
common ( row ) ;
65
80
return 'fontWeight-test' ;
66
81
} ;
67
- const fontSize = ( row : DataItem ) => {
82
+ const fontSize = ( row : Row ) => {
68
83
common ( row ) ;
69
84
return 11 ;
70
85
} ;
71
- const rotate = ( row : DataItem ) => {
86
+ const rotate = ( row : Row ) => {
72
87
common ( row ) ;
73
88
return 22 ;
74
89
} ;
75
- const padding = ( row : DataItem ) => {
90
+ const padding = ( row : Row ) => {
76
91
common ( row ) ;
77
92
return 33 ;
78
93
} ;
@@ -94,14 +109,105 @@ describe('word-cloud', () => {
94
109
spiral,
95
110
} ) ;
96
111
const firstRow = result [ 0 ] ;
97
- expect ( firstRow . hasText ) . toBe ( true ) ;
98
- expect ( typeof firstRow . x ) . toBe ( 'number' ) ;
99
- expect ( typeof firstRow . y ) . toBe ( 'number' ) ;
100
- expect ( typeof firstRow . text ) . toBe ( 'string' ) ;
112
+ basicCommon ( firstRow ) ;
101
113
expect ( firstRow . font ) . toBe ( 'font-test' ) ;
102
114
expect ( firstRow . weight ) . toBe ( 'fontWeight-test' ) ;
103
115
expect ( firstRow . size ) . toBe ( 11 ) ;
104
116
expect ( firstRow . rotate ) . toBe ( 22 ) ;
105
117
expect ( firstRow . padding ) . toBe ( 33 ) ;
106
118
} ) ;
119
+
120
+ it ( 'data is empty' , ( ) => {
121
+ const result = wordCloud ( [ ] ) ;
122
+ expect ( result . length ) . toBe ( 2 ) ;
123
+ } ) ;
124
+
125
+ it ( 'image mask' , async ( ) => {
126
+ const base64 =
127
+ '' ;
128
+
129
+ const img = await processImageMask ( base64 ) ;
130
+ const result = wordCloud ( data , { imageMask : img } ) ;
131
+ basicCommon ( result [ 0 ] ) ;
132
+ } ) ;
133
+
134
+ it ( 'spiral is rectangular' , ( ) => {
135
+ const result = wordCloud ( data , { spiral : 'rectangular' } ) ;
136
+ basicCommon ( result [ 0 ] ) ;
137
+ } ) ;
138
+ } ) ;
139
+
140
+ describe ( 'transform' , ( ) => {
141
+ it ( 'default' , ( ) => {
142
+ const result = transform ( data , {
143
+ fields : [ 'text' , 'value' ] ,
144
+ size : [ 800 , 800 ] ,
145
+ } ) ;
146
+ basicCommon ( result [ 0 ] ) ;
147
+ } ) ;
148
+
149
+ it ( 'error of fields' , ( ) => {
150
+ expect ( ( ) => {
151
+ transform ( data , {
152
+ fields : [ null , null ] ,
153
+ size : [ 800 , 800 ] ,
154
+ } ) ;
155
+ } ) . toThrow ( ) ;
156
+ } ) ;
157
+
158
+ it ( 'fields is not exit' , ( ) => {
159
+ const result = transform ( data , {
160
+ fields : [ 'a' , 'b' ] ,
161
+ size : [ 800 , 800 ] ,
162
+ } ) ;
163
+
164
+ expect ( result [ 0 ] . text ) . toBe ( undefined ) ;
165
+ expect ( result [ 0 ] . value ) . toBe ( undefined ) ;
166
+ } ) ;
167
+
168
+ it ( 'image mask with size is 0' , async ( ) => {
169
+ const base64 =
170
+ '' ;
171
+
172
+ const img = await processImageMask ( base64 ) ;
173
+ const result = transform ( data , {
174
+ fields : [ 'text' , 'value' ] ,
175
+ size : [ 0 , 0 ] ,
176
+ imageMask : img ,
177
+ } ) ;
178
+
179
+ // 画布大小为 0 时,返回的数组应为空数组,但该实现中,
180
+ // 最终会往返回的数组中 push 进两个元素,所以最终长度为 2。
181
+ expect ( result . length ) . toBe ( 2 ) ;
182
+ } ) ;
183
+
184
+ it ( 'timeInterval is 0' , ( ) => {
185
+ const result = transform ( data , {
186
+ fields : [ 'text' , 'value' ] ,
187
+ size : [ 800 , 800 ] ,
188
+ timeInterval : 0 ,
189
+ } ) ;
190
+
191
+ // 时间间隔为 0 ,也就是说不给程序运行的时间,
192
+ // 所以最终返回的是空数据,只包含两个占位符数据。
193
+ expect ( result . length ) . toBe ( 2 ) ;
194
+ } ) ;
195
+
196
+ it ( 'padding is 0' , ( ) => {
197
+ const result = transform ( data , {
198
+ fields : [ 'text' , 'value' ] ,
199
+ size : [ 800 , 800 ] ,
200
+ padding : 0 ,
201
+ } ) ;
202
+ basicCommon ( result [ 0 ] ) ;
203
+ } ) ;
204
+
205
+ it ( 'rotate is 0' , ( ) => {
206
+ const result = transform ( data , {
207
+ fields : [ 'text' , 'value' ] ,
208
+ size : [ 800 , 800 ] ,
209
+ rotate : 0 ,
210
+ } ) ;
211
+ basicCommon ( result [ 0 ] ) ;
212
+ } ) ;
107
213
} ) ;
0 commit comments