mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-18 22:36:31 +08:00
test: set maxWorkers for test:visual-regression (#50219)
* test: set maxWorkers for test:visual-regression * chore: print args * chore: set max-workers to 4 * test: use move instead of copy * chore: set max-workers to 2
This commit is contained in:
parent
f4b585af5f
commit
cbdbed3013
@ -132,7 +132,7 @@ jobs:
|
||||
EVENT_NUMBER: ${{ github.event.number }}
|
||||
BASE_REF: ${{ github.base_ref }}
|
||||
run: |
|
||||
npm run test:visual-regression -- --pr-id=$EVENT_NUMBER --base-ref=$BASE_REF
|
||||
npm run test:visual-regression -- --pr-id=$EVENT_NUMBER --base-ref=$BASE_REF --max-workers=2
|
||||
|
||||
# Upload report in `visualRegressionReport`
|
||||
- name: upload report artifact
|
||||
@ -153,4 +153,4 @@ jobs:
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: visual-regression-diff-ref
|
||||
path: ./visual-regression-pr-id.txt
|
||||
path: ./visual-regression-pr-id.txt
|
||||
|
@ -275,6 +275,7 @@
|
||||
"nprogress": "^0.2.0",
|
||||
"open": "^10.1.0",
|
||||
"ora": "^8.0.1",
|
||||
"p-all": "^5.0.0",
|
||||
"pixelmatch": "^6.0.0",
|
||||
"pngjs": "^7.0.0",
|
||||
"prettier": "^3.3.3",
|
||||
|
@ -150,19 +150,22 @@ interface IBadCase {
|
||||
const git = simpleGit();
|
||||
|
||||
async function parseArgs() {
|
||||
// parse args from -- --pr-id=123 --base_ref=feature
|
||||
// parse args from -- --pr-id=123 --base_ref=feature --max-workers=2
|
||||
const argv = minimist(process.argv.slice(2));
|
||||
const prId = argv['pr-id'];
|
||||
assert(prId, 'Missing --pr-id');
|
||||
const baseRef = argv['base-ref'];
|
||||
assert(baseRef, 'Missing --base-ref');
|
||||
|
||||
const maxWorkers = argv['max-workers'] ? parseInt(argv['max-workers'], 10) : 1;
|
||||
|
||||
const { latest } = await git.log();
|
||||
|
||||
return {
|
||||
prId,
|
||||
baseRef,
|
||||
currentRef: latest?.hash.slice(0, 8) || '',
|
||||
maxWorkers,
|
||||
};
|
||||
}
|
||||
|
||||
@ -311,7 +314,10 @@ If you think the visual diff is acceptable, please check:
|
||||
}
|
||||
|
||||
async function boot() {
|
||||
const { prId, baseRef: targetBranch = 'master', currentRef } = await parseArgs();
|
||||
const args = await parseArgs();
|
||||
console.log(`Args: ${JSON.stringify(args)}`);
|
||||
|
||||
const { prId, baseRef: targetBranch = 'master', currentRef, maxWorkers } = args;
|
||||
|
||||
const baseImgSourceDir = path.resolve(ROOT_DIR, `./imageSnapshots-${targetBranch}`);
|
||||
|
||||
@ -365,8 +371,8 @@ async function boot() {
|
||||
.map((n) => path.basename(n, path.extname(n)));
|
||||
|
||||
// compare to target branch
|
||||
for (const basename of cssInJsImgNames) {
|
||||
for (const extname of ['.png', '.css-var.png']) {
|
||||
const compareTasks = cssInJsImgNames.map((basename) =>
|
||||
['.png', '.css-var.png'].map((extname) => async () => {
|
||||
// baseImg always use cssinjs png
|
||||
const baseImgName = `${basename}.png`;
|
||||
const baseImgPath = path.join(baseImgSourceDir, baseImgName);
|
||||
@ -379,13 +385,12 @@ async function boot() {
|
||||
const currentImgExists = await fse.exists(currentImgPath);
|
||||
if (!currentImgExists) {
|
||||
console.log(chalk.red(`⛔️ Missing image: ${compareImgName}\n`));
|
||||
badCases.push({
|
||||
await fse.move(baseImgPath, path.join(baseImgReportDir, compareImgName));
|
||||
return {
|
||||
type: 'removed',
|
||||
filename: compareImgName,
|
||||
weight: 1,
|
||||
});
|
||||
await fse.copy(baseImgPath, path.join(baseImgReportDir, compareImgName));
|
||||
continue;
|
||||
} as IBadCase;
|
||||
}
|
||||
|
||||
const mismatchedPxPercent = await compareScreenshots(
|
||||
@ -400,19 +405,27 @@ async function boot() {
|
||||
chalk.yellow(compareImgName),
|
||||
`${(mismatchedPxPercent * 100).toFixed(2)}%\n`,
|
||||
);
|
||||
// copy compare imgs(x2) to report dir
|
||||
await fse.copy(baseImgPath, path.join(baseImgReportDir, compareImgName));
|
||||
await fse.copy(currentImgPath, path.join(currentImgReportDir, compareImgName));
|
||||
// move compare imgs(x2) to report dir
|
||||
await fse.move(baseImgPath, path.join(baseImgReportDir, compareImgName));
|
||||
await fse.move(currentImgPath, path.join(currentImgReportDir, compareImgName));
|
||||
|
||||
badCases.push({
|
||||
return {
|
||||
type: 'changed',
|
||||
filename: compareImgName,
|
||||
targetFilename: baseImgName,
|
||||
weight: mismatchedPxPercent,
|
||||
});
|
||||
} else {
|
||||
console.log('Passed for: %s\n', chalk.green(compareImgName));
|
||||
} as IBadCase;
|
||||
}
|
||||
console.log('Passed for: %s\n', chalk.green(compareImgName));
|
||||
}),
|
||||
);
|
||||
|
||||
const { default: pAll } = await import('p-all');
|
||||
|
||||
const compareResults = await pAll(compareTasks.flat(), { concurrency: maxWorkers });
|
||||
for (const compareResult of compareResults) {
|
||||
if (compareResult) {
|
||||
badCases.push(compareResult);
|
||||
}
|
||||
}
|
||||
|
||||
@ -431,16 +444,23 @@ async function boot() {
|
||||
console.log('\n');
|
||||
}
|
||||
|
||||
for (const newImg of newImgs) {
|
||||
badCases.push({
|
||||
type: 'added',
|
||||
filename: newImg,
|
||||
weight: 0,
|
||||
});
|
||||
await fse.copy(
|
||||
const newImgTask = newImgs.map((newImg) => async () => {
|
||||
await fse.move(
|
||||
path.join(currentImgSourceDir, newImg),
|
||||
path.resolve(currentImgReportDir, newImg),
|
||||
);
|
||||
return {
|
||||
type: 'added',
|
||||
filename: newImg,
|
||||
weight: 0,
|
||||
} as IBadCase;
|
||||
});
|
||||
|
||||
const newTaskResults = await pAll(newImgTask, { concurrency: maxWorkers });
|
||||
for (const newTaskResult of newTaskResults) {
|
||||
if (newTaskResult) {
|
||||
badCases.push(newTaskResult);
|
||||
}
|
||||
}
|
||||
|
||||
/* --- generate report stage --- */
|
||||
|
Loading…
Reference in New Issue
Block a user