mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-13 15:36:25 +00:00
fix(npm): better logs when transitive remediation is prevented
This commit is contained in:
parent
c482661cf5
commit
570ce0ccee
2 changed files with 24 additions and 10 deletions
|
@ -1,4 +1,5 @@
|
||||||
import type { PackageJson } from 'type-fest';
|
import type { PackageJson } from 'type-fest';
|
||||||
|
import { logger } from '../../../../logger';
|
||||||
import { api as semver } from '../../../../versioning/npm';
|
import { api as semver } from '../../../../versioning/npm';
|
||||||
import type { PackageLockOrEntry, ParentDependency } from './types';
|
import type { PackageLockOrEntry, ParentDependency } from './types';
|
||||||
|
|
||||||
|
@ -29,16 +30,26 @@ export function findDepConstraints(
|
||||||
const { dependencies, requires, version } = lockEntry;
|
const { dependencies, requires, version } = lockEntry;
|
||||||
if (parentDepName && requires) {
|
if (parentDepName && requires) {
|
||||||
const constraint = requires[depName];
|
const constraint = requires[depName];
|
||||||
if (constraint && semver.matches(currentVersion, constraint)) {
|
if (constraint) {
|
||||||
if (constraint === currentVersion) {
|
// istanbul ignore else
|
||||||
// Workaround for old versions of npm which wrote the exact version in requires instead of the constraint
|
if (semver.isValid(constraint)) {
|
||||||
requires[depName] = newVersion;
|
if (semver.matches(currentVersion, constraint)) {
|
||||||
|
if (constraint === currentVersion) {
|
||||||
|
// Workaround for old versions of npm which wrote the exact version in requires instead of the constraint
|
||||||
|
requires[depName] = newVersion;
|
||||||
|
}
|
||||||
|
parents.push({
|
||||||
|
parentDepName,
|
||||||
|
parentVersion: version,
|
||||||
|
constraint,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
logger.warn(
|
||||||
|
{ parentDepName, depName, currentVersion, constraint },
|
||||||
|
'Parent constraint is invalid'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
parents.push({
|
|
||||||
parentDepName,
|
|
||||||
parentVersion: version,
|
|
||||||
constraint,
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (dependencies) {
|
if (dependencies) {
|
||||||
|
|
|
@ -89,7 +89,10 @@ export async function updateLockedDependency(
|
||||||
);
|
);
|
||||||
logger.trace({ deps: lockedDeps, constraints }, 'Matching details');
|
logger.trace({ deps: lockedDeps, constraints }, 'Matching details');
|
||||||
if (!constraints.length) {
|
if (!constraints.length) {
|
||||||
logger.warn('Could not find constraints for the locked dependency');
|
logger.info(
|
||||||
|
{ depName, currentVersion, newVersion },
|
||||||
|
'Could not find constraints for the locked dependency - cannot remediate'
|
||||||
|
);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
const parentUpdates: UpdateLockedConfig[] = [];
|
const parentUpdates: UpdateLockedConfig[] = [];
|
||||||
|
|
Loading…
Reference in a new issue