refactor(dev-infra): improve error message for unexpected version branches (#38622)
Currently the merge script default branch configuration throws an error if an unexpected version branch is discovered. The error right now assumes to much knowledge of the logic and the document outlining the release trains conceptually. We change it to something more easy to understand that doesn't require full understanding of the versioning/labeling/branching document that has been created for the Angular organization. PR Close #38622
This commit is contained in:
parent
3487b549fd
commit
ebc0e46501
|
@ -165,6 +165,11 @@ export async function findActiveVersionBranches(
|
||||||
latestVersionBranch: string | null,
|
latestVersionBranch: string | null,
|
||||||
releaseCandidateBranch: string | null,
|
releaseCandidateBranch: string | null,
|
||||||
}> {
|
}> {
|
||||||
|
// Version representing the release-train currently in the next phase. Note that we ignore
|
||||||
|
// patch and pre-release segments in order to be able to compare the next release train to
|
||||||
|
// other release trains from version branches (which follow the `N.N.x` pattern).
|
||||||
|
const nextReleaseTrainVersion = semver.parse(`${nextVersion.major}.${nextVersion.minor}.0`)!;
|
||||||
|
|
||||||
let latestVersionBranch: string|null = null;
|
let latestVersionBranch: string|null = null;
|
||||||
let releaseCandidateBranch: string|null = null;
|
let releaseCandidateBranch: string|null = null;
|
||||||
|
|
||||||
|
@ -177,15 +182,21 @@ export async function findActiveVersionBranches(
|
||||||
// next version-branch as that one is supposed to be the latest active version-branch. If it
|
// next version-branch as that one is supposed to be the latest active version-branch. If it
|
||||||
// is not, then an error will be thrown due to two FF/RC branches existing at the same time.
|
// is not, then an error will be thrown due to two FF/RC branches existing at the same time.
|
||||||
for (const {name, parsed} of branches) {
|
for (const {name, parsed} of branches) {
|
||||||
// It can happen that version branches that are more recent than the version in the next
|
// It can happen that version branches have been accidentally created which are more recent
|
||||||
// branch (i.e. `master`) have been created. We could ignore such branches silently, but
|
// than the release-train in the next branch (i.e. `master`). We could ignore such branches
|
||||||
// it might actually be symptomatic for an outdated version in the `next` branch, or an
|
// silently, but it might be symptomatic for an outdated version in the `next` branch, or an
|
||||||
// accidentally created branch by the caretaker. In either way we want to raise awareness.
|
// accidentally created branch by the caretaker. In either way we want to raise awareness.
|
||||||
if (semver.gte(parsed, nextVersion)) {
|
if (semver.gt(parsed, nextReleaseTrainVersion)) {
|
||||||
throw Error(
|
throw Error(
|
||||||
`Discovered unexpected version-branch that is representing a minor ` +
|
`Discovered unexpected version-branch "${name}" for a release-train that is ` +
|
||||||
`version more recent than the one in the "${nextBranchName}" branch. Consider ` +
|
`more recent than the release-train currently in the "${nextBranchName}" branch. ` +
|
||||||
`deleting the branch, or check if the version in "${nextBranchName}" is outdated.`);
|
`Please either delete the branch if created by accident, or update the outdated ` +
|
||||||
|
`version in the next branch (${nextBranchName}).`);
|
||||||
|
} else if (semver.eq(parsed, nextReleaseTrainVersion)) {
|
||||||
|
throw Error(
|
||||||
|
`Discovered unexpected version-branch "${name}" for a release-train that is already ` +
|
||||||
|
`active in the "${nextBranchName}" branch. Please either delete the branch if ` +
|
||||||
|
`created by accident, or update the version in the next branch (${nextBranchName}).`);
|
||||||
}
|
}
|
||||||
|
|
||||||
const version = await getVersionOfBranch(repo, name);
|
const version = await getVersionOfBranch(repo, name);
|
||||||
|
|
|
@ -280,7 +280,21 @@ describe('default target labels', () => {
|
||||||
.toBeRejectedWithError('Invalid version detected in following branch: 11.1.x.');
|
.toBeRejectedWithError('Invalid version detected in following branch: 11.1.x.');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should error if branch more recent than version in "next" branch is found', async () => {
|
it('should error if version-branch more recent than "next" is discovered', async () => {
|
||||||
|
interceptBranchVersionRequest('master', '11.2.0-next.0');
|
||||||
|
interceptBranchVersionRequest('11.3.x', '11.3.0-next.0');
|
||||||
|
interceptBranchVersionRequest('11.1.x', '11.1.5');
|
||||||
|
interceptBranchesListRequest(['11.1.x', '11.3.x']);
|
||||||
|
|
||||||
|
await expectAsync(getBranchesForLabel('target: lts', '10.2.x'))
|
||||||
|
.toBeRejectedWithError(
|
||||||
|
'Discovered unexpected version-branch "11.3.x" for a release-train that is ' +
|
||||||
|
'more recent than the release-train currently in the "master" branch. Please ' +
|
||||||
|
'either delete the branch if created by accident, or update the outdated version ' +
|
||||||
|
'in the next branch (master).');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should error if branch is matching with release-train in the "next" branch', async () => {
|
||||||
interceptBranchVersionRequest('master', '11.2.0-next.0');
|
interceptBranchVersionRequest('master', '11.2.0-next.0');
|
||||||
interceptBranchVersionRequest('11.2.x', '11.2.0-next.0');
|
interceptBranchVersionRequest('11.2.x', '11.2.0-next.0');
|
||||||
interceptBranchVersionRequest('11.1.x', '11.1.5');
|
interceptBranchVersionRequest('11.1.x', '11.1.5');
|
||||||
|
@ -288,9 +302,9 @@ describe('default target labels', () => {
|
||||||
|
|
||||||
await expectAsync(getBranchesForLabel('target: lts', '10.2.x'))
|
await expectAsync(getBranchesForLabel('target: lts', '10.2.x'))
|
||||||
.toBeRejectedWithError(
|
.toBeRejectedWithError(
|
||||||
'Discovered unexpected version-branch that is representing a minor version more ' +
|
'Discovered unexpected version-branch "11.2.x" for a release-train that is already ' +
|
||||||
'recent than the one in the "master" branch. Consider deleting the branch, or check ' +
|
'active in the "master" branch. Please either delete the branch if created by ' +
|
||||||
'if the version in "master" is outdated.');
|
'accident, or update the version in the next branch (master).');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should allow merging PR only into patch branch with "target: patch"', async () => {
|
it('should allow merging PR only into patch branch with "target: patch"', async () => {
|
||||||
|
|
Loading…
Reference in New Issue