- Remove the `getLastRelease` plugin type - Retrieve the last release based on Git tags - Create the next release Git tag before calling the `publish` plugins BREAKING CHANGE: Remove the `getLastRelease` plugin type The `getLastRelease` plugins will not be called anymore. BREAKING CHANGE: Git repository authentication is now mandatory The Git authentication is now mandatory and must be set via `GH_TOKEN`, `GITHUB_TOKEN`, `GL_TOKEN`, `GITLAB_TOKEN` or `GIT_CREDENTIALS` as described in [CI configuration](https://github.com/semantic-release/semantic-release/blob/caribou/docs/usage/ci-configuration.md#authentication).
		
			
				
	
	
		
			78 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import test from 'ava';
 | |
| import definitions from '../../lib/plugins/definitions';
 | |
| 
 | |
| test('The "verifyConditions" plugin, if defined, must be a single or an array of plugins definition', t => {
 | |
|   t.false(definitions.verifyConditions.config.validator({}));
 | |
|   t.false(definitions.verifyConditions.config.validator({path: null}));
 | |
| 
 | |
|   t.true(definitions.verifyConditions.config.validator({path: 'plugin-path.js'}));
 | |
|   t.true(definitions.verifyConditions.config.validator());
 | |
|   t.true(definitions.verifyConditions.config.validator('plugin-path.js'));
 | |
|   t.true(definitions.verifyConditions.config.validator(() => {}));
 | |
|   t.true(definitions.verifyConditions.config.validator([{path: 'plugin-path.js'}, 'plugin-path.js', () => {}]));
 | |
| });
 | |
| 
 | |
| test('The "analyzeCommits" plugin is mandatory, and must be a single plugin definition', t => {
 | |
|   t.false(definitions.analyzeCommits.config.validator({}));
 | |
|   t.false(definitions.analyzeCommits.config.validator({path: null}));
 | |
|   t.false(definitions.analyzeCommits.config.validator([]));
 | |
|   t.false(definitions.analyzeCommits.config.validator());
 | |
| 
 | |
|   t.true(definitions.analyzeCommits.config.validator({path: 'plugin-path.js'}));
 | |
|   t.true(definitions.analyzeCommits.config.validator('plugin-path.js'));
 | |
|   t.true(definitions.analyzeCommits.config.validator(() => {}));
 | |
| });
 | |
| 
 | |
| test('The "verifyRelease" plugin, if defined, must be a single or an array of plugins definition', t => {
 | |
|   t.false(definitions.verifyRelease.config.validator({}));
 | |
|   t.false(definitions.verifyRelease.config.validator({path: null}));
 | |
| 
 | |
|   t.true(definitions.verifyRelease.config.validator({path: 'plugin-path.js'}));
 | |
|   t.true(definitions.verifyRelease.config.validator());
 | |
|   t.true(definitions.verifyRelease.config.validator('plugin-path.js'));
 | |
|   t.true(definitions.verifyRelease.config.validator(() => {}));
 | |
|   t.true(definitions.verifyRelease.config.validator([{path: 'plugin-path.js'}, 'plugin-path.js', () => {}]));
 | |
| });
 | |
| 
 | |
| test('The "generateNotes" plugin, if defined, must be a single plugin definition', t => {
 | |
|   t.false(definitions.generateNotes.config.validator({}));
 | |
|   t.false(definitions.generateNotes.config.validator({path: null}));
 | |
|   t.false(definitions.generateNotes.config.validator([]));
 | |
| 
 | |
|   t.true(definitions.generateNotes.config.validator());
 | |
|   t.true(definitions.generateNotes.config.validator({path: 'plugin-path.js'}));
 | |
|   t.true(definitions.generateNotes.config.validator('plugin-path.js'));
 | |
|   t.true(definitions.generateNotes.config.validator(() => {}));
 | |
| });
 | |
| 
 | |
| test('The "publish" plugin is mandatory, and must be a single or an array of plugins definition', t => {
 | |
|   t.false(definitions.publish.config.validator({}));
 | |
|   t.false(definitions.publish.config.validator({path: null}));
 | |
|   t.false(definitions.publish.config.validator());
 | |
| 
 | |
|   t.true(definitions.publish.config.validator({path: 'plugin-path.js'}));
 | |
|   t.true(definitions.publish.config.validator('plugin-path.js'));
 | |
|   t.true(definitions.publish.config.validator(() => {}));
 | |
|   t.true(definitions.publish.config.validator([{path: 'plugin-path.js'}, 'plugin-path.js', () => {}]));
 | |
| });
 | |
| 
 | |
| test('The "analyzeCommits" plugin output must be either undefined or a valid semver release type', t => {
 | |
|   t.false(definitions.analyzeCommits.output.validator('invalid'));
 | |
|   t.false(definitions.analyzeCommits.output.validator(1));
 | |
|   t.false(definitions.analyzeCommits.output.validator({}));
 | |
| 
 | |
|   t.true(definitions.analyzeCommits.output.validator());
 | |
|   t.true(definitions.analyzeCommits.output.validator(null));
 | |
|   t.true(definitions.analyzeCommits.output.validator('major'));
 | |
| });
 | |
| 
 | |
| test('The "generateNotes" plugin output, if defined, must be a string', t => {
 | |
|   t.false(definitions.generateNotes.output.validator(1));
 | |
|   t.false(definitions.generateNotes.output.validator({}));
 | |
| 
 | |
|   t.true(definitions.generateNotes.output.validator());
 | |
|   t.true(definitions.generateNotes.output.validator(null));
 | |
|   t.true(definitions.generateNotes.output.validator(''));
 | |
|   t.true(definitions.generateNotes.output.validator('string'));
 | |
| });
 |