Select Git revision
index.spec.ts
error-config.spec.ts 4.59 KiB
import { mock } from 'jest-mock-extended';
import { RenovateConfig, partial, platform } from '../../../test/util';
import { GlobalConfig } from '../../config/global';
import { CONFIG_VALIDATION } from '../../constants/error-messages';
import { logger } from '../../logger';
import type { Pr } from '../../modules/platform';
import {
raiseConfigWarningIssue,
raiseCredentialsWarningIssue,
} from './error-config';
jest.mock('../../modules/platform');
let config: RenovateConfig;
beforeEach(() => {
// default values
config = partial<RenovateConfig>({
onboardingBranch: 'configure/renovate',
suppressNotifications: ['deprecationWarningIssues'],
configWarningReuseIssue: true,
confidential: false,
});
});
describe('workers/repository/error-config', () => {
describe('raiseConfigWarningIssue()', () => {
beforeEach(() => {
GlobalConfig.reset();
});
it('returns if mode is silent', async () => {
config.mode = 'silent';
const res = await raiseConfigWarningIssue(
config,
new Error(CONFIG_VALIDATION),
);
expect(res).toBeUndefined();
expect(logger.debug).toHaveBeenCalledWith(
'Config warning issues are not created, updated or closed when mode=silent',
);
});
it('creates issues', async () => {
const expectedBody = `There are missing credentials for the authentication-required feature. As a precaution, Renovate will pause PRs until it is resolved.
Location: \`package.json\`
Error type: some-error
Message: some-message
`;
const error = new Error(CONFIG_VALIDATION);
error.validationSource = 'package.json';
error.validationMessage = 'some-message';
error.validationError = 'some-error';
platform.ensureIssue.mockResolvedValueOnce('created');
const res = await raiseCredentialsWarningIssue(config, error);
expect(res).toBeUndefined();
expect(logger.warn).toHaveBeenCalledWith(
{ configError: error, res: 'created' },
'Configuration Warning',
);
expect(platform.ensureIssue).toHaveBeenCalledWith(
expect.objectContaining({ body: expectedBody }),
);
});