renovate/lib/config/migrate-validate.ts

49 lines
1.6 KiB
TypeScript
Raw Normal View History

2019-07-17 08:14:56 +00:00
import is from '@sindresorhus/is';
2019-08-23 13:46:31 +00:00
import { logger } from '../logger';
import * as configMassage from './massage';
2020-05-01 16:03:48 +00:00
import * as configMigration from './migration';
2021-03-02 20:44:55 +00:00
import type { RenovateConfig, ValidationMessage } from './types';
2019-08-23 13:46:31 +00:00
import * as configValidation from './validation';
2019-07-17 08:14:56 +00:00
2019-08-23 13:46:31 +00:00
export async function migrateAndValidate(
config: RenovateConfig,
input: RenovateConfig
): Promise<RenovateConfig> {
logger.debug('migrateAndValidate()');
try {
const { isMigrated, migratedConfig } = configMigration.migrateConfig(input);
if (isMigrated) {
logger.debug(
{ oldConfig: input, newConfig: migratedConfig },
'Config migration necessary'
);
} else {
logger.debug('No config migration necessary');
}
const massagedConfig = configMassage.massageConfig(migratedConfig);
2018-03-22 12:14:28 +00:00
logger.debug({ config: massagedConfig }, 'massaged config');
2019-08-23 13:46:31 +00:00
const {
warnings,
errors,
}: {
warnings: ValidationMessage[];
errors: ValidationMessage[];
} = await configValidation.validateConfig(massagedConfig);
// istanbul ignore if
if (is.nonEmptyArray(warnings)) {
2021-02-02 12:13:13 +00:00
logger.warn({ warnings }, 'Found renovate config warnings');
}
if (is.nonEmptyArray(errors)) {
logger.info({ errors }, 'Found renovate config errors');
}
massagedConfig.errors = (config.errors || []).concat(errors);
if (!config.repoIsOnboarded) {
massagedConfig.warnings = (config.warnings || []).concat(warnings);
}
return massagedConfig;
} catch (err) /* istanbul ignore next */ {
logger.debug({ config: input }, 'migrateAndValidate error');
throw err;
}
}