mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-27 05:09:37 +00:00
174 lines
6.2 KiB
TypeScript
174 lines
6.2 KiB
TypeScript
import type { RenovateConfig } from '../../../../test/util';
|
|
import { git, logger, mocked, platform, scm } from '../../../../test/util';
|
|
import { getConfig } from '../../../config/defaults';
|
|
import { GlobalConfig } from '../../../config/global';
|
|
import { CONFIG_VALIDATION } from '../../../constants/error-messages';
|
|
import { addMeta } from '../../../logger';
|
|
import { getCache } from '../../../util/cache/repository';
|
|
import * as _extractUpdate from './extract-update';
|
|
import { lookup } from './extract-update';
|
|
import { extractDependencies, updateRepo } from '.';
|
|
|
|
jest.mock('../../../util/git');
|
|
jest.mock('./extract-update');
|
|
|
|
const extract = mocked(_extractUpdate).extract;
|
|
|
|
let config: RenovateConfig;
|
|
|
|
beforeEach(() => {
|
|
config = getConfig();
|
|
});
|
|
|
|
describe('workers/repository/process/index', () => {
|
|
describe('processRepo()', () => {
|
|
it('processes single branches', async () => {
|
|
const res = await extractDependencies(config);
|
|
expect(res).toBeUndefined();
|
|
});
|
|
|
|
it('processes baseBranches', async () => {
|
|
extract.mockResolvedValue({} as never);
|
|
config.baseBranches = ['branch1', 'branch2'];
|
|
scm.branchExists.mockResolvedValueOnce(false);
|
|
scm.branchExists.mockResolvedValueOnce(true);
|
|
scm.branchExists.mockResolvedValueOnce(false);
|
|
scm.branchExists.mockResolvedValueOnce(true);
|
|
const res = await extractDependencies(config);
|
|
await updateRepo(config, res.branches);
|
|
expect(res).toEqual({
|
|
branchList: [undefined],
|
|
branches: [undefined],
|
|
packageFiles: undefined,
|
|
});
|
|
});
|
|
|
|
it('reads config from default branch if useBaseBranchConfig not specified', async () => {
|
|
scm.branchExists.mockResolvedValue(true);
|
|
platform.getJsonFile.mockResolvedValueOnce({});
|
|
config.baseBranches = ['master', 'dev'];
|
|
config.useBaseBranchConfig = 'none';
|
|
getCache().configFileName = 'renovate.json';
|
|
const res = await extractDependencies(config);
|
|
expect(res).toEqual({
|
|
branchList: [undefined, undefined],
|
|
branches: [undefined, undefined],
|
|
packageFiles: undefined,
|
|
});
|
|
expect(platform.getJsonFile).not.toHaveBeenCalledWith(
|
|
'renovate.json',
|
|
undefined,
|
|
'dev',
|
|
);
|
|
});
|
|
|
|
it('reads config from branches in baseBranches if useBaseBranchConfig specified', async () => {
|
|
scm.branchExists.mockResolvedValue(true);
|
|
platform.getJsonFile = jest
|
|
.fn()
|
|
.mockResolvedValue({ extends: [':approveMajorUpdates'] });
|
|
config.baseBranches = ['master', 'dev'];
|
|
config.useBaseBranchConfig = 'merge';
|
|
getCache().configFileName = 'renovate.json';
|
|
const res = await extractDependencies(config);
|
|
expect(res).toEqual({
|
|
branchList: [undefined, undefined],
|
|
branches: [undefined, undefined],
|
|
packageFiles: undefined,
|
|
});
|
|
expect(platform.getJsonFile).toHaveBeenCalledWith(
|
|
'renovate.json',
|
|
undefined,
|
|
'dev',
|
|
);
|
|
expect(addMeta).toHaveBeenNthCalledWith(1, { baseBranch: 'master' });
|
|
expect(addMeta).toHaveBeenNthCalledWith(2, { baseBranch: 'dev' });
|
|
});
|
|
|
|
it('handles config name mismatch between baseBranches if useBaseBranchConfig specified', async () => {
|
|
scm.branchExists.mockResolvedValue(true);
|
|
platform.getJsonFile = jest
|
|
.fn()
|
|
.mockImplementation((fileName, repoName, branchName) => {
|
|
if (branchName === 'dev') {
|
|
throw new Error();
|
|
}
|
|
return {};
|
|
});
|
|
getCache().configFileName = 'renovate.json';
|
|
config.baseBranches = ['master', 'dev'];
|
|
config.useBaseBranchConfig = 'merge';
|
|
await expect(extractDependencies(config)).rejects.toThrow(
|
|
CONFIG_VALIDATION,
|
|
);
|
|
expect(addMeta).toHaveBeenNthCalledWith(1, { baseBranch: 'master' });
|
|
expect(addMeta).toHaveBeenNthCalledWith(2, { baseBranch: 'dev' });
|
|
});
|
|
|
|
it('processes baseBranches dryRun extract', async () => {
|
|
extract.mockResolvedValue({} as never);
|
|
GlobalConfig.set({ dryRun: 'extract' });
|
|
const res = await extractDependencies(config);
|
|
await updateRepo(config, res.branches);
|
|
expect(res).toEqual({
|
|
branchList: [],
|
|
branches: [],
|
|
packageFiles: {},
|
|
});
|
|
expect(lookup).toHaveBeenCalledTimes(0);
|
|
});
|
|
|
|
it('finds baseBranches via regular expressions', async () => {
|
|
extract.mockResolvedValue({} as never);
|
|
config.baseBranches = ['/^release\\/.*/i', 'dev', '!/^pre-release\\/.*/'];
|
|
git.getBranchList.mockReturnValue([
|
|
'dev',
|
|
'pre-release/v0',
|
|
'RELEASE/v0',
|
|
'release/v1',
|
|
'release/v2',
|
|
'some-other',
|
|
]);
|
|
scm.branchExists.mockResolvedValue(true);
|
|
const res = await extractDependencies(config);
|
|
expect(res).toStrictEqual({
|
|
branchList: [undefined, undefined, undefined, undefined, undefined],
|
|
branches: [undefined, undefined, undefined, undefined, undefined],
|
|
packageFiles: undefined,
|
|
});
|
|
|
|
expect(logger.logger.debug).toHaveBeenCalledWith(
|
|
{
|
|
baseBranches: [
|
|
'RELEASE/v0',
|
|
'release/v1',
|
|
'release/v2',
|
|
'dev',
|
|
'some-other',
|
|
],
|
|
},
|
|
'baseBranches',
|
|
);
|
|
expect(addMeta).toHaveBeenCalledWith({ baseBranch: 'RELEASE/v0' });
|
|
expect(addMeta).toHaveBeenCalledWith({ baseBranch: 'release/v1' });
|
|
expect(addMeta).toHaveBeenCalledWith({ baseBranch: 'release/v2' });
|
|
expect(addMeta).toHaveBeenCalledWith({ baseBranch: 'dev' });
|
|
expect(addMeta).toHaveBeenCalledWith({ baseBranch: 'some-other' });
|
|
});
|
|
|
|
it('maps $default to defaultBranch', async () => {
|
|
extract.mockResolvedValue({} as never);
|
|
config.baseBranches = ['$default'];
|
|
config.defaultBranch = 'master';
|
|
git.getBranchList.mockReturnValue(['dev', 'master']);
|
|
scm.branchExists.mockResolvedValue(true);
|
|
const res = await extractDependencies(config);
|
|
expect(res).toStrictEqual({
|
|
branchList: [undefined],
|
|
branches: [undefined],
|
|
packageFiles: undefined,
|
|
});
|
|
expect(addMeta).toHaveBeenCalledWith({ baseBranch: 'master' });
|
|
});
|
|
});
|
|
});
|