- Do not rely on `package.json` anymore - Use `cosmiconfig` to load the configation. `semantic-release` can be configured: - via CLI options (including plugin names but not plugin options) - in the `release` property of `package.json` (as before) - in a `.releaserc.yml` or `.releaserc.js` or `.releaserc.js` or `release.config.js` file - in a `.releaserc` file containing `json`, `yaml` or `javascript` module - Add the `repositoryUrl` options (used across `semantic-release` and plugins). The value is determined from CLi option, or option configuration, or package.json or the git remote url - Verifies that `semantic-release` runs from a git repository - `pkg` and `env` are not passed to plugin anymore - `semantic-release` can be run both locally and globally. If ran globally with non default plugins, the plugins can be installed both globally or locally. BREAKING CHANGE: `pkg` and `env` are not passed to plugin anymore. Plugins relying on a `package.json` must verify the presence of a valid `package.json` and load it. Plugins can use `process.env` instead of `env`.
92 lines
2.6 KiB
JavaScript
92 lines
2.6 KiB
JavaScript
const execa = require('execa');
|
|
const debug = require('debug')('semantic-release:get-version-head');
|
|
const {debugShell} = require('./debug');
|
|
|
|
/**
|
|
* Get the commit sha for a given tag.
|
|
*
|
|
* @param {string} tagName Tag name for which to retrieve the commit sha.
|
|
*
|
|
* @return {string} The commit sha of the tag in parameter or `null`.
|
|
*/
|
|
async function gitTagHead(tagName) {
|
|
try {
|
|
const shell = await execa('git', ['rev-list', '-1', tagName]);
|
|
debugShell('Get git tag head', shell, debug);
|
|
return shell.stdout;
|
|
} catch (err) {
|
|
debug(err);
|
|
return null;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get the tag associated with a commit sha.
|
|
*
|
|
* @param {string} gitHead The commit sha for which to retrieve the associated tag.
|
|
*
|
|
* @return {string} The tag associatedwith the sha in parameter or `null`.
|
|
*/
|
|
async function gitCommitTag(gitHead) {
|
|
try {
|
|
const shell = await execa('git', ['describe', '--tags', '--exact-match', gitHead]);
|
|
debugShell('Get git commit tag', shell, debug);
|
|
return shell.stdout;
|
|
} catch (err) {
|
|
debug(err);
|
|
return null;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Verify if the commit `sha` is in the direct history of the current branch.
|
|
*
|
|
* @param {string} sha The sha of the commit to look for.
|
|
*
|
|
* @return {boolean} `true` if the commit `sha` is in the history of the current branch, `false` otherwise.
|
|
*/
|
|
async function isCommitInHistory(sha) {
|
|
const shell = await execa('git', ['merge-base', '--is-ancestor', sha, 'HEAD'], {reject: false});
|
|
debugShell('Check if commit is in history', shell, debug);
|
|
return shell.code === 0;
|
|
}
|
|
|
|
/**
|
|
* Unshallow the git repository (retriving every commits and tags).
|
|
*/
|
|
async function unshallow() {
|
|
await execa('git', ['fetch', '--unshallow', '--tags'], {reject: false});
|
|
}
|
|
|
|
/**
|
|
* @return {string} the sha of the HEAD commit.
|
|
*/
|
|
async function gitHead() {
|
|
try {
|
|
const shell = await execa('git', ['rev-parse', 'HEAD']);
|
|
debugShell('Get git head', shell, debug);
|
|
return shell.stdout;
|
|
} catch (err) {
|
|
debug(err);
|
|
throw new Error(err.stderr);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @return {string|null} The value of the remote git URL.
|
|
*/
|
|
async function repoUrl() {
|
|
return (await execa.stdout('git', ['remote', 'get-url', 'origin'], {reject: false})) || null;
|
|
}
|
|
|
|
/**
|
|
* @return {Boolean} `true` if the current working directory is in a git repository, `false` otherwise.
|
|
*/
|
|
async function isGitRepo() {
|
|
const shell = await execa('git', ['rev-parse', '--git-dir'], {reject: false});
|
|
debugShell('Check if the current working directory is a git repository', shell, debug);
|
|
return shell.code === 0;
|
|
}
|
|
|
|
module.exports = {gitTagHead, gitCommitTag, isCommitInHistory, unshallow, gitHead, repoUrl, isGitRepo};
|