- Run with one command and do not rely on error exit codes to stop the process when a release is not necessary - Break `index.js` in smaller modules in order to improve testability and simplify the code - Add several missing unit and integration tests to reach 100% coverage - Integration tests now test end to end, including publishing to Github (with http://www.mock-server.com on Docker) - Use `tj/commander.js` to print an help message, verify and parse CLI arguments - Semantic-release can now be called via Javascript API: `require('semantic-release')(options)` - Remove npmlog dependency and add more log messages - Logger is now passed to plugins - Add debug logs with `visionmedia/debug`. `debug` is enabled for both semantic-release and plugins with `--debug` - Use `kevva/npm-conf` in place of the deprecated `npm/npmconf` - Pass lastRelease, nextRelease and commits to generate-notes plugin - In dry-run mode, print the release note instead of publishing it to Github as draft, and skip the CI verifications - The dry-run mode does not require npm and Github TOKEN to be set anymore and can be run locally BREAKING CHANGE: Semantic-Release must now be executed with `semantic-release` instead of `semantic-release pre && npm publish && semantic-release post`. BREAKING CHANGE: The `semantic-release` command now returns with exit code 0 on expected exception (no release has to be done, running on a PR, gitHead not found, other CI job failed etc...). It only returns with 1 when there is an unexpected error (code error in a plugin, plugin not found, git command cannot be run etc..). BREAKING CHANGE: Calling the `semantic-release` command with unexpected argument(s) now exit with 1 and print an help message. BREAKING CHANGE: Semantic-Release does not rely on `npmlog` anymore and the log level cannot be configured. Debug logs can be activated with CLI option `--debug` or with environment variable `DEBUG=semantic-release:*` BREAKING CHANGE: The CLI options `--debug` doesn't enable the dry-run mode anymore but activate the debugs. The dry run mode is now set with the CLI command `--dry-run` or `-d`.
92 lines
3.2 KiB
JavaScript
92 lines
3.2 KiB
JavaScript
import test from 'ava';
|
|
import {gitRepo, gitCommits, gitHead} from './helpers/git-utils';
|
|
import nock from 'nock';
|
|
import {authenticate} from './helpers/mock-github';
|
|
import githubRelease from '../src/lib/github-release';
|
|
|
|
test.beforeEach(t => {
|
|
// Save the current working diretory
|
|
t.context.cwd = process.cwd();
|
|
});
|
|
|
|
test.afterEach.always(t => {
|
|
// Restore the current working directory
|
|
process.chdir(t.context.cwd);
|
|
// Reset nock
|
|
nock.cleanAll();
|
|
});
|
|
|
|
test.serial('Github release with default url', async t => {
|
|
// Create a git repository, set the current working directory at the root of the repo
|
|
await gitRepo();
|
|
// Add commits to the master branch
|
|
await gitCommits(['fix: First fix', 'feat: Second feature']);
|
|
|
|
const sha = await gitHead();
|
|
const owner = 'test_user';
|
|
const repo = 'test_repo';
|
|
const githubToken = 'github_token';
|
|
const notes = 'Test release note body';
|
|
const version = '1.0.0';
|
|
const branch = 'master';
|
|
const tagName = `v${version}`;
|
|
const options = {branch, githubToken};
|
|
const pkg = {version, repository: {url: `git+https://othertesturl.com/${owner}/${repo}.git`}};
|
|
const releaseUrl = `https://othertesturl.com/${owner}/${repo}/releases/${version}`;
|
|
|
|
// Mock github API for releases and git/refs endpoints
|
|
const github = authenticate({githubToken})
|
|
.post(`/repos/${owner}/${repo}/releases`, {
|
|
tag_name: tagName,
|
|
target_commitish: branch,
|
|
name: tagName,
|
|
body: notes,
|
|
})
|
|
.reply(200, {html_url: releaseUrl})
|
|
.post(`/repos/${owner}/${repo}/git/refs`, {ref: `refs/tags/${tagName}`, sha})
|
|
.reply({});
|
|
|
|
// Call the post module
|
|
t.is(releaseUrl, await githubRelease(pkg, notes, version, options));
|
|
// Verify the releases and git/refs endpoint have been call with expected requests
|
|
t.true(github.isDone());
|
|
});
|
|
|
|
test.serial('Github release with custom url', async t => {
|
|
// Create a git repository, set the current working directory at the root of the repo
|
|
await gitRepo();
|
|
// Add commits to the master branch
|
|
await gitCommits(['fix: First fix', 'feat: Second feature']);
|
|
|
|
const sha = await gitHead();
|
|
const owner = 'test_user';
|
|
const repo = 'test_repo';
|
|
const githubUrl = 'https://testurl.com:443';
|
|
const githubToken = 'github_token';
|
|
const githubApiPathPrefix = 'prefix';
|
|
const notes = 'Test release note body';
|
|
const version = '1.0.0';
|
|
const branch = 'master';
|
|
const tagName = `v${version}`;
|
|
const options = {branch, githubUrl, githubToken, githubApiPathPrefix};
|
|
const pkg = {version, repository: {url: `git@othertesturl.com:${owner}/${repo}.git`}};
|
|
const releaseUrl = `https://othertesturl.com/${owner}/${repo}/releases/${version}`;
|
|
|
|
// Mock github API for releases and git/refs endpoints
|
|
const github = authenticate({githubUrl, githubToken, githubApiPathPrefix})
|
|
.post(`/repos/${owner}/${repo}/releases`, {
|
|
tag_name: tagName,
|
|
target_commitish: branch,
|
|
name: tagName,
|
|
body: notes,
|
|
})
|
|
.reply(200, {html_url: releaseUrl})
|
|
.post(`/repos/${owner}/${repo}/git/refs`, {ref: `refs/tags/${tagName}`, sha})
|
|
.reply({});
|
|
|
|
// Call the post module
|
|
t.is(releaseUrl, await githubRelease(pkg, notes, version, options));
|
|
// Verify the releases and git/refs endpoint have been call with expected requests
|
|
t.true(github.isDone());
|
|
});
|