@nocobase/test 0.21.0-alpha.1 → 0.21.0-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/e2e/e2eUtils.d.ts +2 -0
- package/es/e2e/index.mjs +4 -2
- package/es/index.mjs +3 -0
- package/lib/e2e/defineConfig.js +0 -1
- package/lib/e2e/e2eUtils.d.ts +2 -0
- package/lib/e2e/e2eUtils.js +4 -1
- package/lib/server/mockServer.js +3 -0
- package/package.json +6 -3
- package/vitest.mjs +170 -70
package/es/e2e/e2eUtils.d.ts
CHANGED
|
@@ -5,6 +5,7 @@ export { defineConfig };
|
|
|
5
5
|
export interface CollectionSetting {
|
|
6
6
|
name: string;
|
|
7
7
|
title?: string;
|
|
8
|
+
titleField?: string;
|
|
8
9
|
/**
|
|
9
10
|
* @default 'general'
|
|
10
11
|
*/
|
|
@@ -47,6 +48,7 @@ export interface CollectionSetting {
|
|
|
47
48
|
* @default false
|
|
48
49
|
*/
|
|
49
50
|
inherit?: boolean;
|
|
51
|
+
inherits?: string[];
|
|
50
52
|
category?: any[];
|
|
51
53
|
hidden?: boolean;
|
|
52
54
|
description?: string;
|
package/es/e2e/index.mjs
CHANGED
|
@@ -17,7 +17,6 @@ const defineConfig = (config) => {
|
|
|
17
17
|
fullyParallel: false,
|
|
18
18
|
// Fail the build on CI if you accidentally left test.only in the source code.
|
|
19
19
|
forbidOnly: !!process.env.CI,
|
|
20
|
-
// Retry on CI only.
|
|
21
20
|
retries: 2,
|
|
22
21
|
// Opt out of parallel tests on CI.
|
|
23
22
|
// workers: process.env.CI ? 1 : undefined,
|
|
@@ -353,7 +352,10 @@ const deleteCollections = async (collectionNames) => {
|
|
|
353
352
|
const headers = getHeaders(state);
|
|
354
353
|
const params = collectionNames.map((name) => `filterByTk[]=${name}`).join("&");
|
|
355
354
|
const result = await api.post(`/api/collections:destroy?${params}`, {
|
|
356
|
-
headers
|
|
355
|
+
headers,
|
|
356
|
+
params: {
|
|
357
|
+
cascade: true
|
|
358
|
+
}
|
|
357
359
|
});
|
|
358
360
|
if (!result.ok()) {
|
|
359
361
|
throw new Error(await result.text());
|
package/es/index.mjs
CHANGED
|
@@ -85,6 +85,9 @@ class MockServer extends Application {
|
|
|
85
85
|
if (filterByTk) {
|
|
86
86
|
url += `/${filterByTk}`;
|
|
87
87
|
}
|
|
88
|
+
if (restParams.filter) {
|
|
89
|
+
restParams.filter = JSON.stringify(restParams.filter);
|
|
90
|
+
}
|
|
88
91
|
const queryString = qs.stringify(restParams, { arrayFormat: "brackets" });
|
|
89
92
|
let request;
|
|
90
93
|
switch (method2) {
|
package/lib/e2e/defineConfig.js
CHANGED
|
@@ -36,7 +36,6 @@ const defineConfig = /* @__PURE__ */ __name((config) => {
|
|
|
36
36
|
fullyParallel: false,
|
|
37
37
|
// Fail the build on CI if you accidentally left test.only in the source code.
|
|
38
38
|
forbidOnly: !!process.env.CI,
|
|
39
|
-
// Retry on CI only.
|
|
40
39
|
retries: 2,
|
|
41
40
|
// Opt out of parallel tests on CI.
|
|
42
41
|
// workers: process.env.CI ? 1 : undefined,
|
package/lib/e2e/e2eUtils.d.ts
CHANGED
|
@@ -5,6 +5,7 @@ export { defineConfig };
|
|
|
5
5
|
export interface CollectionSetting {
|
|
6
6
|
name: string;
|
|
7
7
|
title?: string;
|
|
8
|
+
titleField?: string;
|
|
8
9
|
/**
|
|
9
10
|
* @default 'general'
|
|
10
11
|
*/
|
|
@@ -47,6 +48,7 @@ export interface CollectionSetting {
|
|
|
47
48
|
* @default false
|
|
48
49
|
*/
|
|
49
50
|
inherit?: boolean;
|
|
51
|
+
inherits?: string[];
|
|
50
52
|
category?: any[];
|
|
51
53
|
hidden?: boolean;
|
|
52
54
|
description?: string;
|
package/lib/e2e/e2eUtils.js
CHANGED
|
@@ -348,7 +348,10 @@ const deleteCollections = /* @__PURE__ */ __name(async (collectionNames) => {
|
|
|
348
348
|
const headers = getHeaders(state);
|
|
349
349
|
const params = collectionNames.map((name) => `filterByTk[]=${name}`).join("&");
|
|
350
350
|
const result = await api.post(`/api/collections:destroy?${params}`, {
|
|
351
|
-
headers
|
|
351
|
+
headers,
|
|
352
|
+
params: {
|
|
353
|
+
cascade: true
|
|
354
|
+
}
|
|
352
355
|
});
|
|
353
356
|
if (!result.ok()) {
|
|
354
357
|
throw new Error(await result.text());
|
package/lib/server/mockServer.js
CHANGED
|
@@ -118,6 +118,9 @@ const _MockServer = class _MockServer extends import_server.Application {
|
|
|
118
118
|
if (filterByTk) {
|
|
119
119
|
url += `/${filterByTk}`;
|
|
120
120
|
}
|
|
121
|
+
if (restParams.filter) {
|
|
122
|
+
restParams.filter = JSON.stringify(restParams.filter);
|
|
123
|
+
}
|
|
121
124
|
const queryString = import_qs.default.stringify(restParams, { arrayFormat: "brackets" });
|
|
122
125
|
let request;
|
|
123
126
|
switch (method2) {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nocobase/test",
|
|
3
|
-
"version": "0.21.0-alpha.
|
|
3
|
+
"version": "0.21.0-alpha.3",
|
|
4
4
|
"main": "lib/index.js",
|
|
5
5
|
"module": "./src/index.ts",
|
|
6
6
|
"types": "./lib/index.d.ts",
|
|
@@ -41,7 +41,7 @@
|
|
|
41
41
|
},
|
|
42
42
|
"dependencies": {
|
|
43
43
|
"@faker-js/faker": "8.1.0",
|
|
44
|
-
"@nocobase/server": "0.21.0-alpha.
|
|
44
|
+
"@nocobase/server": "0.21.0-alpha.3",
|
|
45
45
|
"@playwright/test": "^1.42.1",
|
|
46
46
|
"@testing-library/jest-dom": "^6.4.2",
|
|
47
47
|
"@testing-library/react": "^14.0.0",
|
|
@@ -49,6 +49,8 @@
|
|
|
49
49
|
"@testing-library/user-event": "^14.4.3",
|
|
50
50
|
"@types/supertest": "^2.0.11",
|
|
51
51
|
"@vitejs/plugin-react": "^4.0.0",
|
|
52
|
+
"@vitest/coverage-istanbul": "^1.4.0",
|
|
53
|
+
"@vitest/coverage-v8": "^1.4.0",
|
|
52
54
|
"jsdom": "^16.0.0",
|
|
53
55
|
"jsdom-worker": "^0.3.0",
|
|
54
56
|
"mariadb": "^2.5.6",
|
|
@@ -60,7 +62,8 @@
|
|
|
60
62
|
"supertest": "^6.1.6",
|
|
61
63
|
"vite": "^5.0.0",
|
|
62
64
|
"vitest": "^1.4.0",
|
|
65
|
+
"vitest-dom": "^0.1.1",
|
|
63
66
|
"ws": "^8.13.0"
|
|
64
67
|
},
|
|
65
|
-
"gitHead": "
|
|
68
|
+
"gitHead": "f7276aff14063a2cf825191a0c83aeacde05a912"
|
|
66
69
|
}
|
package/vitest.mjs
CHANGED
|
@@ -1,8 +1,12 @@
|
|
|
1
|
+
/// <reference types="vitest" />
|
|
2
|
+
|
|
1
3
|
import react from '@vitejs/plugin-react';
|
|
2
4
|
import fs from 'fs';
|
|
3
5
|
import path, { resolve } from 'path';
|
|
4
6
|
import { URL } from 'url';
|
|
5
|
-
import { defineConfig as vitestConfig } from 'vitest/config';
|
|
7
|
+
import { mergeConfig, defineConfig as vitestConfig } from 'vitest/config';
|
|
8
|
+
|
|
9
|
+
const CORE_CLIENT_PACKAGES = ['sdk', 'client'];
|
|
6
10
|
|
|
7
11
|
const __dirname = new URL('.', import.meta.url).pathname;
|
|
8
12
|
|
|
@@ -44,75 +48,171 @@ function tsConfigPathsToAlias() {
|
|
|
44
48
|
];
|
|
45
49
|
}
|
|
46
50
|
|
|
47
|
-
|
|
48
|
-
return vitestConfig(
|
|
49
|
-
process.
|
|
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
|
-
|
|
51
|
+
const defineCommonConfig = () => {
|
|
52
|
+
return vitestConfig({
|
|
53
|
+
root: process.cwd(),
|
|
54
|
+
resolve: {
|
|
55
|
+
mainFields: ['module'],
|
|
56
|
+
},
|
|
57
|
+
test: {
|
|
58
|
+
globals: true,
|
|
59
|
+
alias: tsConfigPathsToAlias(),
|
|
60
|
+
testTimeout: 300000,
|
|
61
|
+
hookTimeout: 300000,
|
|
62
|
+
silent: !!process.env.GITHUB_ACTIONS,
|
|
63
|
+
include: ['packages/**/src/**/__tests__/**/*.test.{ts,tsx}'],
|
|
64
|
+
exclude: [
|
|
65
|
+
'**/demos/**',
|
|
66
|
+
'**/node_modules/**',
|
|
67
|
+
'**/dist/**',
|
|
68
|
+
'**/lib/**',
|
|
69
|
+
'**/es/**',
|
|
70
|
+
'**/.dumi/**',
|
|
71
|
+
'**/e2e/**',
|
|
72
|
+
'**/__e2e__/**',
|
|
73
|
+
'**/{vitest,commitlint}.config.*',
|
|
74
|
+
],
|
|
75
|
+
watchExclude: [
|
|
76
|
+
'**/node_modules/**',
|
|
77
|
+
'**/dist/**',
|
|
78
|
+
'**/lib/**',
|
|
79
|
+
'**/es/**',
|
|
80
|
+
'**/.dumi/**',
|
|
81
|
+
'**/e2e/**',
|
|
82
|
+
'**/__e2e__/**',
|
|
83
|
+
'**/{vitest,commitlint}.config.*',
|
|
84
|
+
],
|
|
85
|
+
coverage: {
|
|
86
|
+
provider: 'istanbul',
|
|
87
|
+
include: ['packages/**/src/**/*.{ts,tsx}'],
|
|
88
|
+
exclude: [
|
|
89
|
+
'**/demos/**',
|
|
90
|
+
'**/swagger/**',
|
|
91
|
+
'**/.dumi/**',
|
|
92
|
+
'**/.umi/**',
|
|
93
|
+
'**/.plugins/**',
|
|
94
|
+
'**/lib/**',
|
|
95
|
+
'**/__tests__/**',
|
|
96
|
+
'**/e2e/**',
|
|
97
|
+
'**/client.js',
|
|
98
|
+
'**/server.js',
|
|
99
|
+
'**/*.d.ts',
|
|
100
|
+
],
|
|
101
|
+
},
|
|
102
|
+
},
|
|
103
|
+
});
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
function getExclude(isServer) {
|
|
107
|
+
return [
|
|
108
|
+
`packages/core/${isServer ? '' : '!'}(${CORE_CLIENT_PACKAGES.join('|')})/**/*`,
|
|
109
|
+
`packages/**/src/${isServer ? 'client' : 'server'}/**/*`,
|
|
110
|
+
];
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
const defineServerConfig = () => {
|
|
114
|
+
return vitestConfig({
|
|
115
|
+
test: {
|
|
116
|
+
setupFiles: resolve(__dirname, './setup/server.ts'),
|
|
117
|
+
exclude: getExclude(true),
|
|
118
|
+
},
|
|
119
|
+
coverage: {
|
|
120
|
+
exclude: getExclude(true),
|
|
121
|
+
},
|
|
122
|
+
});
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
const defineClientConfig = () => {
|
|
126
|
+
return vitestConfig({
|
|
127
|
+
plugins: [react()],
|
|
128
|
+
define: {
|
|
129
|
+
'process.env.__TEST__': true,
|
|
130
|
+
'process.env.__E2E__': false,
|
|
131
|
+
global: 'window',
|
|
132
|
+
},
|
|
133
|
+
test: {
|
|
134
|
+
environment: 'jsdom',
|
|
135
|
+
css: false,
|
|
136
|
+
setupFiles: resolve(__dirname, './setup/client.ts'),
|
|
137
|
+
server: {
|
|
138
|
+
deps: {
|
|
139
|
+
inline: ['@juggle/resize-observer', 'clsx'],
|
|
116
140
|
},
|
|
141
|
+
},
|
|
142
|
+
exclude: getExclude(false),
|
|
143
|
+
coverage: {
|
|
144
|
+
exclude: getExclude(false),
|
|
145
|
+
},
|
|
146
|
+
},
|
|
147
|
+
});
|
|
148
|
+
};
|
|
149
|
+
|
|
150
|
+
export const getFilterInclude = (isServer, isCoverage) => {
|
|
151
|
+
let filterFileOrDir = process.argv.slice(2).find((arg) => !arg.startsWith('-'));
|
|
152
|
+
if (!filterFileOrDir) return;
|
|
153
|
+
const absPath = path.join(process.cwd(), filterFileOrDir);
|
|
154
|
+
const isDir = fs.existsSync(absPath) && fs.statSync(absPath).isDirectory();
|
|
155
|
+
// 如果是文件,则只测试当前文件
|
|
156
|
+
if (!isDir) {
|
|
157
|
+
return [filterFileOrDir];
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
const suffix = isCoverage ? `**/*.{ts,tsx}` : `**/__tests__/**/*.{test,spec}.{ts,tsx}`;
|
|
161
|
+
|
|
162
|
+
// 判断是否为包目录,如果不是包目录,则只测试当前目录
|
|
163
|
+
const isPackage = fs.existsSync(path.join(absPath, 'package.json'));
|
|
164
|
+
if (!isPackage) {
|
|
165
|
+
return [`${filterFileOrDir}/${suffix}`];
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
// 判断是否为 core 包目录,不分 client 和 server
|
|
169
|
+
const isCore = absPath.includes('packages/core');
|
|
170
|
+
if (isCore) {
|
|
171
|
+
return [`${filterFileOrDir}/src/${suffix}`];
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
// 插件目录,区分 client 和 server
|
|
175
|
+
return [`${filterFileOrDir}/src/${isServer ? 'server' : 'client'}/${suffix}`];
|
|
176
|
+
};
|
|
177
|
+
|
|
178
|
+
export const getReportsDirectory = (isServer) => {
|
|
179
|
+
let filterFileOrDir = process.argv.slice(2).find((arg) => !arg.startsWith('-'));
|
|
180
|
+
if (!filterFileOrDir) return;
|
|
181
|
+
const isPackage = fs.existsSync(path.join(process.cwd(), filterFileOrDir, 'package.json'));
|
|
182
|
+
if (isPackage) {
|
|
183
|
+
let reportsDirectory = `./storage/coverage/${filterFileOrDir.replace('packages/', '')}`;
|
|
184
|
+
|
|
185
|
+
const isCore = filterFileOrDir.includes('packages/core');
|
|
186
|
+
|
|
187
|
+
if (!isCore) {
|
|
188
|
+
reportsDirectory = `${reportsDirectory}/${isServer ? 'server' : 'client'}`;
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
return reportsDirectory;
|
|
192
|
+
}
|
|
193
|
+
};
|
|
194
|
+
|
|
195
|
+
export const defineConfig = () => {
|
|
196
|
+
const isServer = process.env.TEST_ENV === 'server-side';
|
|
197
|
+
const config = vitestConfig(
|
|
198
|
+
mergeConfig(defineCommonConfig(), isServer ? defineServerConfig() : defineClientConfig()),
|
|
117
199
|
);
|
|
200
|
+
|
|
201
|
+
const isCoverage = process.argv.includes('--coverage');
|
|
202
|
+
if (!isCoverage) {
|
|
203
|
+
return config;
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
const filterInclude = getFilterInclude(isServer);
|
|
207
|
+
if (filterInclude) {
|
|
208
|
+
config.test.include = getFilterInclude(isServer);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
config.test.coverage.include = getFilterInclude(isServer, true);
|
|
212
|
+
const reportsDirectory = getReportsDirectory(isServer);
|
|
213
|
+
if (reportsDirectory) {
|
|
214
|
+
config.test.coverage.reportsDirectory = reportsDirectory;
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
return config;
|
|
118
218
|
};
|