2019-07-17 08:14:56 +00:00
|
|
|
import is from '@sindresorhus/is';
|
|
|
|
|
2019-07-15 09:04:05 +00:00
|
|
|
const { logger } = require('../logger');
|
2017-11-03 07:25:51 +00:00
|
|
|
const configMigration = require('./migration');
|
|
|
|
const configMassage = require('./massage');
|
|
|
|
const configValidation = require('./validation');
|
|
|
|
|
2019-07-17 08:14:56 +00:00
|
|
|
export { migrateAndValidate };
|
2017-11-03 07:25:51 +00:00
|
|
|
|
2018-03-28 08:04:07 +00:00
|
|
|
async function migrateAndValidate(config, input) {
|
2017-12-18 08:39:52 +00:00
|
|
|
logger.debug('migrateAndValidate()');
|
2018-03-08 06:28:06 +00:00
|
|
|
try {
|
|
|
|
const { isMigrated, migratedConfig } = configMigration.migrateConfig(input);
|
|
|
|
if (isMigrated) {
|
|
|
|
logger.info(
|
|
|
|
{ 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');
|
2018-03-28 08:04:07 +00:00
|
|
|
const { warnings, errors } = await configValidation.validateConfig(
|
2018-03-08 06:28:06 +00:00
|
|
|
massagedConfig
|
2017-11-03 07:25:51 +00:00
|
|
|
);
|
2018-03-08 06:28:06 +00:00
|
|
|
// istanbul ignore if
|
2018-09-28 13:20:46 +00:00
|
|
|
if (is.nonEmptyArray(warnings)) {
|
2018-03-08 06:28:06 +00:00
|
|
|
logger.info({ warnings }, 'Found renovate config warnings');
|
|
|
|
}
|
2018-09-28 13:20:46 +00:00
|
|
|
if (is.nonEmptyArray(errors)) {
|
2018-03-08 06:28:06 +00:00
|
|
|
logger.info({ errors }, 'Found renovate config errors');
|
|
|
|
}
|
|
|
|
massagedConfig.errors = (config.errors || []).concat(errors);
|
|
|
|
if (!config.repoIsOnboarded) {
|
|
|
|
// TODO #556 - enable warnings in real PRs
|
|
|
|
massagedConfig.warnings = (config.warnings || []).concat(warnings);
|
|
|
|
}
|
|
|
|
return massagedConfig;
|
|
|
|
} catch (err) /* istanbul ignore next */ {
|
|
|
|
logger.debug({ config: input }, 'migrateAndValidate error');
|
|
|
|
throw err;
|
2017-11-03 07:25:51 +00:00
|
|
|
}
|
|
|
|
}
|