@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.
@@ -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) {
@@ -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,
@@ -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;
@@ -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());
@@ -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.1",
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.1",
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": "afd2f3d1341b85ea9daa7b2667dd4ace1fafb7ff"
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
- export const defineConfig = (config = {}) => {
48
- return vitestConfig(
49
- process.env.TEST_ENV === 'server-side'
50
- ? {
51
- root: process.cwd(),
52
- resolve: {
53
- mainFields: ['module'],
54
- },
55
- test: {
56
- globals: true,
57
- setupFiles: resolve(__dirname, './setup/server.ts'),
58
- alias: tsConfigPathsToAlias(),
59
- include: ['packages/**/__tests__/**/*.test.ts'],
60
- exclude: [
61
- '**/node_modules/**',
62
- '**/dist/**',
63
- '**/lib/**',
64
- '**/es/**',
65
- '**/e2e/**',
66
- '**/__e2e__/**',
67
- '**/{vitest,commitlint}.config.*',
68
- 'packages/**/{dumi-theme-nocobase,sdk,client}/**/__tests__/**/*.{test,spec}.{ts,tsx}',
69
- ],
70
- testTimeout: 300000,
71
- hookTimeout: 300000,
72
- // bail: 1,
73
- // 在 GitHub Actions 中不输出日志
74
- silent: !!process.env.GITHUB_ACTIONS,
75
- // poolOptions: {
76
- // threads: {
77
- // singleThread: process.env.SINGLE_THREAD == 'false' ? false : true,
78
- // },
79
- // },
80
- },
81
- }
82
- : {
83
- plugins: [react()],
84
- resolve: {
85
- mainFields: ['module'],
86
- },
87
- define: {
88
- 'process.env.__TEST__': true,
89
- 'process.env.__E2E__': false,
90
- },
91
- test: {
92
- globals: true,
93
- setupFiles: resolve(__dirname, './setup/client.ts'),
94
- environment: 'jsdom',
95
- css: false,
96
- alias: tsConfigPathsToAlias(),
97
- include: ['packages/**/{dumi-theme-nocobase,sdk,client}/**/__tests__/**/*.{test,spec}.{ts,tsx}'],
98
- exclude: [
99
- '**/node_modules/**',
100
- '**/dist/**',
101
- '**/lib/**',
102
- '**/es/**',
103
- '**/e2e/**',
104
- '**/__e2e__/**',
105
- '**/{vitest,commitlint}.config.*',
106
- ],
107
- testTimeout: 300000,
108
- // 在 GitHub Actions 中不输出日志
109
- silent: !!process.env.GITHUB_ACTIONS,
110
- server: {
111
- deps: {
112
- inline: ['@juggle/resize-observer', 'clsx'],
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
  };