Skip to content

Commit

Permalink
Minor improvements in the retry mechanism. Now, it takes from a stack…
Browse files Browse the repository at this point in the history
… of available attempts.
  • Loading branch information
pomek committed Oct 4, 2024
1 parent 5d29385 commit f0907bb
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 23 deletions.
46 changes: 24 additions & 22 deletions scripts/ci/check-unit-tests-for-package.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,9 @@ main()
} );

async function main() {
const { packageName, checkCoverage, allowNonFullCoverage, coverageFile, retries } = getOptions( process.argv.slice( 2 ) );
const { packageName, checkCoverage, allowNonFullCoverage, coverageFile, attempts } = getOptions( process.argv.slice( 2 ) );

runTests( { packageName, checkCoverage, retries } );
runTests( { packageName, checkCoverage, attempts } );

if ( checkCoverage && !allowNonFullCoverage ) {
const exitCode = checkCodeCoverage();
Expand All @@ -46,9 +46,9 @@ async function main() {
* @param {Object} options
* @param {String} options.packageName
* @param {Boolean} options.checkCoverage
* @param {Number} options.retries
* @param {Number} options.attempts
*/
function runTests( { packageName, checkCoverage, retries = 3 } ) {
function runTests( { packageName, checkCoverage, attempts = 3 } ) {
const shortName = packageName.replace( /^ckeditor5?-/, '' );

const testCommand = [
Expand All @@ -60,22 +60,23 @@ function runTests( { packageName, checkCoverage, retries = 3 } ) {
checkCoverage ? '--coverage' : null
].filter( Boolean );

for ( let retry = 0; retry < retries; retry++ ) {
try {
execSync( testCommand.join( ' ' ), {
cwd: CKEDITOR5_ROOT_PATH,
stdio: 'inherit'
} );

break;
} catch ( err ) {
if ( retry === retries ) {
throw err;
} else {
console.error( err );
console.log( `\n⚠️ Retry ${ retry + 1 } of ${ retries } for ${ packageName }!` );
}
try {
execSync( testCommand.join( ' ' ), {
cwd: CKEDITOR5_ROOT_PATH,
stdio: 'inherit'
} );
} catch ( err ) {
if ( !attempts ) {
throw err;
}

console.log( `\n⚠️ Retry the test execution. Remaining attempts: ${ attempts - 1 }.` );

return runTests( {
packageName,
checkCoverage,
attempts: attempts - 1
} );
}
}

Expand Down Expand Up @@ -104,13 +105,14 @@ function checkCodeCoverage() {
* @returns {Boolean} options.checkCoverage
* @returns {Boolean} options.allowNonFullCoverage
* @returns {String|null} options.coverageFile
* @returns {Number} options.retries
* @returns {Number} options.attempts
*/
function getOptions( argv ) {
const options = minimist( argv, {
string: [
'package-name',
'coverage-file'
'coverage-file',
'attempts'
],
boolean: [
'check-coverage',
Expand All @@ -122,7 +124,7 @@ function getOptions( argv ) {
}
} );

options.retries = Number( options.retries ?? 3 );
options.attempts = Number( options.attempts || 1 );
options.packageName = options[ 'package-name' ];
options.coverageFile = options[ 'coverage-file' ];
options.checkCoverage = options[ 'check-coverage' ];
Expand Down
2 changes: 1 addition & 1 deletion scripts/ci/generate-circleci-configuration.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -235,7 +235,7 @@ function generateTestSteps( packages, { checkCoverage, coverageFile = null } ) {
const testCommand = [
'node',
'scripts/ci/check-unit-tests-for-package.mjs',
'--retries 3',
'--attempts 3',
'--package-name',
packageName,
checkCoverage ? '--check-coverage' : null,
Expand Down

0 comments on commit f0907bb

Please sign in to comment.