2020-04-24 20:46:48 +00:00
|
|
|
import { hrtime } from 'process';
|
2020-05-01 16:03:48 +00:00
|
|
|
import { RenovateConfig } from '../../../config';
|
2020-01-06 08:16:15 +00:00
|
|
|
import { logger } from '../../../logger';
|
|
|
|
import { PackageFile } from '../../../manager/common';
|
|
|
|
import { BranchConfig } from '../../common';
|
2020-05-01 16:03:48 +00:00
|
|
|
import { extractAllDependencies } from '../extract';
|
|
|
|
import { branchifyUpgrades } from '../updates/branchify';
|
|
|
|
import { raiseDeprecationWarnings } from './deprecated';
|
|
|
|
import { fetchUpdates } from './fetch';
|
|
|
|
import { sortBranches } from './sort';
|
|
|
|
import { WriteUpdateResult, writeUpdates } from './write';
|
2020-01-06 08:16:15 +00:00
|
|
|
|
2020-04-18 13:36:38 +00:00
|
|
|
export type ExtractResult = {
|
2020-01-06 08:16:15 +00:00
|
|
|
branches: BranchConfig[];
|
|
|
|
branchList: string[];
|
2020-04-18 13:36:38 +00:00
|
|
|
packageFiles: Record<string, PackageFile[]>;
|
2020-01-06 08:16:15 +00:00
|
|
|
};
|
|
|
|
|
2020-04-24 20:46:48 +00:00
|
|
|
// istanbul ignore next
|
|
|
|
function extractStats(packageFiles: Record<string, PackageFile[]>): any {
|
|
|
|
if (!packageFiles) {
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
const stats = {
|
|
|
|
managers: {},
|
|
|
|
total: {
|
|
|
|
fileCount: 0,
|
|
|
|
depCount: 0,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
for (const [manager, managerPackageFiles] of Object.entries(packageFiles)) {
|
|
|
|
const fileCount = managerPackageFiles.length;
|
|
|
|
let depCount = 0;
|
|
|
|
for (const file of managerPackageFiles) {
|
|
|
|
depCount += file.deps.length;
|
|
|
|
}
|
|
|
|
stats.managers[manager] = {
|
|
|
|
fileCount,
|
|
|
|
depCount,
|
|
|
|
};
|
|
|
|
stats.total.fileCount += fileCount;
|
|
|
|
stats.total.depCount += depCount;
|
|
|
|
}
|
|
|
|
return stats;
|
|
|
|
}
|
|
|
|
|
2020-04-18 13:36:38 +00:00
|
|
|
export async function extract(config: RenovateConfig): Promise<ExtractResult> {
|
2020-01-06 08:16:15 +00:00
|
|
|
logger.debug('extractAndUpdate()');
|
2020-04-24 20:46:48 +00:00
|
|
|
const startTime = hrtime();
|
2020-01-06 08:16:15 +00:00
|
|
|
const packageFiles = await extractAllDependencies(config);
|
2020-04-24 20:46:48 +00:00
|
|
|
const duration = hrtime(startTime);
|
|
|
|
const seconds = Math.round(duration[0] + duration[1] / 1e9);
|
|
|
|
const stats = extractStats(packageFiles);
|
|
|
|
logger.info({ stats, seconds }, `Dependency extraction complete`);
|
2020-01-06 08:16:15 +00:00
|
|
|
logger.trace({ config: packageFiles }, 'packageFiles');
|
|
|
|
await fetchUpdates(config, packageFiles);
|
|
|
|
logger.debug({ config: packageFiles }, 'packageFiles with updates');
|
|
|
|
await raiseDeprecationWarnings(config, packageFiles);
|
2020-04-09 13:44:23 +00:00
|
|
|
const { branches, branchList } = await branchifyUpgrades(
|
|
|
|
config,
|
|
|
|
packageFiles
|
|
|
|
);
|
2020-01-06 08:16:15 +00:00
|
|
|
sortBranches(branches);
|
2020-04-18 13:36:38 +00:00
|
|
|
return { branches, branchList, packageFiles };
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function update(
|
|
|
|
config: RenovateConfig,
|
|
|
|
branches: BranchConfig[],
|
|
|
|
branchList: string[],
|
|
|
|
packageFiles: Record<string, PackageFile[]>
|
|
|
|
): Promise<WriteUpdateResult | undefined> {
|
2020-01-06 08:16:15 +00:00
|
|
|
let res: WriteUpdateResult | undefined;
|
|
|
|
// istanbul ignore else
|
|
|
|
if (config.repoIsOnboarded) {
|
|
|
|
res = await writeUpdates(config, packageFiles, branches);
|
|
|
|
}
|
2020-04-18 13:36:38 +00:00
|
|
|
|
|
|
|
return res;
|
2020-01-06 08:16:15 +00:00
|
|
|
}
|