-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdangerfile.ts
52 lines (42 loc) · 1.57 KB
/
dangerfile.ts
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
import {danger, warn, message} from 'danger';
import {includes} from 'lodash';
import * as fs from 'fs';
// No PR is too small to include a description of why you made a change
if (danger.github.pr.body.length < 10) {
warn('Please include a description of your PR changes.');
}
const filesOnly = (file) =>
fs.existsSync(file) && fs.lstatSync(file).isFile();
const javascriptOnly = (file) => includes(file, '.js');
const modifiedMD = danger.git.modified_files.join('- ');
const modified = danger.git.modified_files;
// Custom subsets of known files
const modifiedAppFiles = modified
.filter(p => includes(p, 'src') || includes(p, '__tests__'))
.filter(p => filesOnly(p) && javascriptOnly(p));
const hasAppChanges = modifiedAppFiles.length > 0;
message('Changed Files in this PR: \n - ' + modifiedMD);
// Warn when there is a big PR
const bigPRThreshold = 500;
if (
danger.github.pr.additions + danger.github.pr.deletions >
bigPRThreshold
) {
warn(':exclamation: Big PR');
}
const testChanges = modifiedAppFiles.filter(filepath =>
filepath.includes('test'),
);
const hasTestChanges = testChanges.length > 0;
// Warn if there are library changes, but not tests
if (hasAppChanges && !hasTestChanges) {
warn(
'There are library changes, but not tests. That\'s OK as long as you\'re refactoring existing code',
);
}
// Politely ask for their name in the authors file
message('Please add your name and email to the AUTHORS file (optional)');
message(
`If this was a change that affects the external API,
please update the docs and post a link to the PR in the discussion`,
);