feat(repo/lookup): log registry urls used at the lookup phase (#19332)

This commit is contained in:
Gabriel-Ladzaretti 2022-12-12 10:23:03 +02:00 committed by GitHub
parent 645f5d5194
commit 66159ac549
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 49 additions and 17 deletions

View file

@ -139,20 +139,21 @@ async function mergeRegistries(
for (const registryUrl of registryUrls) { for (const registryUrl of registryUrls) {
try { try {
const res = await getRegistryReleases(datasource, config, registryUrl); const res = await getRegistryReleases(datasource, config, registryUrl);
if (res) { if (!res) {
if (combinedRes) { continue;
for (const existingRelease of combinedRes.releases || []) { }
existingRelease.registryUrl = combinedRes.registryUrl; if (combinedRes) {
} for (const existingRelease of combinedRes.releases || []) {
for (const additionalRelease of res.releases || []) { existingRelease.registryUrl ??= combinedRes.registryUrl;
additionalRelease.registryUrl = res.registryUrl;
}
combinedRes = { ...res, ...combinedRes };
delete combinedRes.registryUrl;
combinedRes.releases = [...combinedRes.releases, ...res.releases];
} else {
combinedRes = res;
} }
for (const additionalRelease of res.releases || []) {
additionalRelease.registryUrl = res.registryUrl;
}
combinedRes = { ...res, ...combinedRes };
delete combinedRes.registryUrl;
combinedRes.releases = [...combinedRes.releases, ...res.releases];
} else {
combinedRes = res;
} }
} catch (err) { } catch (err) {
if (err instanceof ExternalHostError) { if (err instanceof ExternalHostError) {

View file

@ -135,6 +135,7 @@ export interface LookupUpdate {
checksumUrl?: string; checksumUrl?: string;
downloadUrl?: string; downloadUrl?: string;
releaseTimestamp?: any; releaseTimestamp?: any;
registryUrl?: string;
} }
export interface PackageDependency<T = Record<string, any>> extends Package<T> { export interface PackageDependency<T = Record<string, any>> extends Package<T> {

View file

@ -8,6 +8,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() handles digest
"fixedVersion": "8.0.0", "fixedVersion": "8.0.0",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": undefined,
"sourceUrl": "https://github.com/nodejs/node", "sourceUrl": "https://github.com/nodejs/node",
"updates": [ "updates": [
{ {
@ -53,6 +54,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() handles digest
"dependencyUrl": undefined, "dependencyUrl": undefined,
"fixedVersion": "8.1.0", "fixedVersion": "8.1.0",
"homepage": undefined, "homepage": undefined,
"registryUrl": undefined,
"sourceUrl": "https://github.com/nodejs/node", "sourceUrl": "https://github.com/nodejs/node",
"updates": [ "updates": [
{ {
@ -75,6 +77,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() handles digest
"fixedVersion": "8.0.0", "fixedVersion": "8.0.0",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": undefined,
"sourceUrl": "https://github.com/nodejs/node", "sourceUrl": "https://github.com/nodejs/node",
"updates": [ "updates": [
{ {
@ -132,6 +135,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() handles replac
"dependencyUrl": undefined, "dependencyUrl": undefined,
"fixedVersion": "1.4.1", "fixedVersion": "1.4.1",
"homepage": undefined, "homepage": undefined,
"registryUrl": "https://registry.npmjs.org",
"sourceUrl": "https://github.com/kriskowal/q", "sourceUrl": "https://github.com/kriskowal/q",
"updates": [ "updates": [
{ {
@ -153,6 +157,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() handles source
"fixedVersion": "0.9.99", "fixedVersion": "0.9.99",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": "https://registry.npmjs.org",
"sourceUrl": "https://github.com/kriskowal/q", "sourceUrl": "https://github.com/kriskowal/q",
"updates": [ "updates": [
{ {
@ -215,6 +220,7 @@ Marking the latest version of an npm package as deprecated results in the entire
"fixedVersion": "1.3.0", "fixedVersion": "1.3.0",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": "https://registry.npmjs.org",
"sourceUrl": "https://github.com/kriskowal/q", "sourceUrl": "https://github.com/kriskowal/q",
"updates": [ "updates": [
{ {
@ -240,6 +246,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() is deprecated
"fixedVersion": "1.3.0", "fixedVersion": "1.3.0",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": "https://registry.npmjs.org",
"sourceDirectory": "test", "sourceDirectory": "test",
"sourceUrl": "https://github.com/kriskowal/q", "sourceUrl": "https://github.com/kriskowal/q",
"updates": [ "updates": [
@ -298,6 +305,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() returns comple
"fixedVersion": "1.3.0", "fixedVersion": "1.3.0",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": "https://registry.npmjs.org",
"sourceUrl": "https://github.com/kriskowal/q", "sourceUrl": "https://github.com/kriskowal/q",
"updates": [ "updates": [
{ {
@ -464,6 +472,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() should downgra
"newMajor": 1, "newMajor": 1,
"newValue": "1.16.0", "newValue": "1.16.0",
"newVersion": "1.16.0", "newVersion": "1.16.0",
"registryUrl": undefined,
"updateType": "rollback", "updateType": "rollback",
} }
`; `;
@ -517,6 +526,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() should roll ba
"newMajor": 3, "newMajor": 3,
"newValue": "3.0.1-insiders.20180726", "newValue": "3.0.1-insiders.20180726",
"newVersion": "3.0.1-insiders.20180726", "newVersion": "3.0.1-insiders.20180726",
"registryUrl": undefined,
"updateType": "rollback", "updateType": "rollback",
}, },
] ]
@ -546,6 +556,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() skips uncompat
"fixedVersion": "8", "fixedVersion": "8",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": undefined,
"sourceUrl": "https://github.com/nodejs/node", "sourceUrl": "https://github.com/nodejs/node",
"updates": [ "updates": [
{ {
@ -570,6 +581,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() skips uncompat
"fixedVersion": "8.1", "fixedVersion": "8.1",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": undefined,
"sourceUrl": "https://github.com/nodejs/node", "sourceUrl": "https://github.com/nodejs/node",
"updates": [ "updates": [
{ {
@ -602,6 +614,7 @@ exports[`workers/repository/process/lookup/index .lookupUpdates() skips uncompat
"fixedVersion": "8.1.0", "fixedVersion": "8.1.0",
"homepage": undefined, "homepage": undefined,
"isSingleVersion": true, "isSingleVersion": true,
"registryUrl": undefined,
"sourceUrl": "https://github.com/nodejs/node", "sourceUrl": "https://github.com/nodejs/node",
"updates": [ "updates": [
{ {

View file

@ -37,6 +37,15 @@ export function generateUpdate(
if (release.releaseTimestamp !== undefined) { if (release.releaseTimestamp !== undefined) {
update.releaseTimestamp = release.releaseTimestamp; update.releaseTimestamp = release.releaseTimestamp;
} }
// istanbul ignore if
if (release.registryUrl !== undefined) {
/**
* This means:
* - registry strategy is set to merge
* - releases were fetched from multiple registry urls
*/
update.registryUrl = release.registryUrl;
}
const { currentValue } = config; const { currentValue } = config;
if (currentValue) { if (currentValue) {

View file

@ -95,6 +95,7 @@ export async function lookupUpdates(
} }
res.sourceUrl = dependency?.sourceUrl; res.sourceUrl = dependency?.sourceUrl;
res.registryUrl = dependency?.registryUrl; // undefined when we fetched releases from multiple registries
if (dependency.sourceDirectory) { if (dependency.sourceDirectory) {
res.sourceDirectory = dependency.sourceDirectory; res.sourceDirectory = dependency.sourceDirectory;
} }

View file

@ -40,14 +40,19 @@ export function getRollbackUpdate(
); );
lessThanVersions.sort((a, b) => version.sortVersions(a.version, b.version)); lessThanVersions.sort((a, b) => version.sortVersions(a.version, b.version));
let newVersion; let newRelease;
if (currentValue && version.isStable(currentValue)) { if (currentValue && version.isStable(currentValue)) {
newVersion = lessThanVersions newRelease = lessThanVersions
.filter((v) => version.isStable(v.version)) .filter((v) => version.isStable(v.version))
.pop()?.version; .pop();
} }
let newVersion = newRelease?.version;
let registryUrl = newRelease?.registryUrl;
if (!newVersion) { if (!newVersion) {
newVersion = lessThanVersions.pop()?.version; newRelease = lessThanVersions.pop();
newVersion = newRelease?.version;
registryUrl = newRelease?.registryUrl;
} }
// istanbul ignore if // istanbul ignore if
if (!newVersion) { if (!newVersion) {
@ -66,6 +71,7 @@ export function getRollbackUpdate(
newMajor: version.getMajor(newVersion)!, newMajor: version.getMajor(newVersion)!,
newValue: newValue!, newValue: newValue!,
newVersion, newVersion,
registryUrl,
updateType: 'rollback', updateType: 'rollback',
}; };
} }

View file

@ -59,6 +59,7 @@ export interface UpdateResult {
currentVersion?: string; currentVersion?: string;
isSingleVersion?: boolean; isSingleVersion?: boolean;
skipReason?: SkipReason; skipReason?: SkipReason;
registryUrl?: string;
releases: Release[]; releases: Release[];
fixedVersion?: string; fixedVersion?: string;
updates: LookupUpdate[]; updates: LookupUpdate[];