renovate/lib/config/migrate-validate.ts
2021-02-02 13:13:13 +01:00

48 lines
1.6 KiB
TypeScript

import is from '@sindresorhus/is';
import { logger } from '../logger';
import { RenovateConfig, ValidationMessage } from './common';
import * as configMassage from './massage';
import * as configMigration from './migration';
import * as configValidation from './validation';
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);
logger.debug({ config: massagedConfig }, 'massaged config');
const {
warnings,
errors,
}: {
warnings: ValidationMessage[];
errors: ValidationMessage[];
} = await configValidation.validateConfig(massagedConfig);
// istanbul ignore if
if (is.nonEmptyArray(warnings)) {
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;
}
}