forked from cerner/terra-application
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdangerfile.js
57 lines (41 loc) · 1.84 KB
/
dangerfile.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
// eslint-disable-next-line import/no-extraneous-dependencies
import { danger, fail } from 'danger';
const lernaConfig = require('./lerna.json');
let ignorePatterns = [];
if (lernaConfig.command) {
ignorePatterns = lernaConfig.command.publish.ignoreChanges;
}
const CHANGELOG_PATTERN = /^packages\/([a-z-])*\/CHANGELOG\.md/i;
const changedFiles = danger.git.created_files.concat(danger.git.modified_files);
const allowedFilepaths = ['package.json', 'CHANGELOG.md', 'src', 'translations', 'terra-application-docs'];
const changedChangelogs = new Set();
const changedPackages = new Set();
const getPackageName = (pattern) => pattern.split('packages/')[1].split('/')[0];
const ignorePackages = ignorePatterns.map((pattern) => getPackageName(pattern));
changedFiles.forEach((file) => {
// file isn't in a package so it has no changelog, skip further processing
if (file.substring(0, 9) !== 'packages/') {
return;
}
const packageName = getPackageName(file);
if (ignorePackages.includes(packageName)) {
// file is in a package that currently is not released, skip further processing
return;
}
if (!allowedFilepaths.some(filepath => file.includes(filepath))) {
// skip further processing if the changed file is not among the allowed filepaths
return;
}
if (CHANGELOG_PATTERN.test(file)) {
// changed file is the CHANGELOG itself
changedChangelogs.add(packageName);
return;
}
// for other allowed files
changedPackages.add(packageName);
});
const missingChangelogs = [...changedPackages].filter(packageName => !changedChangelogs.has(packageName));
// Fail if there are package changes without a CHANGELOG update
if (missingChangelogs.length > 0) {
fail(`Please include a CHANGELOG entry for each changed package on this PR. Looks like a CHANGELOG entry is missing for: \n\n - ${missingChangelogs.join('\n - ')}`);
}