-
Notifications
You must be signed in to change notification settings - Fork 2.2k
/
commit.spec.ts
49 lines (47 loc) · 1.56 KB
/
commit.spec.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
import { defaultConfig, git, partial } from '../../../test/util';
import { setAdminConfig } from '../../config/admin';
import { BranchConfig } from '../common';
import { commitFilesToBranch } from './commit';
jest.mock('../../util/git');
describe('workers/branch/automerge', () => {
describe('commitFilesToBranch', () => {
let config: BranchConfig;
beforeEach(() => {
config = partial<BranchConfig>({
...defaultConfig,
branchName: 'renovate/some-branch',
commitMessage: 'some commit message',
semanticCommits: 'disabled',
semanticCommitType: 'a',
semanticCommitScope: 'b',
updatedPackageFiles: [],
updatedArtifacts: [],
});
jest.resetAllMocks();
git.commitFiles.mockResolvedValueOnce('abc123');
setAdminConfig();
});
it('handles empty files', async () => {
await commitFilesToBranch(config);
expect(git.commitFiles).toHaveBeenCalledTimes(0);
});
it('commits files', async () => {
config.updatedPackageFiles.push({
name: 'package.json',
contents: 'some contents',
});
await commitFilesToBranch(config);
expect(git.commitFiles).toHaveBeenCalledTimes(1);
expect(git.commitFiles.mock.calls).toMatchSnapshot();
});
it('dry runs', async () => {
setAdminConfig({ dryRun: true });
config.updatedPackageFiles.push({
name: 'package.json',
contents: 'some contents',
});
await commitFilesToBranch(config);
expect(git.commitFiles).toHaveBeenCalledTimes(0);
});
});
});