229 lines
12 KiB
JavaScript
229 lines
12 KiB
JavaScript
const {inspect} = require('util');
|
|
const {toLower, isString, trim} = require('lodash');
|
|
const pkg = require('../../package.json');
|
|
const {RELEASE_TYPE} = require('./constants');
|
|
|
|
const [homepage] = pkg.homepage.split('#');
|
|
const stringify = obj => (isString(obj) ? obj : inspect(obj, {breakLength: Infinity, depth: 2, maxArrayLength: 5}));
|
|
const linkify = file => `${homepage}/blob/master/${file}`;
|
|
const wordsList = words =>
|
|
`${words.slice(0, -1).join(', ')}${words.length > 1 ? ` or ${words[words.length - 1]}` : trim(words[0])}`;
|
|
|
|
module.exports = {
|
|
ENOGITREPO: ({cwd}) => ({
|
|
message: 'Not running from a git repository.',
|
|
details: `The \`semantic-release\` command must be executed from a Git repository.
|
|
|
|
The current working directory is \`${cwd}\`.
|
|
|
|
Please verify your CI configuration to make sure the \`semantic-release\` command is executed from the root of the cloned repository.`,
|
|
}),
|
|
ENOREPOURL: () => ({
|
|
message: 'The `repositoryUrl` option is required.',
|
|
details: `The [repositoryUrl option](${linkify(
|
|
'docs/usage/configuration.md#repositoryurl'
|
|
)}) cannot be determined from the semantic-release configuration, the \`package.json\` nor the [git origin url](https://git-scm.com/book/en/v2/Git-Basics-Working-with-Remotes).
|
|
|
|
Please make sure to add the \`repositoryUrl\` to the [semantic-release configuration] (${linkify(
|
|
'docs/usage/configuration.md'
|
|
)}).`,
|
|
}),
|
|
EGITNOPERMISSION: ({options: {repositoryUrl}, branch: {name}}) => ({
|
|
message: 'The push permission to the Git repository is required.',
|
|
details: `**semantic-release** cannot push the version tag to the branch \`${name}\` on remote Git repository with URL \`${repositoryUrl}\`.
|
|
|
|
Please refer to the [authentication configuration documentation](${linkify(
|
|
'docs/usage/ci-configuration.md#authentication'
|
|
)}) to configure the Git credentials on your CI environment and make sure the [repositoryUrl](${linkify(
|
|
'docs/usage/configuration.md#repositoryurl'
|
|
)}) is configured with a [valid Git URL](https://git-scm.com/book/en/v2/Git-on-the-Server-The-Protocols).`,
|
|
}),
|
|
EINVALIDTAGFORMAT: ({options: {tagFormat}}) => ({
|
|
message: 'Invalid `tagFormat` option.',
|
|
details: `The [tagFormat](${linkify(
|
|
'docs/usage/configuration.md#tagformat'
|
|
)}) must compile to a [valid Git reference](https://git-scm.com/docs/git-check-ref-format#_description).
|
|
|
|
Your configuration for the \`tagFormat\` option is \`${stringify(tagFormat)}\`.`,
|
|
}),
|
|
ETAGNOVERSION: ({options: {tagFormat}}) => ({
|
|
message: 'Invalid `tagFormat` option.',
|
|
details: `The [tagFormat](${linkify(
|
|
'docs/usage/configuration.md#tagformat'
|
|
)}) option must contain the variable \`version\` exactly once.
|
|
|
|
Your configuration for the \`tagFormat\` option is \`${stringify(tagFormat)}\`.`,
|
|
}),
|
|
EPLUGINCONF: ({type, required, pluginConf}) => ({
|
|
message: `The \`${type}\` plugin configuration is invalid.`,
|
|
details: `The [${type} plugin configuration](${linkify(`docs/usage/plugins.md#${toLower(type)}-plugin`)}) ${
|
|
required ? 'is required and ' : ''
|
|
} must be a single or an array of plugins definition. A plugin definition is an npm module name, optionnaly wrapped in an array with an object.
|
|
|
|
Your configuration for the \`${type}\` plugin is \`${stringify(pluginConf)}\`.`,
|
|
}),
|
|
EPLUGINSCONF: ({plugin}) => ({
|
|
message: 'The `plugins` configuration is invalid.',
|
|
details: `The [plugins](${linkify(
|
|
'docs/usage/configuration.md#plugins'
|
|
)}) option must be an array of plugin definions. A plugin definition is an npm module name, optionnaly wrapped in an array with an object.
|
|
|
|
The invalid configuration is \`${stringify(plugin)}\`.`,
|
|
}),
|
|
EPLUGIN: ({pluginName, type}) => ({
|
|
message: `A plugin configured in the step ${type} is not a valid semantic-release plugin.`,
|
|
details: `A valid \`${type}\` **semantic-release** plugin must be a function or an object with a function in the property \`${type}\`.
|
|
|
|
The plugin \`${pluginName}\` doesn't have the property \`${type}\` and cannot be used for the \`${type}\` step.
|
|
|
|
Please refer to the \`${pluginName}\` and [semantic-release plugins configuration](${linkify(
|
|
'docs/usage/plugins.md'
|
|
)}) documentation for more details.`,
|
|
}),
|
|
EANALYZECOMMITSOUTPUT: ({result, pluginName}) => ({
|
|
message: 'The `analyzeCommits` plugin returned an invalid value. It must return a valid semver release type.',
|
|
details: `The \`analyzeCommits\` plugin must return a valid [semver](https://semver.org) release type. The valid values are: ${RELEASE_TYPE.map(
|
|
type => `\`${type}\``
|
|
).join(', ')}.
|
|
|
|
The \`analyzeCommits\` function of the \`${pluginName}\` returned \`${stringify(result)}\` instead.
|
|
|
|
We recommend to report the issue to the \`${pluginName}\` authors, providing the following informations:
|
|
- The **semantic-release** version: \`${pkg.version}\`
|
|
- The **semantic-release** logs from your CI job
|
|
- The value returned by the plugin: \`${stringify(result)}\`
|
|
- A link to the **semantic-release** plugin developer guide: [${linkify('docs/developer-guide/plugin.md')}](${linkify(
|
|
'docs/developer-guide/plugin.md'
|
|
)})`,
|
|
}),
|
|
EGENERATENOTESOUTPUT: ({result, pluginName}) => ({
|
|
message: 'The `generateNotes` plugin returned an invalid value. It must return a `String`.',
|
|
details: `The \`generateNotes\` plugin must return a \`String\`.
|
|
|
|
The \`generateNotes\` function of the \`${pluginName}\` returned \`${stringify(result)}\` instead.
|
|
|
|
We recommend to report the issue to the \`${pluginName}\` authors, providing the following informations:
|
|
- The **semantic-release** version: \`${pkg.version}\`
|
|
- The **semantic-release** logs from your CI job
|
|
- The value returned by the plugin: \`${stringify(result)}\`
|
|
- A link to the **semantic-release** plugin developer guide: [${linkify('docs/developer-guide/plugin.md')}](${linkify(
|
|
'docs/developer-guide/plugin.md'
|
|
)})`,
|
|
}),
|
|
EPUBLISHOUTPUT: ({result, pluginName}) => ({
|
|
message: 'A `publish` plugin returned an invalid value. It must return an `Object`.',
|
|
details: `The \`publish\` plugins must return an \`Object\`.
|
|
|
|
The \`publish\` function of the \`${pluginName}\` returned \`${stringify(result)}\` instead.
|
|
|
|
We recommend to report the issue to the \`${pluginName}\` authors, providing the following informations:
|
|
- The **semantic-release** version: \`${pkg.version}\`
|
|
- The **semantic-release** logs from your CI job
|
|
- The value returned by the plugin: \`${stringify(result)}\`
|
|
- A link to the **semantic-release** plugin developer guide: [${linkify('docs/developer-guide/plugin.md')}](${linkify(
|
|
'docs/developer-guide/plugin.md'
|
|
)})`,
|
|
}),
|
|
EADDCHANNELOUTPUT: ({result, pluginName}) => ({
|
|
message: 'A `addChannel` plugin returned an invalid value. It must return an `Object`.',
|
|
details: `The \`addChannel\` plugins must return an \`Object\`.
|
|
|
|
The \`addChannel\` function of the \`${pluginName}\` returned \`${stringify(result)}\` instead.
|
|
|
|
We recommend to report the issue to the \`${pluginName}\` authors, providing the following informations:
|
|
- The **semantic-release** version: \`${pkg.version}\`
|
|
- The **semantic-release** logs from your CI job
|
|
- The value returned by the plugin: \`${stringify(result)}\`
|
|
- A link to the **semantic-release** plugin developer guide: [${linkify('docs/developer-guide/plugin.md')}](${linkify(
|
|
'docs/developer-guide/plugin.md'
|
|
)})`,
|
|
}),
|
|
EINVALIDBRANCH: ({branch}) => ({
|
|
message: 'A branch is invalid in the `branches` configuration.',
|
|
details: `Each branch in the [branches configuration](${linkify(
|
|
'docs/usage/configuration.md#branches'
|
|
)}) must be either a string, a regexp or an object with a \`name\` property.
|
|
|
|
Your configuration for the problematic branch is \`${stringify(branch)}\`.`,
|
|
}),
|
|
EINVALIDBRANCHNAME: ({branch}) => ({
|
|
message: 'A branch name is invalid in the `branches` configuration.',
|
|
details: `Each branch in the [branches configuration](${linkify(
|
|
'docs/usage/configuration.md#branches'
|
|
)}) must be a [valid Git reference](https://git-scm.com/docs/git-check-ref-format#_description).
|
|
|
|
Your configuration for the problematic branch is \`${stringify(branch)}\`.`,
|
|
}),
|
|
EDUPLICATEBRANCHES: ({duplicates}) => ({
|
|
message: 'The `branches` configuration has duplicate branches.',
|
|
details: `Each branch in the [branches configuration](${linkify(
|
|
'docs/usage/configuration.md#branches'
|
|
)}) must havea unique name.
|
|
|
|
Your configuration contains duplicates for the following branch names: \`${stringify(duplicates)}\`.`,
|
|
}),
|
|
EMAINTENANCEBRANCH: ({branch}) => ({
|
|
message: 'A maintenance branch is invalid in the `branches` configuration.',
|
|
details: `Each maintenance branch in the [branches configuration](${linkify(
|
|
'docs/usage/configuration.md#branches'
|
|
)}) must have a \`range\` property formatted like \`N.x\`, \`N.x.x\` or \`N.N.x\` (\`N\` is a number).
|
|
|
|
Your configuration for the problematic branch is \`${stringify(branch)}\`.`,
|
|
}),
|
|
EMAINTENANCEBRANCHES: ({branches}) => ({
|
|
message: 'The maintenance branches are invalid in the `branches` configuration.',
|
|
details: `Each maintenance branch in the [branches configuration](${linkify(
|
|
'docs/usage/configuration.md#branches'
|
|
)}) must have a unique \`range\` property.
|
|
|
|
Your configuration for the problematic branches is \`${stringify(branches)}\`.`,
|
|
}),
|
|
ERELEASEBRANCHES: ({branches}) => ({
|
|
message: 'The release branches are invalid in the `branches` configuration.',
|
|
details: `A minimum of 1 and a maximum of 3 release branches are required in the [branches configuration](${linkify(
|
|
'docs/usage/configuration.md#branches'
|
|
)}).
|
|
|
|
Your configuration for the problematic branches is \`${stringify(branches)}\`.`,
|
|
}),
|
|
EPRERELEASEBRANCH: ({branch}) => ({
|
|
message: 'A pre-release branch configuration is invalid in the `branches` configuration.',
|
|
details: `Each pre-release branch in the [branches configuration](${linkify(
|
|
'docs/usage/configuration.md#branches'
|
|
)}) must have a \`prerelease\` property valid per the [Semantic Versioning Specification](https://semver.org/#spec-item-9). If the \`prerelease\` property is set to \`true\`, then the \`name\` property is used instead.
|
|
|
|
Your configuration for the problematic branch is \`${stringify(branch)}\`.`,
|
|
}),
|
|
EPRERELEASEBRANCHES: ({branches}) => ({
|
|
message: 'The pre-release branches are invalid in the `branches` configuration.',
|
|
details: `Each pre-release branch in the [branches configuration](${linkify(
|
|
'docs/usage/configuration.md#branches'
|
|
)}) must have a unique \`prerelease\` property. If the \`prerelease\` property is set to \`true\`, then the \`name\` property is used instead.
|
|
|
|
Your configuration for the problematic branches is \`${stringify(branches)}\`.`,
|
|
}),
|
|
EINVALIDNEXTVERSION: ({nextRelease: {version}, branch: {name, range}, commits, validBranches}) => ({
|
|
message: `The release \`${version}\` on branch \`${name}\` cannot be published as it is out of range.`,
|
|
details: `Based on the releases published on other branches, only versions within the range \`${range}\` can be published from branch \`${name}\`.
|
|
|
|
The following commit${commits.length > 1 ? 's are' : ' is'} responsible for the invalid release:
|
|
${commits.map(({commit: {short}, subject}) => `- ${subject} (${short})`).join('\n')}
|
|
|
|
${
|
|
commits.length > 1 ? 'Those commits' : 'This commit'
|
|
} should be moved to a valid branch with [git merge](https://git-scm.com/docs/git-merge) or [git cherry-pick](https://git-scm.com/docs/git-cherry-pick) and removed from branch \`${name}\` with [git revert](https://git-scm.com/docs/git-revert) or [git reset](https://git-scm.com/docs/git-reset).
|
|
|
|
A valid branch could be ${wordsList(validBranches.map(({name}) => `\`${name}\``))}.
|
|
|
|
See the [workflow configuration documentation](${linkify('docs/usage/workflow-configuration.md')}) for more details.`,
|
|
}),
|
|
EINVALIDMAINTENANCEMERGE: ({nextRelease: {channel, gitTag, version}, branch: {mergeRange, name}}) => ({
|
|
message: `The release \`${version}\` on branch \`${name}\` cannot be published as it is out of range.`,
|
|
details: `Only releases within the range \`${mergeRange}\` can be merged into the maintenance branch \`${name}\` and published to the \`${channel}\` distribution channel.
|
|
|
|
The branch \`${name}\` head should be [reset](https://git-scm.com/docs/git-reset) to a previous commit so the commit with tag \`${gitTag}\` is removed from the branch history.
|
|
|
|
See the [workflow configuration documentation](${linkify('docs/usage/workflow-configuration.md')}) for more details.`,
|
|
}),
|
|
};
|