mirror of
https://github.com/PaulHatch/semantic-version.git
synced 2025-12-28 13:28:18 +00:00
Fix tagged version behavior
This commit is contained in:
parent
142e038c41
commit
caa92bb3e3
4 changed files with 59 additions and 59 deletions
|
|
@ -1,5 +1,5 @@
|
||||||
name: "Semantic Version"
|
name: "Git Semantic Version"
|
||||||
description: "Determines version of a repo"
|
description: "Determines version of a repo based on git history"
|
||||||
branding:
|
branding:
|
||||||
icon: "layers"
|
icon: "layers"
|
||||||
color: "blue"
|
color: "blue"
|
||||||
|
|
|
||||||
51
dist/index.js
vendored
51
dist/index.js
vendored
|
|
@ -652,6 +652,22 @@ const cmd = async (command, ...args) => {
|
||||||
return output;
|
return output;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const setOutput = (major, minor, patch, increment) => {
|
||||||
|
const format = core.getInput('format', { required: true });
|
||||||
|
var version = format
|
||||||
|
.replace('${major}', major)
|
||||||
|
.replace('${minor}', minor)
|
||||||
|
.replace('${patch}', patch)
|
||||||
|
.replace('${increment}', increment);
|
||||||
|
|
||||||
|
core.info(`Version is ${major}.${minor}.${patch}+${increment}`);
|
||||||
|
core.setOutput("version", version);
|
||||||
|
core.setOutput("major", major.toString());
|
||||||
|
core.setOutput("minor", minor.toString());
|
||||||
|
core.setOutput("patch", patch.toString());
|
||||||
|
core.setOutput("increment", increment.toString());
|
||||||
|
};
|
||||||
|
|
||||||
async function run() {
|
async function run() {
|
||||||
try {
|
try {
|
||||||
const remote = await cmd('git', 'remote');
|
const remote = await cmd('git', 'remote');
|
||||||
|
|
@ -666,30 +682,29 @@ async function run() {
|
||||||
const releasePattern = `refs/tags/${tagPrefix}*`;
|
const releasePattern = `refs/tags/${tagPrefix}*`;
|
||||||
let major = 0, minor = 0, patch = 0, increment = 0;
|
let major = 0, minor = 0, patch = 0, increment = 0;
|
||||||
|
|
||||||
|
let lastCommitAll = (await cmd('git', 'rev-list', '-n1', '--all')).trim();
|
||||||
|
|
||||||
|
if (lastCommitAll === '') {
|
||||||
|
// empty repo
|
||||||
|
setOutput('0', '0', '0', '0');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let commit = (await cmd('git', 'rev-parse', 'HEAD')).trim();
|
||||||
|
|
||||||
let tag = (await cmd(
|
let tag = (await cmd(
|
||||||
'git',
|
'git',
|
||||||
`for-each-ref`,
|
`for-each-ref`,
|
||||||
`--format='%(refname:short)'`,
|
`--format='%(refname:short)'`,
|
||||||
`--sort=-committerdate`,
|
`--sort=-committerdate`,
|
||||||
|
`--no-contains`, commit,
|
||||||
releasePattern
|
releasePattern
|
||||||
)).split(eol)[0].trim().replace(/'/g, "");
|
)).split(eol)[0].trim().replace(/'/g, "");
|
||||||
|
|
||||||
let root;
|
let root;
|
||||||
if (tag === '') {
|
if (tag === '') {
|
||||||
const isEmpty = (await cmd('git', `status`)).includes('No commits yet');
|
// no release tags yet, use the initial commit as the root
|
||||||
if (isEmpty) {
|
root = '';
|
||||||
// empty repo
|
|
||||||
core.info('Version is 0.0.0+0');
|
|
||||||
core.setOutput("version", '0.0.0+0');
|
|
||||||
core.setOutput("major", '0');
|
|
||||||
core.setOutput("minor", '0');
|
|
||||||
core.setOutput("patch", '0');
|
|
||||||
core.setOutput("increment", '0');
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
// no release tags yet, use the initial commit as the root
|
|
||||||
root = '';
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
// parse the version tag
|
// parse the version tag
|
||||||
let tagParts = tag.split('/');
|
let tagParts = tag.split('/');
|
||||||
|
|
@ -741,13 +756,7 @@ async function run() {
|
||||||
patch++;
|
patch++;
|
||||||
}
|
}
|
||||||
|
|
||||||
let version = `${major}.${minor}.${patch}`;
|
setOutput(major, minor, patch, increment);
|
||||||
core.info(`Version is ${version}+${increment}`);
|
|
||||||
core.setOutput("version", version);
|
|
||||||
core.setOutput("major", major.toString());
|
|
||||||
core.setOutput("minor", minor.toString());
|
|
||||||
core.setOutput("patch", patch.toString());
|
|
||||||
core.setOutput("increment", increment.toString());
|
|
||||||
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.error(error);
|
core.error(error);
|
||||||
|
|
|
||||||
22
index.js
22
index.js
|
|
@ -46,25 +46,29 @@ async function run() {
|
||||||
const releasePattern = `refs/tags/${tagPrefix}*`;
|
const releasePattern = `refs/tags/${tagPrefix}*`;
|
||||||
let major = 0, minor = 0, patch = 0, increment = 0;
|
let major = 0, minor = 0, patch = 0, increment = 0;
|
||||||
|
|
||||||
|
let lastCommitAll = (await cmd('git', 'rev-list', '-n1', '--all')).trim();
|
||||||
|
|
||||||
|
if (lastCommitAll === '') {
|
||||||
|
// empty repo
|
||||||
|
setOutput('0', '0', '0', '0');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let commit = (await cmd('git', 'rev-parse', 'HEAD')).trim();
|
||||||
|
|
||||||
let tag = (await cmd(
|
let tag = (await cmd(
|
||||||
'git',
|
'git',
|
||||||
`for-each-ref`,
|
`for-each-ref`,
|
||||||
`--format='%(refname:short)'`,
|
`--format='%(refname:short)'`,
|
||||||
`--sort=-committerdate`,
|
`--sort=-committerdate`,
|
||||||
|
`--no-contains`, commit,
|
||||||
releasePattern
|
releasePattern
|
||||||
)).split(eol)[0].trim().replace(/'/g, "");
|
)).split(eol)[0].trim().replace(/'/g, "");
|
||||||
|
|
||||||
let root;
|
let root;
|
||||||
if (tag === '') {
|
if (tag === '') {
|
||||||
const isEmpty = (await cmd('git', `status`)).includes('No commits yet');
|
// no release tags yet, use the initial commit as the root
|
||||||
if (isEmpty) {
|
root = '';
|
||||||
// empty repo
|
|
||||||
setOutput('0', '0', '0', '0');
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
// no release tags yet, use the initial commit as the root
|
|
||||||
root = '';
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
// parse the version tag
|
// parse the version tag
|
||||||
let tagParts = tag.split('/');
|
let tagParts = tag.split('/');
|
||||||
|
|
|
||||||
|
|
@ -74,6 +74,19 @@ test('Repository with commits shows increment', () => {
|
||||||
repo.clean();
|
repo.clean();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('Tagging does not break version', () => {
|
||||||
|
const repo = createTestRepo(); // 0.0.0+0
|
||||||
|
|
||||||
|
repo.makeCommit('Initial Commit'); // 0.0.1+0
|
||||||
|
repo.makeCommit(`Second Commit`); // 0.0.1+1
|
||||||
|
repo.exec('git tag v0.0.1')
|
||||||
|
const result = repo.runAction();
|
||||||
|
|
||||||
|
expect(result).toMatch('Version is 0.0.1+1');
|
||||||
|
|
||||||
|
repo.clean();
|
||||||
|
});
|
||||||
|
|
||||||
test('Minor update bumps minor version and resets increment', () => {
|
test('Minor update bumps minor version and resets increment', () => {
|
||||||
const repo = createTestRepo(); // 0.0.0+0
|
const repo = createTestRepo(); // 0.0.0+0
|
||||||
|
|
||||||
|
|
@ -126,7 +139,7 @@ test('Minor commits after a major commit are ignored', () => {
|
||||||
repo.clean();
|
repo.clean();
|
||||||
});
|
});
|
||||||
|
|
||||||
test('Release branches start new version', () => {
|
test('Tags start new version', () => {
|
||||||
const repo = createTestRepo(); // 0.0.0+0
|
const repo = createTestRepo(); // 0.0.0+0
|
||||||
|
|
||||||
repo.makeCommit('Initial Commit'); // 0.0.1+0
|
repo.makeCommit('Initial Commit'); // 0.0.1+0
|
||||||
|
|
@ -184,32 +197,6 @@ test('Tags on branches are used', () => {
|
||||||
repo.clean();
|
repo.clean();
|
||||||
});
|
});
|
||||||
|
|
||||||
test('Merged tags do not affect version', () => {
|
|
||||||
|
|
||||||
// This test checks that merges are counted correctly
|
|
||||||
// master o--o--o--o---o <- expecting v0.0.2+1
|
|
||||||
// \ /
|
|
||||||
// release o--o <- taged v0.0.1
|
|
||||||
|
|
||||||
|
|
||||||
const repo = createTestRepo(); // 0.0.0+0
|
|
||||||
|
|
||||||
repo.makeCommit('Initial Commit'); // 0.0.1+0
|
|
||||||
repo.makeCommit('Second Commit'); // 0.0.1+1
|
|
||||||
repo.makeCommit('Third Commit'); // 0.1.1+2
|
|
||||||
repo.exec('git checkout -b release/0.0.1')
|
|
||||||
repo.makeCommit('Fourth Commit'); // 0.1.1+3
|
|
||||||
repo.exec('git tag v0.0.1');
|
|
||||||
repo.exec('git checkout master');
|
|
||||||
repo.makeCommit('Fifth Commit'); // 0.0.2+1
|
|
||||||
repo.exec('git merge release/0.0.1');
|
|
||||||
const result = repo.runAction();
|
|
||||||
|
|
||||||
expect(result).toMatch('Version is 0.0.2+1');
|
|
||||||
|
|
||||||
repo.clean();
|
|
||||||
});
|
|
||||||
|
|
||||||
test('Merged tags do not affect version', () => {
|
test('Merged tags do not affect version', () => {
|
||||||
|
|
||||||
// This test checks that merges don't override tags
|
// This test checks that merges don't override tags
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue