Skip to content

Commit 686b275

Browse files
committed
chore(word-cloud): 主要完善词云图的测试用例
1 parent b5df7c9 commit 686b275

File tree

4 files changed

+166
-81
lines changed

4 files changed

+166
-81
lines changed

__tests__/unit/utils/transform/word-cloud-spec.ts

+127-21
Original file line numberDiff line numberDiff line change
@@ -1,16 +1,22 @@
11
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'>;
37

48
const { View } = DataSet;
59
const options = {
610
type: 'tag-cloud',
711
fields: ['text', 'value'],
12+
font: 'Impact',
813
fontSize: 10,
914
fontWeight: 'bold',
15+
rotate: 90,
16+
padding: 2,
1017
size: [800, 800],
11-
padding: 0,
18+
spiral: 'archimedean',
1219
timeInterval: 5000,
13-
rotate: 90,
1420
};
1521
const data = ['Hello', 'world', 'normally', 'you', 'want', 'more', 'words', 'than', 'this'].map((d) => {
1622
return {
@@ -20,6 +26,22 @@ const data = ['Hello', 'world', 'normally', 'you', 'want', 'more', 'words', 'tha
2026
};
2127
});
2228

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+
2345
describe('word-cloud', () => {
2446
it('with data-set', () => {
2547
const dv = new View();
@@ -41,38 +63,31 @@ describe('word-cloud', () => {
4163

4264
it('default', () => {
4365
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]);
5267
});
5368

5469
it('callback', () => {
55-
const common = (row: DataItem) => {
70+
const common = (row: Row) => {
5671
expect(typeof row.text).toBe('string');
5772
expect(typeof row.value).toBe('number');
5873
};
59-
const font = (row: DataItem) => {
74+
const font = (row: Row) => {
6075
common(row);
6176
return 'font-test';
6277
};
63-
const fontWeight = (row: DataItem): any => {
78+
const fontWeight = (row: Row): any => {
6479
common(row);
6580
return 'fontWeight-test';
6681
};
67-
const fontSize = (row: DataItem) => {
82+
const fontSize = (row: Row) => {
6883
common(row);
6984
return 11;
7085
};
71-
const rotate = (row: DataItem) => {
86+
const rotate = (row: Row) => {
7287
common(row);
7388
return 22;
7489
};
75-
const padding = (row: DataItem) => {
90+
const padding = (row: Row) => {
7691
common(row);
7792
return 33;
7893
};
@@ -94,14 +109,105 @@ describe('word-cloud', () => {
94109
spiral,
95110
});
96111
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);
101113
expect(firstRow.font).toBe('font-test');
102114
expect(firstRow.weight).toBe('fontWeight-test');
103115
expect(firstRow.size).toBe(11);
104116
expect(firstRow.rotate).toBe(22);
105117
expect(firstRow.padding).toBe(33);
106118
});
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+
});
107213
});

src/plots/word-cloud/types.ts

+9-6
Original file line numberDiff line numberDiff line change
@@ -3,11 +3,14 @@ import { Options } from '../../types';
33

44
type FontWeight = ShapeAttrs['fontWeight'];
55

6-
export interface DataItem {
6+
interface Row {
77
/** 文本内容 */
88
text: string;
99
/** 该文本所占权重 */
1010
value: number;
11+
}
12+
13+
export type DataItem = Row & {
1114
/** 字体 */
1215
font?: string;
1316
/** 字体样式 */
@@ -30,21 +33,21 @@ export interface DataItem {
3033
x?: number;
3134
/** y 轴坐标 */
3235
y?: number;
33-
}
36+
};
3437

3538
/** 词云字体样式 */
3639
interface WordStyle {
3740
/** 词云的字体, 当为函数时,其参数是一个经过处理之后的数据元素的值 */
38-
readonly fontFamily?: string | ((row: DataItem) => string);
41+
readonly fontFamily?: string | ((row: Row) => string);
3942
/** 设置字体的粗细, 当为函数时,其参数是一个经过处理之后的数据元素的值 */
40-
readonly fontWeight?: FontWeight | ((row: DataItem) => FontWeight);
43+
readonly fontWeight?: FontWeight | ((row: Row) => FontWeight);
4144
/**
4245
* 每个单词所占的盒子的内边距,默认为 1。 越大单词之间的间隔越大。
4346
* 当为函数时,其参数是一个经过处理之后的数据元素的值
4447
*/
45-
readonly padding?: number | ((row: DataItem) => number);
48+
readonly padding?: number | ((row: Row) => number);
4649
/** 字体的大小范围,当为函数时,其参数是一个经过处理之后的数据元素的值 */
47-
readonly fontSize?: [number, number] | ((row: DataItem) => number);
50+
readonly fontSize?: [number, number] | ((row: Row) => number);
4851
/** 旋转的最小角度和最大角度 默认 [0, 90] */
4952
readonly rotation?: [number, number];
5053
/** 旋转实际的步数,越大可能旋转角度越小, 默认是 2 */

src/plots/word-cloud/utils.ts

-8
Original file line numberDiff line numberDiff line change
@@ -208,10 +208,6 @@ function resolveRotate(options: WordCloudOptions) {
208208
* @param numbers
209209
*/
210210
function min(numbers: number[]) {
211-
if (numbers.length === 0) {
212-
throw new Error('min requires at least one data point');
213-
}
214-
215211
return Math.min(...numbers);
216212
}
217213

@@ -221,9 +217,5 @@ function min(numbers: number[]) {
221217
* @param numbers
222218
*/
223219
function max(numbers: number[]) {
224-
if (numbers.length === 0) {
225-
throw new Error('min requires at least one data point');
226-
}
227-
228220
return Math.max(...numbers);
229221
}

0 commit comments

Comments
 (0)