electron/script/release/version-utils.js

104 lines
3 KiB
JavaScript
Raw Normal View History

2020-03-20 20:28:31 +00:00
const path = require('path');
const fs = require('fs');
const semver = require('semver');
const { GitProcess } = require('dugite');
const { promisify } = require('util');
2020-03-20 20:28:31 +00:00
const { ELECTRON_DIR } = require('../lib/utils');
2020-03-20 20:28:31 +00:00
const readFile = promisify(fs.readFile);
const preType = {
NONE: 'none',
PARTIAL: 'partial',
FULL: 'full'
2020-03-20 20:28:31 +00:00
};
const getCurrentDate = () => {
2020-03-20 20:28:31 +00:00
const d = new Date();
const dd = `${d.getDate()}`.padStart(2, '0');
const mm = `${d.getMonth() + 1}`.padStart(2, '0');
const yyyy = d.getFullYear();
return `${yyyy}${mm}${dd}`;
};
const isNightly = v => v.includes('nightly');
const isBeta = v => v.includes('beta');
const isStable = v => {
2020-03-20 20:28:31 +00:00
const parsed = semver.parse(v);
return !!(parsed && parsed.prerelease.length === 0);
};
const makeVersion = (components, delim, pre = preType.NONE) => {
2020-03-20 20:28:31 +00:00
let version = [components.major, components.minor, components.patch].join(delim);
if (pre === preType.PARTIAL) {
2020-03-20 20:28:31 +00:00
version += `${delim}${components.pre[1] || 0}`;
} else if (pre === preType.FULL) {
2020-03-20 20:28:31 +00:00
version += `-${components.pre[0]}${delim}${components.pre[1]}`;
}
2020-03-20 20:28:31 +00:00
return version;
};
async function nextBeta (v) {
2020-03-20 20:28:31 +00:00
const next = semver.coerce(semver.clean(v));
2020-03-20 20:28:31 +00:00
const tagBlob = await GitProcess.exec(['tag', '--list', '-l', `v${next}-beta.*`], ELECTRON_DIR);
const tags = tagBlob.stdout.split('\n').filter(e => e !== '');
tags.sort((t1, t2) => {
const a = parseInt(t1.split('.').pop(), 10);
const b = parseInt(t2.split('.').pop(), 10);
return a - b;
});
// increment the latest existing beta tag or start at beta.1 if it's a new beta line
2020-03-20 20:28:31 +00:00
return tags.length === 0 ? `${next}-beta.1` : semver.inc(tags.pop(), 'prerelease');
}
async function getElectronVersion () {
2020-03-20 20:28:31 +00:00
const versionPath = path.resolve(ELECTRON_DIR, 'ELECTRON_VERSION');
const version = await readFile(versionPath, 'utf8');
return version.trim();
}
async function nextNightly (v) {
2020-03-20 20:28:31 +00:00
let next = semver.valid(semver.coerce(v));
const pre = `nightly.${getCurrentDate()}`;
2020-03-20 20:28:31 +00:00
const branch = (await GitProcess.exec(['rev-parse', '--abbrev-ref', 'HEAD'], ELECTRON_DIR)).stdout.trim();
if (branch === 'master') {
2020-03-20 20:28:31 +00:00
next = semver.inc(await getLastMajorForMaster(), 'major');
} else if (isStable(v)) {
2020-03-20 20:28:31 +00:00
next = semver.inc(next, 'patch');
}
2020-03-20 20:28:31 +00:00
return `${next}-${pre}`;
}
async function getLastMajorForMaster () {
2020-03-20 20:28:31 +00:00
let branchNames;
const result = await GitProcess.exec(['branch', '-a', '--remote', '--list', 'origin/[0-9]*-x-y'], ELECTRON_DIR);
if (result.exitCode === 0) {
2020-03-20 20:28:31 +00:00
branchNames = result.stdout.trim().split('\n');
const filtered = branchNames.map(b => b.replace('origin/', ''));
return getNextReleaseBranch(filtered);
} else {
2020-03-20 20:28:31 +00:00
throw new Error('Release branches could not be fetched.');
}
}
function getNextReleaseBranch (branches) {
2020-03-20 20:28:31 +00:00
const converted = branches.map(b => b.replace(/-/g, '.').replace('x', '0').replace('y', '0'));
return converted.reduce((v1, v2) => semver.gt(v1, v2) ? v1 : v2);
}
module.exports = {
isStable,
isBeta,
isNightly,
nextBeta,
makeVersion,
getElectronVersion,
nextNightly,
preType
2020-03-20 20:28:31 +00:00
};