mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-25 14:06:27 +00:00
refactor: Simplify lookup function (#32968)
This commit is contained in:
parent
8a52e50b3f
commit
ab09e25e9c
3 changed files with 95 additions and 89 deletions
|
@ -1,56 +0,0 @@
|
||||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
||||||
|
|
||||||
exports[`workers/repository/process/fetch fetchUpdates() fetches updates 1`] = `
|
|
||||||
{
|
|
||||||
"maven": [
|
|
||||||
{
|
|
||||||
"deps": [
|
|
||||||
{
|
|
||||||
"datasource": "maven",
|
|
||||||
"depName": "bbb",
|
|
||||||
"packageName": "bbb",
|
|
||||||
"updates": [
|
|
||||||
"a",
|
|
||||||
"b",
|
|
||||||
],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"extractedConstraints": {
|
|
||||||
"other": "constraint",
|
|
||||||
"some": "constraint",
|
|
||||||
},
|
|
||||||
"packageFile": "pom.xml",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
|
|
||||||
exports[`workers/repository/process/fetch fetchUpdates() handles ignored, skipped and disabled 1`] = `
|
|
||||||
{
|
|
||||||
"npm": [
|
|
||||||
{
|
|
||||||
"deps": [
|
|
||||||
{
|
|
||||||
"depName": "abcd",
|
|
||||||
"packageName": "abcd",
|
|
||||||
"skipReason": "ignored",
|
|
||||||
"updates": [],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"depName": "foo",
|
|
||||||
"packageName": "foo",
|
|
||||||
"skipReason": "disabled",
|
|
||||||
"updates": [],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"depName": "skipped",
|
|
||||||
"packageName": "skipped",
|
|
||||||
"skipReason": "some-reason",
|
|
||||||
"updates": [],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"packageFile": "package.json",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
}
|
|
||||||
`;
|
|
|
@ -50,7 +50,33 @@ describe('workers/repository/process/fetch', () => {
|
||||||
],
|
],
|
||||||
};
|
};
|
||||||
await fetchUpdates(config, packageFiles);
|
await fetchUpdates(config, packageFiles);
|
||||||
expect(packageFiles).toMatchSnapshot();
|
expect(packageFiles).toEqual({
|
||||||
|
npm: [
|
||||||
|
{
|
||||||
|
deps: [
|
||||||
|
{
|
||||||
|
depName: 'abcd',
|
||||||
|
packageName: 'abcd',
|
||||||
|
skipReason: 'ignored',
|
||||||
|
updates: [],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
depName: 'foo',
|
||||||
|
packageName: 'foo',
|
||||||
|
skipReason: 'disabled',
|
||||||
|
updates: [],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
depName: 'skipped',
|
||||||
|
packageName: 'skipped',
|
||||||
|
skipReason: 'some-reason',
|
||||||
|
updates: [],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
packageFile: 'package.json',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
expect(packageFiles.npm[0].deps[0].skipReason).toBe('ignored');
|
expect(packageFiles.npm[0].deps[0].skipReason).toBe('ignored');
|
||||||
expect(packageFiles.npm[0].deps[0].updates).toHaveLength(0);
|
expect(packageFiles.npm[0].deps[0].updates).toHaveLength(0);
|
||||||
expect(packageFiles.npm[0].deps[1].skipReason).toBe('disabled');
|
expect(packageFiles.npm[0].deps[1].skipReason).toBe('disabled');
|
||||||
|
@ -71,7 +97,22 @@ describe('workers/repository/process/fetch', () => {
|
||||||
};
|
};
|
||||||
lookupUpdates.mockResolvedValue({ updates: ['a', 'b'] } as never);
|
lookupUpdates.mockResolvedValue({ updates: ['a', 'b'] } as never);
|
||||||
await fetchUpdates(config, packageFiles);
|
await fetchUpdates(config, packageFiles);
|
||||||
expect(packageFiles).toMatchSnapshot();
|
expect(packageFiles).toEqual({
|
||||||
|
maven: [
|
||||||
|
{
|
||||||
|
deps: [
|
||||||
|
{
|
||||||
|
datasource: 'maven',
|
||||||
|
depName: 'bbb',
|
||||||
|
packageName: 'bbb',
|
||||||
|
updates: ['a', 'b'],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
extractedConstraints: { other: 'constraint', some: 'constraint' },
|
||||||
|
packageFile: 'pom.xml',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('skips deps with empty names', async () => {
|
it('skips deps with empty names', async () => {
|
||||||
|
|
|
@ -17,27 +17,38 @@ import { Result } from '../../../util/result';
|
||||||
import { LookupStats } from '../../../util/stats';
|
import { LookupStats } from '../../../util/stats';
|
||||||
import { PackageFiles } from '../package-files';
|
import { PackageFiles } from '../package-files';
|
||||||
import { lookupUpdates } from './lookup';
|
import { lookupUpdates } from './lookup';
|
||||||
import type { LookupUpdateConfig } from './lookup/types';
|
import type { LookupUpdateConfig, UpdateResult } from './lookup/types';
|
||||||
|
|
||||||
async function fetchDepUpdates(
|
type LookupResult = Result<PackageDependency, Error>;
|
||||||
|
|
||||||
|
async function lookup(
|
||||||
packageFileConfig: RenovateConfig & PackageFile,
|
packageFileConfig: RenovateConfig & PackageFile,
|
||||||
indep: PackageDependency,
|
indep: PackageDependency,
|
||||||
): Promise<Result<PackageDependency, Error>> {
|
): Promise<LookupResult> {
|
||||||
const dep = clone(indep);
|
const dep = clone(indep);
|
||||||
|
|
||||||
dep.updates = [];
|
dep.updates = [];
|
||||||
|
|
||||||
if (is.string(dep.depName)) {
|
if (is.string(dep.depName)) {
|
||||||
dep.depName = dep.depName.trim();
|
dep.depName = dep.depName.trim();
|
||||||
}
|
}
|
||||||
|
|
||||||
dep.packageName ??= dep.depName;
|
dep.packageName ??= dep.depName;
|
||||||
if (!is.nonEmptyString(dep.packageName)) {
|
|
||||||
dep.skipReason = 'invalid-name';
|
|
||||||
}
|
|
||||||
if (dep.isInternal && !packageFileConfig.updateInternalDeps) {
|
|
||||||
dep.skipReason = 'internal-package';
|
|
||||||
}
|
|
||||||
if (dep.skipReason) {
|
if (dep.skipReason) {
|
||||||
return Result.ok(dep);
|
return Result.ok(dep);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!is.nonEmptyString(dep.packageName)) {
|
||||||
|
dep.skipReason = 'invalid-name';
|
||||||
|
return Result.ok(dep);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dep.isInternal && !packageFileConfig.updateInternalDeps) {
|
||||||
|
dep.skipReason = 'internal-package';
|
||||||
|
return Result.ok(dep);
|
||||||
|
}
|
||||||
|
|
||||||
const { depName } = dep;
|
const { depName } = dep;
|
||||||
// TODO: fix types
|
// TODO: fix types
|
||||||
let depConfig = mergeChildConfig(packageFileConfig, dep);
|
let depConfig = mergeChildConfig(packageFileConfig, dep);
|
||||||
|
@ -46,24 +57,33 @@ async function fetchDepUpdates(
|
||||||
depConfig.versioning ??= getDefaultVersioning(depConfig.datasource);
|
depConfig.versioning ??= getDefaultVersioning(depConfig.datasource);
|
||||||
depConfig = await applyPackageRules(depConfig, 'pre-lookup');
|
depConfig = await applyPackageRules(depConfig, 'pre-lookup');
|
||||||
depConfig.packageName ??= depConfig.depName;
|
depConfig.packageName ??= depConfig.depName;
|
||||||
|
|
||||||
if (depConfig.ignoreDeps!.includes(depName!)) {
|
if (depConfig.ignoreDeps!.includes(depName!)) {
|
||||||
// TODO: fix types (#22198)
|
// TODO: fix types (#22198)
|
||||||
logger.debug(`Dependency: ${depName!}, is ignored`);
|
logger.debug(`Dependency: ${depName!}, is ignored`);
|
||||||
dep.skipReason = 'ignored';
|
dep.skipReason = 'ignored';
|
||||||
} else if (depConfig.enabled === false) {
|
return Result.ok(dep);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (depConfig.enabled === false) {
|
||||||
logger.debug(`Dependency: ${depName!}, is disabled`);
|
logger.debug(`Dependency: ${depName!}, is disabled`);
|
||||||
dep.skipReason = 'disabled';
|
dep.skipReason = 'disabled';
|
||||||
} else {
|
return Result.ok(dep);
|
||||||
if (depConfig.datasource) {
|
}
|
||||||
const { val: updateResult, err } = await LookupStats.wrap(
|
|
||||||
depConfig.datasource,
|
|
||||||
() =>
|
|
||||||
Result.wrap(lookupUpdates(depConfig as LookupUpdateConfig)).unwrap(),
|
|
||||||
);
|
|
||||||
|
|
||||||
if (updateResult) {
|
if (!depConfig.datasource) {
|
||||||
Object.assign(dep, updateResult);
|
return Result.ok(dep);
|
||||||
} else {
|
}
|
||||||
|
|
||||||
|
return LookupStats.wrap(depConfig.datasource, async () => {
|
||||||
|
return await Result.wrap(lookupUpdates(depConfig as LookupUpdateConfig))
|
||||||
|
.onValue((dep) => {
|
||||||
|
logger.trace({ dep }, 'Dependency lookup success');
|
||||||
|
})
|
||||||
|
.onError((err) => {
|
||||||
|
logger.trace({ err, depName }, 'Dependency lookup error');
|
||||||
|
})
|
||||||
|
.catch((err): Result<UpdateResult, Error> => {
|
||||||
if (
|
if (
|
||||||
packageFileConfig.repoIsOnboarded === true ||
|
packageFileConfig.repoIsOnboarded === true ||
|
||||||
!(err instanceof ExternalHostError)
|
!(err instanceof ExternalHostError)
|
||||||
|
@ -72,17 +92,18 @@ async function fetchDepUpdates(
|
||||||
}
|
}
|
||||||
|
|
||||||
const cause = err.err;
|
const cause = err.err;
|
||||||
dep.warnings ??= [];
|
return Result.ok({
|
||||||
dep.warnings.push({
|
updates: [],
|
||||||
topic: 'Lookup Error',
|
warnings: [
|
||||||
// TODO: types (#22198)
|
{
|
||||||
message: `${depName!}: ${cause.message}`,
|
topic: 'Lookup Error',
|
||||||
|
message: `${depName}: ${cause.message}`,
|
||||||
|
},
|
||||||
|
],
|
||||||
});
|
});
|
||||||
}
|
})
|
||||||
}
|
.transform((upd): PackageDependency => Object.assign(dep, upd));
|
||||||
dep.updates ??= [];
|
});
|
||||||
}
|
|
||||||
return Result.ok(dep);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async function fetchManagerPackagerFileUpdates(
|
async function fetchManagerPackagerFileUpdates(
|
||||||
|
@ -101,7 +122,7 @@ async function fetchManagerPackagerFileUpdates(
|
||||||
const { manager } = packageFileConfig;
|
const { manager } = packageFileConfig;
|
||||||
const queue = pFile.deps.map(
|
const queue = pFile.deps.map(
|
||||||
(dep) => async (): Promise<PackageDependency> => {
|
(dep) => async (): Promise<PackageDependency> => {
|
||||||
const updates = await fetchDepUpdates(packageFileConfig, dep);
|
const updates = await lookup(packageFileConfig, dep);
|
||||||
return updates.unwrapOrThrow();
|
return updates.unwrapOrThrow();
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in a new issue