-
Notifications
You must be signed in to change notification settings - Fork 114
Expand file tree
/
Copy pathDatabaseTableSelect.test.tsx
More file actions
144 lines (121 loc) · 5.69 KB
/
DatabaseTableSelect.test.tsx
File metadata and controls
144 lines (121 loc) · 5.69 KB
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
import React from 'react';
import { fireEvent, render, waitFor } from '@testing-library/react';
import { DatabaseSelect, TableSelect, DatabaseTableSelect } from './DatabaseTableSelect';
import { Datasource } from '../../data/CHDatasource';
const defaultDB = 'default';
const testTable = 'samples';
describe('DatabaseSelect', () => {
it('should render with empty options', async () => {
const mockDs = {} as Datasource;
mockDs.getDefaultDatabase = jest.fn(() => '');
mockDs.fetchDatabases = jest.fn(() => Promise.resolve([]));
const result = await waitFor(() =>
render(<DatabaseSelect datasource={mockDs} database="" onDatabaseChange={() => {}} />)
);
expect(result.container.firstChild).not.toBeNull();
});
it('should render with valid options', async () => {
const mockDs = {} as Datasource;
mockDs.getDefaultDatabase = jest.fn(() => defaultDB);
mockDs.fetchDatabases = jest.fn(() => Promise.resolve([defaultDB]));
const result = await waitFor(() =>
render(<DatabaseSelect datasource={mockDs} database="default" onDatabaseChange={() => {}} />)
);
expect(result.container.firstChild).not.toBeNull();
expect(result.getByText(defaultDB)).toBeInTheDocument();
});
it('selects a default database when none is provided', async () => {
const mockDs = {} as Datasource;
mockDs.getDefaultDatabase = jest.fn(() => defaultDB);
mockDs.fetchDatabases = jest.fn(() => Promise.resolve([defaultDB]));
const onDatabaseChange = jest.fn();
const result = await waitFor(() =>
render(<DatabaseSelect datasource={mockDs} database="" onDatabaseChange={onDatabaseChange} />)
);
expect(result.container.firstChild).not.toBeNull();
expect(onDatabaseChange).toHaveBeenCalledTimes(1);
expect(onDatabaseChange).toHaveBeenCalledWith(defaultDB);
});
it('should call onDatabaseChange when a database is selected', async () => {
const mockDs = {} as Datasource;
mockDs.getDefaultDatabase = jest.fn(() => defaultDB);
mockDs.fetchDatabases = jest.fn(() => Promise.resolve([defaultDB]));
const onDatabaseChange = jest.fn();
const result = await waitFor(() =>
render(<DatabaseSelect datasource={mockDs} database="other" onDatabaseChange={onDatabaseChange} />)
);
expect(result.container.firstChild).not.toBeNull();
const multiSelect = result.getByRole('combobox');
expect(multiSelect).toBeInTheDocument();
fireEvent.keyDown(multiSelect, { key: 'ArrowDown' }); // "other" db, a custom value
fireEvent.keyDown(multiSelect, { key: 'ArrowDown' }); // "default" db
fireEvent.keyDown(multiSelect, { key: 'Enter' });
expect(onDatabaseChange).toHaveBeenCalledTimes(1);
expect(onDatabaseChange).toHaveBeenCalledWith(defaultDB);
});
});
describe('TableSelect', () => {
it('should render with empty options', async () => {
const mockDs = {} as Datasource;
mockDs.fetchTables = jest.fn(() => Promise.resolve([]));
const result = await waitFor(() =>
render(<TableSelect datasource={mockDs} database="" table="" onTableChange={() => {}} />)
);
expect(result.container.firstChild).not.toBeNull();
});
it('should render with valid options', async () => {
const mockDs = {} as Datasource;
mockDs.fetchTables = jest.fn(() => Promise.resolve([testTable]));
const result = await waitFor(() =>
render(<TableSelect datasource={mockDs} database={defaultDB} table={testTable} onTableChange={() => {}} />)
);
expect(result.container.firstChild).not.toBeNull();
expect(result.getByText(testTable)).toBeInTheDocument();
});
// TODO: this hook is disabled in the component for now
// it('selects a default table when none is provided', async () => {
// const mockDs = {} as Datasource;
// mockDs.fetchTables = jest.fn(() => Promise.resolve([testTable]));
// const onTableChange = jest.fn();
// const result = await waitFor(() => render(<TableSelect datasource={mockDs} database={defaultDB} table="" onTableChange={onTableChange} />));
// expect(result.container.firstChild).not.toBeNull();
// expect(onTableChange).toBeCalledTimes(1);
// expect(onTableChange).toBeCalledWith(testTable);
// });
it('should call onTableChange when a table is selected', async () => {
const mockDs = {} as Datasource;
mockDs.fetchTables = jest.fn(() => Promise.resolve([testTable]));
const onTableChange = jest.fn();
const result = await waitFor(() =>
render(<TableSelect datasource={mockDs} database={defaultDB} table="other" onTableChange={onTableChange} />)
);
expect(result.container.firstChild).not.toBeNull();
const multiSelect = result.getByRole('combobox');
expect(multiSelect).toBeInTheDocument();
fireEvent.keyDown(multiSelect, { key: 'ArrowDown' }); // "other" table, a custom value
fireEvent.keyDown(multiSelect, { key: 'ArrowDown' }); // test table
fireEvent.keyDown(multiSelect, { key: 'Enter' });
expect(onTableChange).toHaveBeenCalledTimes(1);
expect(onTableChange).toHaveBeenCalledWith(testTable);
});
});
describe('DatabaseTableSelect', () => {
it('should render the combined components', async () => {
const mockDs = {} as Datasource;
mockDs.fetchDatabases = jest.fn(() => Promise.resolve([]));
mockDs.fetchTables = jest.fn(() => Promise.resolve([]));
const result = await waitFor(() =>
render(
<DatabaseTableSelect
datasource={mockDs}
database={defaultDB}
onDatabaseChange={() => {}}
table={testTable}
onTableChange={() => {}}
/>
)
);
expect(result.container.firstChild).not.toBeNull();
expect(result.container.firstChild?.childNodes).toHaveLength(2 * 2); // 2 components with a fragment of 2 components
});
});