mirror of
https://github.com/nocobase/nocobase
synced 2024-11-16 11:47:35 +00:00
bf1a19426a
* fix: form * refactor: schema-initializer * fix: bug * refactor: schema initializer * refactor: rename * fix: delete SchemaInitializerProvider * refactor: props `insert` to hooks `useSchemaInitializerV2` * fix: bug * refactor: delete `SchemaInitializer.Button` * refactor: delete old SchemaInitializer * fix: bug * fix: workflow * fix: docs * fix: bug * fix: bug * feat: style * fix: remove v2 * fix: visible * fix: bug * fix: item hook * feat: item hook * fix: add search DataBlockInitializer * fix: build bug * fix: style bug * fix: style bug * fix: test bug * fix: test bug * fix: rerender bug * fix: remove menu select * fix: bug * chore: add aria-label for SchemaInitializerButton * refactor: rename name to camel case * fix: menu height bug * fix: build errors * fix: build errors * fix: bug * fix: bug * fix: performance * test: add test for header * fix: sidebar is not refresh (T-2422) * feat(e2e): support to add group page and link page * chore: make sure the page is configurable when using page.goto * test: add tests for menu initializer * fix: imporve code * chore: fix build error * chore: optimize locator of menu item * refactor: rename testid for select * test: make tests passing * fix: make tests passing * chore: upgrade vitest to v0.34.6 * chore: increase timeout of e2e * feat: core * fix: revert schema initializer demos * test: menu, page tabs, page grid, table column * fix: schema button interface * feat: refactor: page tab settings * feat: page settings * fix: dumirc * fix: export CSSVariableProvider * feat: lazy render * fix: form-item * fix: general schema desinger * feat: filter form item settings * refactor: form-v2 schema settings * refactor: form-v1 schema settings * refactor: action schema settings * fix: action bug * fix: form-item bug * fix: types error * docs: schema settings doc * docs: schema settings * feat: schema setting item add name * fix: visible lazy render bug * fix: revert form item filter * fix: test bug * fix: test JSON.parse bug * fix: test bug * fix: improve styling * fix: styling * fix: cleanup * fix: token.borderRadiusSM * fix: bug * test: add tests * fix: style bug * fix: add chart performance * feat: add SchemaDesignerContext * fix: bug * fix: test bug * style: create record action style improve * fix: make test passing * chore: mack tests passing * chore: make tests passing * test: fix tests * style: style revert * fix: bug * fix: data selector * fix: fix tests * fix: fix tests * fix: delete PluginManagerContext * refactor: improve router and add SchemaComponentProvider & CSSVariableProvider to MainComponent * fix: add dn and field builtin to SchemaSettingWrapper * feat: update docs * refactor: application providers * fix: test bug * fix: fix tests * chore: make test passing * feat: update docs * chore: rename collection name * feat: update docs * chore: skip weird test * fix: blockInitializers media to otherBlocks * fix: cancel to skip test * fix: bug * test: add test * refactor: migrate to small files * test: add tests for form block settings * chore: format * fix: add chart scroll bug * refactor: action designer improve * refactor: formitem designer schemaSetting * feat: schemaSettingsManager and schemaInitializerManager addItem and removeItem * test: add tests for color field in creating block * test: add tests for email field in creating block * test: make tests passing * perf: reduce fields number * fix: sub menu bug * test: add tests basic in editing form * test: add tests basic in details form * fix: improve code * test: make tests passing * test(plugin-mock-collections): add color for enum options * refactor: improve code * fix: bug * fix: bug * refactor: convert parameters to destructured object * test: add tests choices * test: add tests media * test: add tests for datetime in creating form * feat(plugin-mock-collection): generate faker time * test: add tests for datetime in editing form * test: add tests for datetime in details form * fix: bug * feat: improve code * test: add tests for relation fields * fix: rename SchemaSettings * fix: type bug * refactor: useDesinger() * fix: bug * fix: bug * fix: build tip * fix: designableState * fix: bug * fix: designable * fix: designable * test: add tests for relation fields * test: add tests for relation fields * test: add tests for relation fields * feat: client api doc * test: add tests for relation fields * test: avoid errors * test: make tests passing * fix: bug * test: make tests passing * test: add tests for advanced fields * test: increase e2e timeout-minutes to 60 * fix: bug * fix: improve code * feat: add schema initailizer component demos * test: make tests passing * fix: schema settings demos * feat: shallowMerge & deepMerge * test: reduce number of tests * test: make tests passing * feat: updates * fix: add Initializer Internal * demos: useSchemaSettingsRender * test: make tests passing * test: make tests passing * fix: improve docs * fix: bug * chore: upgrade dumi theme * test: make tests passing * test: add tests for linkage rules * test: add test for form data templates * test: add tests for default value * test: reduce number of tests * fix: dn.deepMerge * fix: bug * fix: bug * fix: toolbar * fix: docs ssr * test: add tests for system fields * test: add tests for actions * fix: bug * test: add tests for lazy loading of variables * test: make testing more stable * fix: update docs * fix: bug --------- Co-authored-by: Rain <958414905@qq.com> Co-authored-by: chenos <chenlinxh@gmail.com> Co-authored-by: katherinehhh <katherine_15995@163.com>
175 lines
4.3 KiB
TypeScript
175 lines
4.3 KiB
TypeScript
import axios from 'axios';
|
|
import dotenv from 'dotenv';
|
|
import type { CommonOptions } from 'execa';
|
|
import execa from 'execa';
|
|
import _ from 'lodash';
|
|
import net from 'net';
|
|
import fs from 'node:fs';
|
|
import path from 'path';
|
|
|
|
const PORT = process.env.APP_PORT || 20000;
|
|
export const APP_BASE_URL = process.env.APP_BASE_URL || `http://localhost:${PORT}`;
|
|
|
|
export const commonConfig: any = {
|
|
stdio: 'inherit',
|
|
};
|
|
|
|
export const runCommand = (command, argv, options: any = {}) => {
|
|
return execa(command, argv, {
|
|
shell: true,
|
|
stdio: 'inherit',
|
|
..._.omit(options, 'force'),
|
|
env: {
|
|
...process.env,
|
|
},
|
|
});
|
|
};
|
|
|
|
/**
|
|
* 检查端口是否被占用
|
|
* @param port
|
|
* @returns
|
|
*/
|
|
function checkPort(port) {
|
|
return new Promise((resolve, reject) => {
|
|
const socket = net.createConnection(port, '127.0.0.1');
|
|
|
|
socket.on('connect', () => {
|
|
socket.destroy();
|
|
resolve(true); // 端口可用
|
|
});
|
|
|
|
socket.on('error', (error) => {
|
|
resolve(false); // 端口被占用或不可访问
|
|
});
|
|
});
|
|
}
|
|
|
|
/**
|
|
* 检查服务是否启动成功
|
|
*/
|
|
const checkServer = async (duration = 1000, max = 60 * 10) => {
|
|
return new Promise((resolve, reject) => {
|
|
let count = 0;
|
|
const timer = setInterval(async () => {
|
|
if (count++ > max) {
|
|
clearInterval(timer);
|
|
return reject(new Error('Server start timeout.'));
|
|
}
|
|
|
|
if (!(await checkPort(PORT))) {
|
|
return;
|
|
}
|
|
|
|
axios
|
|
.get(`${APP_BASE_URL}/api/__health_check`)
|
|
.then((response) => {
|
|
if (response.status === 200) {
|
|
clearInterval(timer);
|
|
resolve(true);
|
|
}
|
|
})
|
|
.catch((error) => {
|
|
console.error('Request error:', error.message);
|
|
});
|
|
}, duration);
|
|
});
|
|
};
|
|
|
|
/**
|
|
* 检查 UI 是否启动成功
|
|
* @param duration
|
|
*/
|
|
const checkUI = async (duration = 1000, max = 60 * 10) => {
|
|
return new Promise((resolve, reject) => {
|
|
let count = 0;
|
|
const timer = setInterval(async () => {
|
|
if (count++ > max) {
|
|
clearInterval(timer);
|
|
return reject(new Error('UI start timeout.'));
|
|
}
|
|
|
|
axios
|
|
.get(`${APP_BASE_URL}/__umi/api/bundle-status`)
|
|
.then((response) => {
|
|
if (response.data.bundleStatus.done) {
|
|
clearInterval(timer);
|
|
resolve(true);
|
|
}
|
|
})
|
|
.catch((error) => {
|
|
console.error('Request error:', error.message);
|
|
});
|
|
}, duration);
|
|
});
|
|
};
|
|
|
|
export const runNocoBase = async (
|
|
options?: CommonOptions<any> & {
|
|
/**
|
|
* 是否强制启动服务
|
|
*/
|
|
force?: boolean;
|
|
signal?: AbortSignal;
|
|
},
|
|
clearDatabase = false,
|
|
) => {
|
|
// 用于存放 playwright 自动生成的相关的文件
|
|
if (!fs.existsSync('playwright')) {
|
|
fs.mkdirSync('playwright');
|
|
}
|
|
|
|
if (!fs.existsSync('.env.e2e') && fs.existsSync('.env.e2e.example')) {
|
|
const env = fs.readFileSync('.env.e2e.example');
|
|
fs.writeFileSync('.env.e2e', env);
|
|
}
|
|
|
|
if (!fs.existsSync('.env.e2e')) {
|
|
throw new Error('Please create .env.e2e file first!');
|
|
}
|
|
|
|
dotenv.config({ path: path.resolve(process.cwd(), '.env.e2e') });
|
|
|
|
if (process.env.APP_BASE_URL && !options?.force) {
|
|
console.log('APP_BASE_URL is setting, skip starting server.');
|
|
return { awaitForNocoBase: () => {} };
|
|
}
|
|
|
|
const awaitForNocoBase = async () => {
|
|
if (process.env.CI) {
|
|
console.log('check server...');
|
|
await checkServer();
|
|
} else {
|
|
console.log('check server...');
|
|
await checkServer();
|
|
console.log('server is ready, check UI...');
|
|
await checkUI();
|
|
console.log('UI is ready.');
|
|
}
|
|
};
|
|
|
|
if (process.env.CI) {
|
|
console.log('yarn nocobase install');
|
|
await runCommand('yarn', ['nocobase', 'install'], options);
|
|
console.log(`yarn start -d -p ${PORT}`);
|
|
await runCommand('yarn', ['start', '-d', `-p ${PORT}`], options);
|
|
return { awaitForNocoBase };
|
|
}
|
|
|
|
if (clearDatabase) {
|
|
// 加上 -f 会清空数据库
|
|
console.log('yarn nocobase install -f');
|
|
await runCommand('yarn', ['nocobase', 'install', '-f'], options);
|
|
}
|
|
|
|
if (await checkPort(PORT)) {
|
|
console.log('Server is running, skip starting server.');
|
|
return { awaitForNocoBase };
|
|
}
|
|
|
|
console.log('starting server...');
|
|
const { cancel, kill } = runCommand('yarn', ['dev', `-p ${PORT}`, ...process.argv.slice(2)], options);
|
|
|
|
return { cancel, kill, awaitForNocoBase };
|
|
};
|