fix(release): currentVersionResolver git-tag should prefer merged tags (#22082)

This commit is contained in:
Austin Fahsl 2024-02-29 13:58:48 -07:00 committed by GitHub
parent a89c73483e
commit d705372f57
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 465 additions and 7 deletions

View File

@ -0,0 +1,441 @@
import { NxJsonConfiguration } from '@nx/devkit';
import {
cleanupProject,
getSelectedPackageManager,
newProject,
runCLI,
runCommand,
tmpProjPath,
uniq,
updateJson,
} from '@nx/e2e/utils';
expect.addSnapshotSerializer({
serialize(str: string) {
return (
str
// Remove all output unique to specific projects to ensure deterministic snapshots
.replaceAll(`/private/${tmpProjPath()}`, '')
.replaceAll(tmpProjPath(), '')
.replaceAll('/private/', '')
.replaceAll(/my-pkg-\d+/g, '{project-name}')
.replaceAll(' in /{project-name}', ' in {project-name}')
.replaceAll(
/integrity:\s*.*/g,
'integrity: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
)
.replaceAll(/\b[0-9a-f]{40}\b/g, '{SHASUM}')
.replaceAll(/\d*B index\.js/g, 'XXB index.js')
.replaceAll(/\d*B project\.json/g, 'XXB project.json')
.replaceAll(/\d*B package\.json/g, 'XXXB package.json')
.replaceAll(/\d*B CHANGELOG\.md/g, 'XXXB CHANGELOG.md')
.replaceAll(/size:\s*\d*\s?B/g, 'size: XXXB')
.replaceAll(/\d*\.\d*\s?kB/g, 'XXX.XXX kb')
// Normalize the version title date
.replaceAll(/\(\d{4}-\d{2}-\d{2}\)/g, '(YYYY-MM-DD)')
.replaceAll('package-lock.json', '{lock-file}')
.replaceAll('yarn.lock', '{lock-file}')
.replaceAll('pnpm-lock.yaml', '{lock-file}')
.replaceAll('npm install --package-lock-only', '{lock-file-command}')
.replaceAll(
'yarn install --mode update-lockfile',
'{lock-file-command}'
)
.replaceAll('pnpm install --lockfile-only', '{lock-file-command}')
.replaceAll(getSelectedPackageManager(), '{package-manager}')
// We trim each line to reduce the chances of snapshot flakiness
.split('\n')
.map((r) => r.trim())
.join('\n')
);
},
test(val: string) {
return val != null && typeof val === 'string';
},
});
describe('nx release multiple release branches', () => {
let pkg1: string;
let pkg2: string;
let pkg3: string;
beforeEach(() => {
newProject({
unsetProjectNameAndRootFormat: false,
packages: ['@nx/js'],
});
pkg1 = uniq('my-pkg-1');
runCLI(`generate @nx/workspace:npm-package ${pkg1}`);
pkg2 = uniq('my-pkg-2');
runCLI(`generate @nx/workspace:npm-package ${pkg2}`);
pkg3 = uniq('my-pkg-3');
runCLI(`generate @nx/workspace:npm-package ${pkg3}`);
});
afterEach(() => cleanupProject());
it('git-tag version resolver should not detect tags in other branches', async () => {
updateJson<NxJsonConfiguration>('nx.json', (json) => {
json.release = {
version: {
git: {
commit: true,
tag: true,
},
generatorOptions: {
currentVersionResolver: 'git-tag',
},
},
};
return json;
});
runCommand(`git checkout -b release/0.x`);
runCommand(`git add .`);
runCommand(`git commit -m "chore: initial commit"`);
const initialVersionResult = runCLI(
`release version 0.0.7 --first-release`
);
runCommand(`git checkout -b release/1.x`);
// update my-pkg-1 with a feature commit
updateJson(`${pkg1}/package.json`, (json) => ({
...json,
license: 'MIT',
}));
runCommand(`git add ${pkg1}/package.json`);
runCommand(`git commit -m "feat(${pkg1}): new feature 1"`);
const versionResult1x = runCLI(`release version minor`);
// update my-pkg-2 with a fix commit
updateJson(`${pkg2}/package.json`, (json) => ({
...json,
license: 'MIT',
}));
runCommand(`git add ${pkg2}/package.json`);
runCommand(`git commit -m "fix(${pkg2}): new fix 1"`);
runCommand(`git checkout release/0.x`);
const versionResult0x = runCLI(`release version patch`);
expect(initialVersionResult).toMatchInlineSnapshot(`
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Unable to resolve the current version from git tag using pattern "v{version}". Falling back to the version on disk of 0.0.0
{project-name} 📄 Using the provided version specifier "0.0.7".
{project-name} New version 0.0.7 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.0.0 already resolved from disk fallback.
{project-name} 📄 Using the provided version specifier "0.0.7".
{project-name} New version 0.0.7 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.0.0 already resolved from disk fallback.
{project-name} 📄 Using the provided version specifier "0.0.7".
{project-name} New version 0.0.7 written to {project-name}/package.json
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "0.0.7",
"scripts": {
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "0.0.7",
"scripts": {
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "0.0.7",
"scripts": {
NX Updating {package-manager} lock file
NX Committing changes with git
NX Tagging commit with git
`);
expect(versionResult1x).toMatchInlineSnapshot(`
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Resolved the current version as 0.0.7 from git tag "v0.0.7".
{project-name} 📄 Using the provided version specifier "minor".
{project-name} New version 0.1.0 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.0.7 already resolved from git tag "v0.0.7".
{project-name} 📄 Using the provided version specifier "minor".
{project-name} New version 0.1.0 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.0.7 already resolved from git tag "v0.0.7".
{project-name} 📄 Using the provided version specifier "minor".
{project-name} New version 0.1.0 written to {project-name}/package.json
"name": "@proj/{project-name}",
- "version": "0.0.7",
+ "version": "0.1.0",
"scripts": {
}
+
"name": "@proj/{project-name}",
- "version": "0.0.7",
+ "version": "0.1.0",
"scripts": {
"name": "@proj/{project-name}",
- "version": "0.0.7",
+ "version": "0.1.0",
"scripts": {
NX Updating {package-manager} lock file
NX Committing changes with git
NX Tagging commit with git
`);
expect(versionResult0x).toMatchInlineSnapshot(`
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Resolved the current version as 0.0.7 from git tag "v0.0.7".
{project-name} 📄 Using the provided version specifier "patch".
{project-name} New version 0.0.8 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.0.7 already resolved from git tag "v0.0.7".
{project-name} 📄 Using the provided version specifier "patch".
{project-name} New version 0.0.8 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.0.7 already resolved from git tag "v0.0.7".
{project-name} 📄 Using the provided version specifier "patch".
{project-name} New version 0.0.8 written to {project-name}/package.json
"name": "@proj/{project-name}",
- "version": "0.0.7",
+ "version": "0.0.8",
"scripts": {
"name": "@proj/{project-name}",
- "version": "0.0.7",
+ "version": "0.0.8",
"scripts": {
"name": "@proj/{project-name}",
- "version": "0.0.7",
+ "version": "0.0.8",
"scripts": {
NX Updating {package-manager} lock file
NX Committing changes with git
NX Tagging commit with git
`);
});
it('git-tag version resolver should detect tags in other branches if none are reachable from the current commit', async () => {
updateJson<NxJsonConfiguration>('nx.json', (json) => {
json.release = {
version: {
git: {
commit: true,
tag: true,
},
generatorOptions: {
currentVersionResolver: 'git-tag',
},
},
};
return json;
});
runCommand(`git checkout -b test-main`);
runCommand(`git add .`);
runCommand(`git commit -m "chore: initial commit"`);
runCommand(`git checkout -b release/1.x`);
// update my-pkg-1 with a feature commit
updateJson(`${pkg1}/package.json`, (json) => ({
...json,
license: 'MIT',
}));
runCommand(`git add ${pkg1}/package.json`);
runCommand(`git commit -m "feat(${pkg1}): new feature 1"`);
const versionResult1x = runCLI(`release version minor --first-release`);
runCommand(`git checkout test-main`);
// update my-pkg-2 with a fix commit
updateJson(`${pkg2}/package.json`, (json) => ({
...json,
license: 'MIT',
}));
runCommand(`git add ${pkg2}/package.json`);
runCommand(`git commit -m "fix(${pkg2}): new fix 1"`);
runCommand(`git checkout -b release/2.x`);
const versionResult2x = runCLI(`release version major`);
expect(versionResult1x).toMatchInlineSnapshot(`
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Unable to resolve the current version from git tag using pattern "v{version}". Falling back to the version on disk of 0.0.0
{project-name} 📄 Using the provided version specifier "minor".
{project-name} New version 0.1.0 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.0.0 already resolved from disk fallback.
{project-name} 📄 Using the provided version specifier "minor".
{project-name} New version 0.1.0 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.0.0 already resolved from disk fallback.
{project-name} 📄 Using the provided version specifier "minor".
{project-name} New version 0.1.0 written to {project-name}/package.json
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "0.1.0",
"scripts": {
}
+
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "0.1.0",
"scripts": {
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "0.1.0",
"scripts": {
NX Updating {package-manager} lock file
NX Committing changes with git
NX Tagging commit with git
`);
expect(versionResult2x).toMatchInlineSnapshot(`
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Resolved the current version as 0.1.0 from git tag "v0.1.0".
{project-name} 📄 Using the provided version specifier "major".
{project-name} New version 1.0.0 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.1.0 already resolved from git tag "v0.1.0".
{project-name} 📄 Using the provided version specifier "major".
{project-name} New version 1.0.0 written to {project-name}/package.json
NX Running release version for project: {project-name}
{project-name} 🔍 Reading data for package "@proj/{project-name}" from {project-name}/package.json
{project-name} 📄 Using the current version 0.1.0 already resolved from git tag "v0.1.0".
{project-name} 📄 Using the provided version specifier "major".
{project-name} New version 1.0.0 written to {project-name}/package.json
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "1.0.0",
"scripts": {
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "1.0.0",
"scripts": {
}
+
"name": "@proj/{project-name}",
- "version": "0.0.0",
+ "version": "1.0.0",
"scripts": {
NX Updating {package-manager} lock file
NX Committing changes with git
NX Tagging commit with git
`);
});
});

View File

@ -46,14 +46,31 @@ export async function getLatestGitTagForPattern(
additionalInterpolationData = {}
): Promise<{ tag: string; extractedVersion: string } | null> {
try {
const tags = await execCommand('git', ['tag', '--sort', '-v:refname']).then(
(r) =>
r
.trim()
.split('\n')
.map((t) => t.trim())
.filter(Boolean)
let tags: string[];
tags = await execCommand('git', [
'tag',
'--sort',
'-v:refname',
'--merged',
]).then((r) =>
r
.trim()
.split('\n')
.map((t) => t.trim())
.filter(Boolean)
);
if (!tags.length) {
// try again, but include all tags on the repo instead of just --merged ones
tags = await execCommand('git', ['tag', '--sort', '-v:refname']).then(
(r) =>
r
.trim()
.split('\n')
.map((t) => t.trim())
.filter(Boolean)
);
}
if (!tags.length) {
return null;
}