mirror of
https://github.com/WeBankFinTech/fes.js.git
synced 2025-04-06 03:59:53 +08:00
feat: 合并master
This commit is contained in:
commit
fdfe79e65c
@ -33,7 +33,6 @@
|
|||||||
"@babel/plugin-transform-runtime": "^7.16.4",
|
"@babel/plugin-transform-runtime": "^7.16.4",
|
||||||
"@babel/preset-env": "^7.16.4",
|
"@babel/preset-env": "^7.16.4",
|
||||||
"@babel/preset-typescript": "^7.15.0",
|
"@babel/preset-typescript": "^7.15.0",
|
||||||
"@fesjs/compiler": "^2.0.5",
|
|
||||||
"@fesjs/utils": "^2.0.4",
|
"@fesjs/utils": "^2.0.4",
|
||||||
"@vue/babel-plugin-jsx": "^1.1.1",
|
"@vue/babel-plugin-jsx": "^1.1.1",
|
||||||
"autoprefixer": "^10.2.4",
|
"autoprefixer": "^10.2.4",
|
||||||
@ -59,7 +58,8 @@
|
|||||||
"webpack": "^5.69.0",
|
"webpack": "^5.69.0",
|
||||||
"webpack-bundle-analyzer": "^4.4.0",
|
"webpack-bundle-analyzer": "^4.4.0",
|
||||||
"webpack-chain": "^6.5.1",
|
"webpack-chain": "^6.5.1",
|
||||||
"webpack-dev-server": "^4.8.1"
|
"webpack-dev-server": "^4.8.1",
|
||||||
|
"webpackbar": "^5.0.2"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"@vue/compiler-sfc": "^3.0.5",
|
"@vue/compiler-sfc": "^3.0.5",
|
||||||
|
@ -5,14 +5,11 @@
|
|||||||
|
|
||||||
import { relative } from 'path';
|
import { relative } from 'path';
|
||||||
import { existsSync } from 'fs';
|
import { existsSync } from 'fs';
|
||||||
import { Logger } from '@fesjs/compiler';
|
|
||||||
|
|
||||||
const logger = new Logger('fes:builder-webpack');
|
|
||||||
|
|
||||||
export default function (api) {
|
export default function (api) {
|
||||||
const {
|
const {
|
||||||
paths,
|
paths,
|
||||||
utils: { rimraf },
|
utils: { rimraf, logger },
|
||||||
} = api;
|
} = api;
|
||||||
|
|
||||||
api.registerCommand({
|
api.registerCommand({
|
||||||
@ -38,7 +35,7 @@ export default function (api) {
|
|||||||
// clear output path before exec build
|
// clear output path before exec build
|
||||||
if (process.env.CLEAR_OUTPUT !== 'none') {
|
if (process.env.CLEAR_OUTPUT !== 'none') {
|
||||||
if (paths.absOutputPath && existsSync(paths.absOutputPath)) {
|
if (paths.absOutputPath && existsSync(paths.absOutputPath)) {
|
||||||
logger.debug(`Clear OutputPath: ${paths.absNodeModulesPath}`);
|
logger.info(`Clear OutputPath: ${paths.absOutputPath}`);
|
||||||
rimraf.sync(paths.absOutputPath);
|
rimraf.sync(paths.absOutputPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import WebpackDevServer from 'webpack-dev-server';
|
import WebpackDevServer from 'webpack-dev-server';
|
||||||
import webpack from 'webpack';
|
import webpack from 'webpack';
|
||||||
|
import { chalk } from '@fesjs/utils';
|
||||||
|
|
||||||
export function startDevServer({ webpackConfig, host, port, proxy, https, beforeMiddlewares, afterMiddlewares, customerDevServerConfig }) {
|
export function startDevServer({ webpackConfig, host, port, proxy, https, beforeMiddlewares, afterMiddlewares, customerDevServerConfig }) {
|
||||||
const options = {
|
const options = {
|
||||||
@ -13,9 +14,6 @@ export function startDevServer({ webpackConfig, host, port, proxy, https, before
|
|||||||
port,
|
port,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
devMiddleware: {
|
|
||||||
stats: 'errors-only',
|
|
||||||
},
|
|
||||||
setupMiddlewares(middlewares) {
|
setupMiddlewares(middlewares) {
|
||||||
middlewares.unshift(...beforeMiddlewares);
|
middlewares.unshift(...beforeMiddlewares);
|
||||||
middlewares.push(...afterMiddlewares);
|
middlewares.push(...afterMiddlewares);
|
||||||
@ -33,6 +31,7 @@ export function startDevServer({ webpackConfig, host, port, proxy, https, before
|
|||||||
const compiler = webpack(webpackConfig);
|
const compiler = webpack(webpackConfig);
|
||||||
const server = new WebpackDevServer(options, compiler);
|
const server = new WebpackDevServer(options, compiler);
|
||||||
|
|
||||||
|
console.log(chalk.green('Server: '), chalk.blue(`${options.server}://${options.host}:${options.port}`));
|
||||||
server.startCallback((err) => {
|
server.startCallback((err) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.error(err);
|
console.error(err);
|
||||||
|
@ -1,11 +1,7 @@
|
|||||||
import { Logger } from '@fesjs/compiler';
|
|
||||||
|
|
||||||
const logger = new Logger('fes:builder-webpack');
|
|
||||||
|
|
||||||
export default (api) => {
|
export default (api) => {
|
||||||
const {
|
const {
|
||||||
paths,
|
paths,
|
||||||
utils: { chalk, getPort, getHostName, changePort },
|
utils: { chalk, getPort, getHostName, changePort, logger },
|
||||||
} = api;
|
} = api;
|
||||||
|
|
||||||
let port;
|
let port;
|
||||||
|
@ -56,7 +56,7 @@ export default async function getConfig({ api, cwd, config, env, entry = {}, mod
|
|||||||
const absoluteOutput = join(cwd, config.outputPath || 'dist');
|
const absoluteOutput = join(cwd, config.outputPath || 'dist');
|
||||||
|
|
||||||
webpackConfig.mode(env);
|
webpackConfig.mode(env);
|
||||||
webpackConfig.stats('verbose');
|
webpackConfig.stats('errors-only');
|
||||||
webpackConfig.externals(config.externals || {});
|
webpackConfig.externals(config.externals || {});
|
||||||
webpackConfig.devtool(isDev ? config.devtool || 'cheap-module-source-map' : config.devtool);
|
webpackConfig.devtool(isDev ? config.devtool || 'cheap-module-source-map' : config.devtool);
|
||||||
|
|
||||||
@ -226,6 +226,8 @@ export default async function getConfig({ api, cwd, config, env, entry = {}, mod
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
webpackConfig.plugin('progress').use(require.resolve(require.resolve('webpackbar')));
|
||||||
|
|
||||||
// --------------- define -----------
|
// --------------- define -----------
|
||||||
createDefineWebpackConfig({
|
createDefineWebpackConfig({
|
||||||
config,
|
config,
|
||||||
@ -279,8 +281,13 @@ export default async function getConfig({ api, cwd, config, env, entry = {}, mod
|
|||||||
|
|
||||||
const memo = webpackConfig.toConfig();
|
const memo = webpackConfig.toConfig();
|
||||||
memo.infrastructureLogging = {
|
memo.infrastructureLogging = {
|
||||||
|
level: 'error',
|
||||||
...memo.infrastructureLogging,
|
...memo.infrastructureLogging,
|
||||||
};
|
};
|
||||||
|
memo.watchOptions = {
|
||||||
|
aggregateTimeout: 200,
|
||||||
|
...memo.watchOptions,
|
||||||
|
};
|
||||||
memo.output = {
|
memo.output = {
|
||||||
...memo.output,
|
...memo.output,
|
||||||
assetModuleFilename: 'static/[name][hash:8][ext]',
|
assetModuleFilename: 'static/[name][hash:8][ext]',
|
||||||
|
@ -3,19 +3,10 @@
|
|||||||
* https://github.com/umijs/umi/tree/master/packages/core
|
* https://github.com/umijs/umi/tree/master/packages/core
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
import Config from './config';
|
import Config from './config';
|
||||||
import Logger from './logger';
|
|
||||||
import Service from './service';
|
import Service from './service';
|
||||||
import PluginAPI from './service/pluginAPI';
|
import PluginAPI from './service/pluginAPI';
|
||||||
import { PluginType } from './service/enums';
|
import { PluginType } from './service/enums';
|
||||||
import { isPluginOrPreset } from './service/utils/pluginUtils';
|
import { isPluginOrPreset } from './service/utils/pluginUtils';
|
||||||
|
|
||||||
export {
|
export { Config, Service, PluginAPI, isPluginOrPreset, PluginType };
|
||||||
Config,
|
|
||||||
Service,
|
|
||||||
PluginAPI,
|
|
||||||
isPluginOrPreset,
|
|
||||||
PluginType,
|
|
||||||
Logger
|
|
||||||
};
|
|
||||||
|
@ -1,86 +0,0 @@
|
|||||||
/**
|
|
||||||
* @copy 该文件代码大部分出自 umi,有需要请参考:
|
|
||||||
* https://github.com/umijs/umi/tree/master/packages/core
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { createDebug, chalk } from '@fesjs/utils';
|
|
||||||
import readline from 'readline';
|
|
||||||
|
|
||||||
export default class Logger {
|
|
||||||
LOG = chalk.black.bgBlue('LOG');
|
|
||||||
|
|
||||||
INFO = chalk.black.bgBlue('INFO');
|
|
||||||
|
|
||||||
WARN = chalk.black.bgHex('#faad14')('WARN');
|
|
||||||
|
|
||||||
ERROR = chalk.black.bgRed('ERROR');
|
|
||||||
|
|
||||||
PROFILE = chalk.black.bgCyan('PROFILE');
|
|
||||||
|
|
||||||
constructor(namespace) {
|
|
||||||
// TODO: get namespace filename accounding caller function
|
|
||||||
if (!namespace) {
|
|
||||||
throw new Error('logger needs namespace');
|
|
||||||
}
|
|
||||||
this.namespace = namespace;
|
|
||||||
this.profilers = {};
|
|
||||||
this.debug = createDebug(this.namespace);
|
|
||||||
}
|
|
||||||
|
|
||||||
log(...args) {
|
|
||||||
// TODO: node env production
|
|
||||||
console.log(this.LOG, ...args);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The {@link logger.info} function is an alias for {@link logger.log()}.
|
|
||||||
* @param args
|
|
||||||
*/
|
|
||||||
info(...args) {
|
|
||||||
console.log(this.INFO, ...args);
|
|
||||||
}
|
|
||||||
|
|
||||||
error(...args) {
|
|
||||||
console.error(this.ERROR, ...args);
|
|
||||||
}
|
|
||||||
|
|
||||||
warn(...args) {
|
|
||||||
console.warn(this.WARN, ...args);
|
|
||||||
}
|
|
||||||
|
|
||||||
formatTiming(timing) {
|
|
||||||
return timing < 60 * 1000 ? `${Math.round(timing / 10) / 100}s` : `${Math.round(timing / 600) / 100}m`;
|
|
||||||
}
|
|
||||||
|
|
||||||
profile(id, message) {
|
|
||||||
const time = Date.now();
|
|
||||||
const namespace = `${this.namespace}:${id}`;
|
|
||||||
// for test
|
|
||||||
let msg;
|
|
||||||
if (this.profilers[id]) {
|
|
||||||
const timeEnd = this.profilers[id];
|
|
||||||
delete this.profilers[id];
|
|
||||||
process.stderr.write(`${this.PROFILE} `);
|
|
||||||
msg = `${this.PROFILE} ${chalk.cyan(`└ ${namespace}`)} Completed in ${this.formatTiming(time - timeEnd)}`;
|
|
||||||
console.log(msg);
|
|
||||||
} else {
|
|
||||||
msg = `${this.PROFILE} ${chalk.cyan(`┌ ${namespace}`)} ${message || ''}`;
|
|
||||||
console.log(msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.profilers[id] = time;
|
|
||||||
return msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
clearConsole(title) {
|
|
||||||
if (process.stdout.isTTY) {
|
|
||||||
const blank = '\n'.repeat(process.stdout.rows);
|
|
||||||
console.log(blank);
|
|
||||||
readline.cursorTo(process.stdout, 0, 0);
|
|
||||||
readline.clearScreenDown(process.stdout);
|
|
||||||
if (title) {
|
|
||||||
console.log(title);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -21,7 +21,6 @@ import getPaths from './getPaths';
|
|||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
// 1. duplicated key
|
// 1. duplicated key
|
||||||
// 2. Logger
|
|
||||||
export default class Service extends EventEmitter {
|
export default class Service extends EventEmitter {
|
||||||
cwd;
|
cwd;
|
||||||
|
|
||||||
|
@ -7,7 +7,6 @@ import assert from 'assert';
|
|||||||
import * as utils from '@fesjs/utils';
|
import * as utils from '@fesjs/utils';
|
||||||
import { isValidPlugin, pathToObj } from './utils/pluginUtils';
|
import { isValidPlugin, pathToObj } from './utils/pluginUtils';
|
||||||
import { EnableBy, PluginType, ServiceStage } from './enums';
|
import { EnableBy, PluginType, ServiceStage } from './enums';
|
||||||
import Logger from '../logger';
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
// 标准化 logger
|
// 标准化 logger
|
||||||
@ -17,7 +16,7 @@ export default class PluginAPI {
|
|||||||
this.key = opts.key;
|
this.key = opts.key;
|
||||||
this.service = opts.service;
|
this.service = opts.service;
|
||||||
this.utils = utils;
|
this.utils = utils;
|
||||||
this.logger = new Logger(`fes:plugin:${this.id || this.key}`);
|
this.logger = utils.logger;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: reversed keys
|
// TODO: reversed keys
|
||||||
|
@ -31,7 +31,6 @@
|
|||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/preset-env": "^7.15.0",
|
"@babel/preset-env": "^7.15.0",
|
||||||
"@fesjs/compiler": "^2.0.5",
|
|
||||||
"@vue/babel-plugin-jsx": "^1.0.6",
|
"@vue/babel-plugin-jsx": "^1.0.6",
|
||||||
"babel-jest": "^27.0.6",
|
"babel-jest": "^27.0.6",
|
||||||
"jest": "^27.0.6",
|
"jest": "^27.0.6",
|
||||||
|
@ -1,13 +1,10 @@
|
|||||||
import assert from 'assert';
|
import assert from 'assert';
|
||||||
import { join } from 'path';
|
import { join } from 'path';
|
||||||
import { existsSync } from 'fs';
|
import { existsSync } from 'fs';
|
||||||
import { Logger } from '@fesjs/compiler';
|
|
||||||
// jest-cli 不在暴露 options,维护一份本地的 options
|
// jest-cli 不在暴露 options,维护一份本地的 options
|
||||||
import { options as CliOptions } from './jestArgs';
|
import { options as CliOptions } from './jestArgs';
|
||||||
import createDefaultConfig from './createDefaultConfig';
|
import createDefaultConfig from './createDefaultConfig';
|
||||||
|
|
||||||
const logger = new Logger('fes:plugin-unit-jest');
|
|
||||||
|
|
||||||
function getCommandOptiton() {
|
function getCommandOptiton() {
|
||||||
const opts = [];
|
const opts = [];
|
||||||
Object.keys(CliOptions).forEach((key) => {
|
Object.keys(CliOptions).forEach((key) => {
|
||||||
@ -28,7 +25,7 @@ function getCommandOptiton() {
|
|||||||
|
|
||||||
export default function (api) {
|
export default function (api) {
|
||||||
const {
|
const {
|
||||||
utils: { mergeConfig },
|
utils: { mergeConfig, logger },
|
||||||
cwd,
|
cwd,
|
||||||
} = api;
|
} = api;
|
||||||
|
|
||||||
@ -43,22 +40,22 @@ export default function (api) {
|
|||||||
args._.shift();
|
args._.shift();
|
||||||
}
|
}
|
||||||
|
|
||||||
args.debug && logger.log(`args: ${JSON.stringify(args)}`);
|
args.debug && logger.info(`args: ${JSON.stringify(args)}`);
|
||||||
|
|
||||||
// Read config from cwd/jest.config.js
|
// Read config from cwd/jest.config.js
|
||||||
const userJestConfigFile = join(cwd, 'jest.config.js');
|
const userJestConfigFile = join(cwd, 'jest.config.js');
|
||||||
const userJestConfig = existsSync(userJestConfigFile) && require(userJestConfigFile);
|
const userJestConfig = existsSync(userJestConfigFile) && require(userJestConfigFile);
|
||||||
args.debug && logger.log(`config from jest.config.js: ${JSON.stringify(userJestConfig)}`);
|
args.debug && logger.info(`config from jest.config.js: ${JSON.stringify(userJestConfig)}`);
|
||||||
|
|
||||||
// Read jest config from package.json
|
// Read jest config from package.json
|
||||||
const packageJSONPath = join(cwd, 'package.json');
|
const packageJSONPath = join(cwd, 'package.json');
|
||||||
const packageJestConfig = existsSync(packageJSONPath) && require(packageJSONPath).jest;
|
const packageJestConfig = existsSync(packageJSONPath) && require(packageJSONPath).jest;
|
||||||
args.debug && logger.log(`jest config from package.json: ${JSON.stringify(packageJestConfig)}`);
|
args.debug && logger.info(`jest config from package.json: ${JSON.stringify(packageJestConfig)}`);
|
||||||
|
|
||||||
// Merge configs
|
// Merge configs
|
||||||
// user config and args config could have value function for modification
|
// user config and args config could have value function for modification
|
||||||
const config = mergeConfig(createDefaultConfig(cwd, args), packageJestConfig, userJestConfig);
|
const config = mergeConfig(createDefaultConfig(cwd, args), packageJestConfig, userJestConfig);
|
||||||
args.debug && logger.log(`final config: ${JSON.stringify(config)}`);
|
args.debug && logger.info(`final config: ${JSON.stringify(config)}`);
|
||||||
|
|
||||||
// Generate jest options
|
// Generate jest options
|
||||||
const argsConfig = Object.keys(CliOptions).reduce((prev, name) => {
|
const argsConfig = Object.keys(CliOptions).reduce((prev, name) => {
|
||||||
@ -69,7 +66,7 @@ export default function (api) {
|
|||||||
if (alias && args[alias]) prev[name] = args[alias];
|
if (alias && args[alias]) prev[name] = args[alias];
|
||||||
return prev;
|
return prev;
|
||||||
}, {});
|
}, {});
|
||||||
args.debug && logger.log(`config from args: ${JSON.stringify(argsConfig)}`);
|
args.debug && logger.info(`config from args: ${JSON.stringify(argsConfig)}`);
|
||||||
|
|
||||||
// 比较大的库建议使用require,使用时才加载,提升fes命令的效率
|
// 比较大的库建议使用require,使用时才加载,提升fes命令的效率
|
||||||
const { runCLI } = require('jest');
|
const { runCLI } = require('jest');
|
||||||
@ -87,7 +84,7 @@ export default function (api) {
|
|||||||
},
|
},
|
||||||
[cwd],
|
[cwd],
|
||||||
);
|
);
|
||||||
args.debug && logger.log(result);
|
args.debug && logger.info(result);
|
||||||
|
|
||||||
// Throw error when run failed
|
// Throw error when run failed
|
||||||
assert(result.results.success, 'Test with jest failed');
|
assert(result.results.success, 'Test with jest failed');
|
||||||
|
@ -1,12 +1,9 @@
|
|||||||
import { readdirSync, statSync, readFileSync } from 'fs';
|
import { readdirSync, statSync, readFileSync } from 'fs';
|
||||||
import { join, extname, posix, basename } from 'path';
|
import { join, extname, posix, basename } from 'path';
|
||||||
import { lodash, parser, generator } from '@fesjs/utils';
|
import { lodash, parser, generator, logger } from '@fesjs/utils';
|
||||||
import { parse } from '@vue/compiler-sfc';
|
import { parse } from '@vue/compiler-sfc';
|
||||||
import { Logger } from '@fesjs/compiler';
|
|
||||||
import { runtimePath } from '../../utils/constants';
|
import { runtimePath } from '../../utils/constants';
|
||||||
|
|
||||||
const logger = new Logger('fes:router');
|
|
||||||
|
|
||||||
// pages
|
// pages
|
||||||
// ├── index.vue # 根路由页面 路径 /
|
// ├── index.vue # 根路由页面 路径 /
|
||||||
// ├── *.vue # 模糊匹配 路径 *
|
// ├── *.vue # 模糊匹配 路径 *
|
||||||
|
@ -31,6 +31,7 @@ import getHostName from './getHostName';
|
|||||||
import resolveRuntimeEnv from './resolveRuntimeEnv';
|
import resolveRuntimeEnv from './resolveRuntimeEnv';
|
||||||
import stringifyObjValue from './stringifyObjValue';
|
import stringifyObjValue from './stringifyObjValue';
|
||||||
import getTargetsAndBrowsersList from './getTargetsAndBrowsersList';
|
import getTargetsAndBrowsersList from './getTargetsAndBrowsersList';
|
||||||
|
import * as logger from './logger';
|
||||||
|
|
||||||
export {
|
export {
|
||||||
chalk,
|
chalk,
|
||||||
@ -50,6 +51,7 @@ export {
|
|||||||
portfinder,
|
portfinder,
|
||||||
resolve,
|
resolve,
|
||||||
generator,
|
generator,
|
||||||
|
logger,
|
||||||
};
|
};
|
||||||
|
|
||||||
export {
|
export {
|
||||||
|
35
packages/fes-utils/src/logger.js
Normal file
35
packages/fes-utils/src/logger.js
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
import chalk from 'chalk';
|
||||||
|
|
||||||
|
export const prefixes = {
|
||||||
|
wait: `${chalk.cyan('wait')} -`,
|
||||||
|
error: `${chalk.red('error')} -`,
|
||||||
|
warn: `${chalk.yellow('warn')} -`,
|
||||||
|
ready: `${chalk.green('ready')} -`,
|
||||||
|
info: `${chalk.cyan('info')} -`,
|
||||||
|
event: `${chalk.magenta('event')} -`,
|
||||||
|
debug: `${chalk.gray('debug')} -`,
|
||||||
|
};
|
||||||
|
|
||||||
|
export function wait(...message) {
|
||||||
|
console.log(prefixes.wait, ...message);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function error(...message) {
|
||||||
|
console.error(prefixes.error, ...message);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function warn(...message) {
|
||||||
|
console.warn(prefixes.warn, ...message);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function ready(...message) {
|
||||||
|
console.log(prefixes.ready, ...message);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function info(...message) {
|
||||||
|
console.log(prefixes.info, ...message);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function event(...message) {
|
||||||
|
console.log(prefixes.event, ...message);
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user