Skip to content

Commit

Permalink
refactor(rebaseWhen): small refactor for rebaseWhen value setter (#32175
Browse files Browse the repository at this point in the history
)
  • Loading branch information
PhilipAbed authored Oct 28, 2024
1 parent 7527f13 commit 5028c90
Showing 1 changed file with 37 additions and 32 deletions.
69 changes: 37 additions & 32 deletions lib/workers/repository/update/branch/reuse.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,34 +37,10 @@ export async function shouldReuseExistingBranch(
return result;
}
logger.debug(`Branch already exists`);
if (result.rebaseWhen === 'auto') {
if (result.automerge === true) {
logger.debug(
'Converting rebaseWhen=auto to rebaseWhen=behind-base-branch because automerge=true',
);
result.rebaseWhen = 'behind-base-branch';
} else if (await platform.getBranchForceRebase?.(result.baseBranch)) {
logger.debug(
'Converting rebaseWhen=auto to rebaseWhen=behind-base-branch because platform is configured to require up-to-date branches',
);
result.rebaseWhen = 'behind-base-branch';
} else if (await shouldKeepUpdated(result, baseBranch, branchName)) {
logger.debug(
'Converting rebaseWhen=auto to rebaseWhen=behind-base-branch because keep-updated label is set',
);
result.rebaseWhen = 'behind-base-branch';
}
}
if (result.rebaseWhen === 'auto') {
logger.debug(
'Converting rebaseWhen=auto to rebaseWhen=conflicted because no rule for converting to rebaseWhen=behind-base-branch applies',
);
result.rebaseWhen = 'conflicted';
}
if (
result.rebaseWhen === 'behind-base-branch' ||
(await shouldKeepUpdated(result, baseBranch, branchName))
) {
const keepUpdated = await shouldKeepUpdated(result, baseBranch, branchName);
await determineRebaseWhenValue(result, keepUpdated);

if (result.rebaseWhen === 'behind-base-branch' || keepUpdated) {
if (await scm.isBranchBehindBase(branchName, baseBranch)) {
logger.debug(`Branch is behind base branch and needs rebasing`);
// We can rebase the branch only if no PR or PR can be rebased
Expand All @@ -91,10 +67,7 @@ export async function shouldReuseExistingBranch(

if ((await scm.isBranchModified(branchName, baseBranch)) === false) {
logger.debug(`Branch is not mergeable and needs rebasing`);
if (
result.rebaseWhen === 'never' &&
!(await shouldKeepUpdated(result, baseBranch, branchName))
) {
if (result.rebaseWhen === 'never' && !keepUpdated) {
logger.debug('Rebasing disabled by config');
result.reuseExistingBranch = true;
result.isModified = false;
Expand Down Expand Up @@ -136,3 +109,35 @@ export async function shouldReuseExistingBranch(
result.isModified = false;
return result;
}

/**
* This method updates rebaseWhen value when it's set to auto(default)
*
* @param result BranchConfig
* @param keepUpdated boolean
*/
async function determineRebaseWhenValue(
result: BranchConfig,
keepUpdated: boolean,
): Promise<void> {
if (result.rebaseWhen === 'auto') {
let reason;

let newValue = 'behind-base-branch';
if (result.automerge === true) {
reason = 'automerge=true';
} else if (await platform.getBranchForceRebase?.(result.baseBranch)) {
reason = 'platform is configured to require up-to-date branches';
} else if (keepUpdated) {
reason = 'keep-updated label is set';
} else {
newValue = 'conflicted';
reason = 'no rule for behind-base-branch applies';
}

logger.debug(
`Converting rebaseWhen=${result.rebaseWhen} to rebaseWhen=${newValue} because ${reason}`,
);
result.rebaseWhen = newValue;
}
}

0 comments on commit 5028c90

Please sign in to comment.