renovate 43.204.0 → 43.204.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -359,14 +359,13 @@ async function checkForPendingVersions(manager, packageFileName, packageFileCont
|
|
|
359
359
|
if (!upgradeInfo) continue;
|
|
360
360
|
const resolvedVersion = dep.lockedVersion ?? dep.newVersion ?? dep.currentVersion ?? dep.currentValue;
|
|
361
361
|
if (!resolvedVersion) {
|
|
362
|
-
logger.
|
|
362
|
+
logger.warn({
|
|
363
363
|
packageFile: packageFileName,
|
|
364
364
|
manager,
|
|
365
365
|
branchName: config.branchName,
|
|
366
|
-
depName
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
throw new Error(WORKER_FILE_UPDATE_FAILED);
|
|
366
|
+
depName
|
|
367
|
+
}, `Could not determine resolved version for '${depName}' after updating '${packageFileName}'; skipping pending-version check`);
|
|
368
|
+
continue;
|
|
370
369
|
}
|
|
371
370
|
if (resolvedVersion && upgradeInfo.pendingVersions.has(resolvedVersion)) {
|
|
372
371
|
const expectedVersion = upgradeInfo.newVersion;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-updated.js","names":[],"sources":["../../../../../lib/workers/repository/update/branch/get-updated.ts"],"sourcesContent":["import { isNonEmptyArray } from '@sindresorhus/is';\nimport { WORKER_FILE_UPDATE_FAILED } from '../../../../constants/error-messages.ts';\nimport { logger } from '../../../../logger/index.ts';\nimport { extractPackageFile, get } from '../../../../modules/manager/index.ts';\nimport type {\n ArtifactError,\n ArtifactNotice,\n PackageFile,\n UpdateArtifact,\n UpdateArtifactsConfig,\n UpdateArtifactsResult,\n} from '../../../../modules/manager/types.ts';\nimport { getFile } from '../../../../util/git/index.ts';\nimport type { FileAddition, FileChange } from '../../../../util/git/types.ts';\nimport { coerceString } from '../../../../util/string.ts';\nimport type { BranchConfig, BranchUpgradeConfig } from '../../../types.ts';\nimport { doAutoReplace } from './auto-replace.ts';\n\nexport interface PackageFilesResult {\n artifactErrors: ArtifactError[];\n reuseExistingBranch?: boolean;\n updatedPackageFiles: FileChange[];\n updatedArtifacts: FileChange[];\n artifactNotices: ArtifactNotice[];\n}\n\nasync function getFileContent(\n updatedFileContents: Record<string, string>,\n filePath: string,\n config: BranchConfig,\n): Promise<string | null> {\n let fileContent: string | null = updatedFileContents[filePath];\n if (!fileContent) {\n fileContent = await getFile(\n filePath,\n config.reuseExistingBranch ? config.branchName : config.baseBranch,\n );\n }\n return fileContent;\n}\n\nfunction sortPackageFiles(\n config: BranchConfig,\n manager: string,\n packageFiles: FilePath[],\n): void {\n const managerPackageFiles = config.packageFiles?.[manager];\n if (!managerPackageFiles) {\n return;\n }\n packageFiles.sort((lhs, rhs) => {\n const lhsIndex = managerPackageFiles.findIndex(\n (entry) => entry.packageFile === lhs.path,\n );\n const rhsIndex = managerPackageFiles.findIndex(\n (entry) => entry.packageFile === rhs.path,\n );\n return lhsIndex - rhsIndex;\n });\n}\n\nfunction hasAny(set: Set<string>, targets: Iterable<string>): boolean {\n for (const target of targets) {\n if (set.has(target)) {\n return true;\n }\n }\n return false;\n}\n\ntype FilePath = Pick<FileChange, 'path'>;\n\nfunction getManagersForPackageFiles<T extends FilePath>(\n packageFiles: T[],\n managerPackageFiles: Record<string, Set<string>>,\n): Set<string> {\n const packageFileNames = packageFiles.map((packageFile) => packageFile.path);\n return new Set(\n Object.keys(managerPackageFiles).filter((manager) =>\n hasAny(managerPackageFiles[manager], packageFileNames),\n ),\n );\n}\n\nfunction getPackageFilesForManager<T extends FilePath>(\n packageFiles: T[],\n managerPackageFiles: Set<string>,\n): T[] {\n return packageFiles.filter((packageFile) =>\n managerPackageFiles.has(packageFile.path),\n );\n}\n\nexport async function getUpdatedPackageFiles(\n config: BranchConfig,\n): Promise<PackageFilesResult> {\n logger.trace({ config });\n const reuseExistingBranch = config.reuseExistingBranch!;\n logger.debug(\n `manager.getUpdatedPackageFiles() reuseExistingBranch=${reuseExistingBranch}`,\n );\n let updatedFileContents: Record<string, string> = {};\n const nonUpdatedFileContents: Record<string, string> = {};\n const managerPackageFiles: Record<string, Set<string>> = {};\n const packageFileUpdatedDeps: Record<string, BranchUpgradeConfig[]> = {};\n const lockFileMaintenanceFiles: string[] = [];\n let firstUpdate = true;\n for (const upgrade of config.upgrades) {\n const manager = upgrade.manager;\n const packageFile = upgrade.packageFile!;\n const depName = upgrade.depName!;\n // TODO: fix types, can be undefined (#22198)\n const newVersion = upgrade.newVersion!;\n const currentVersion = upgrade.currentVersion!;\n const updateLockedDependency = get(manager, 'updateLockedDependency')!;\n managerPackageFiles[manager] ??= new Set<string>();\n managerPackageFiles[manager].add(packageFile);\n packageFileUpdatedDeps[packageFile] ??= [];\n packageFileUpdatedDeps[packageFile].push({ ...upgrade });\n const packageFileContent = await getFileContent(\n updatedFileContents,\n packageFile,\n config,\n );\n let lockFileContent: string | null = null;\n const lockFile = upgrade.lockFile ?? upgrade.lockFiles?.[0] ?? '';\n if (lockFile) {\n lockFileContent = await getFileContent(\n updatedFileContents,\n lockFile,\n config,\n );\n }\n // istanbul ignore if\n if (\n reuseExistingBranch &&\n (!packageFileContent || (lockFile && !lockFileContent))\n ) {\n logger.debug(\n { packageFile, depName },\n 'Rebasing branch after file not found',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n if (upgrade.updateType === 'lockFileMaintenance') {\n lockFileMaintenanceFiles.push(packageFile);\n } else if (upgrade.isRemediation) {\n const { status, files } = await updateLockedDependency({\n ...upgrade,\n depName,\n newVersion,\n currentVersion,\n packageFile,\n packageFileContent: packageFileContent!,\n lockFile,\n lockFileContent: lockFileContent!,\n allowParentUpdates: true,\n allowHigherOrRemoved: true,\n });\n if (reuseExistingBranch && status !== 'already-updated') {\n logger.debug(\n { lockFile, depName, status },\n 'Need to retry branch as it is not already up-to-date',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n if (files) {\n updatedFileContents = { ...updatedFileContents, ...files };\n Object.keys(files).forEach(\n (file) => delete nonUpdatedFileContents[file],\n );\n }\n if (status === 'update-failed' || status === 'unsupported') {\n upgrade.remediationNotPossible = true;\n }\n } else if (upgrade.isLockfileUpdate) {\n if (updateLockedDependency) {\n const { status, files } = await updateLockedDependency({\n ...upgrade,\n depName,\n newVersion,\n currentVersion,\n packageFile,\n packageFileContent: packageFileContent!,\n lockFile,\n lockFileContent: lockFileContent!,\n allowParentUpdates: false,\n });\n if (status === 'unsupported') {\n // incompatible lock file\n if (!updatedFileContents[packageFile]) {\n nonUpdatedFileContents[packageFile] = packageFileContent!;\n }\n } else if (status === 'already-updated') {\n logger.debug(\n `Upgrade of ${depName} to ${newVersion} is already done in existing branch`,\n );\n } else {\n // something changed\n if (reuseExistingBranch) {\n logger.debug(\n { lockFile, depName, status },\n 'Need to retry branch as upgrade requirements are not mets',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n if (files) {\n updatedFileContents = { ...updatedFileContents, ...files };\n Object.keys(files).forEach(\n (file) => delete nonUpdatedFileContents[file],\n );\n }\n }\n } else {\n logger.debug(\n { manager },\n 'isLockFileUpdate without updateLockedDependency',\n );\n if (!updatedFileContents[packageFile]) {\n nonUpdatedFileContents[packageFile] = packageFileContent!;\n }\n }\n } else {\n const updateDependency = get(manager, 'updateDependency');\n if (!updateDependency) {\n let res = await doAutoReplace(\n upgrade,\n packageFileContent!,\n reuseExistingBranch,\n firstUpdate,\n );\n firstUpdate = false;\n if (res) {\n res = await applyManagerBumpPackageVersion(res, upgrade);\n if (res === packageFileContent) {\n logger.debug({ packageFile, depName }, 'No content changed');\n } else {\n logger.debug({ packageFile, depName }, 'Contents updated');\n updatedFileContents[packageFile] = res!;\n delete nonUpdatedFileContents[packageFile];\n }\n continue;\n } else if (reuseExistingBranch) {\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n logger.error({ packageFile, depName }, 'Could not autoReplace');\n throw new Error(WORKER_FILE_UPDATE_FAILED);\n }\n let newContent = await updateDependency({\n packageFile,\n fileContent: packageFileContent!,\n upgrade,\n });\n newContent = await applyManagerBumpPackageVersion(newContent, upgrade);\n if (!newContent) {\n if (reuseExistingBranch) {\n logger.debug(\n { packageFile, depName },\n 'Rebasing branch after error updating content',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n logger.debug(\n { existingContent: packageFileContent, config: upgrade },\n 'Error updating file',\n );\n throw new Error(WORKER_FILE_UPDATE_FAILED);\n }\n if (newContent !== packageFileContent) {\n if (reuseExistingBranch) {\n // This ensure it's always 1 commit from the bot\n logger.debug(\n { packageFile, depName },\n 'Need to update package file so will rebase first',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n logger.debug(\n `Updating ${depName} in ${coerceString(packageFile, lockFile)}`,\n );\n updatedFileContents[packageFile] = newContent;\n delete nonUpdatedFileContents[packageFile];\n }\n if (newContent === packageFileContent) {\n if (upgrade.manager === 'git-submodules') {\n updatedFileContents[packageFile] = newContent;\n delete nonUpdatedFileContents[packageFile];\n }\n }\n }\n }\n const updatedPackageFiles: FileAddition[] = Object.keys(\n updatedFileContents,\n ).map((name) => ({\n type: 'addition',\n path: name,\n contents: updatedFileContents[name],\n }));\n const updatedArtifacts: FileChange[] = [];\n const artifactErrors: ArtifactError[] = [];\n const artifactNotices: ArtifactNotice[] = [];\n if (isNonEmptyArray(updatedPackageFiles)) {\n logger.debug('updateArtifacts for updatedPackageFiles');\n const updatedPackageFileManagers = getManagersForPackageFiles(\n updatedPackageFiles,\n managerPackageFiles,\n );\n for (const manager of updatedPackageFileManagers) {\n const packageFilesForManager = getPackageFilesForManager(\n updatedPackageFiles,\n managerPackageFiles[manager],\n );\n sortPackageFiles(config, manager, packageFilesForManager);\n for (const packageFile of packageFilesForManager) {\n const updatedDeps = packageFileUpdatedDeps[packageFile.path];\n const results = await managerUpdateArtifacts(manager, {\n packageFileName: packageFile.path,\n updatedDeps,\n // TODO #22198\n newPackageFileContent: packageFile.contents!.toString(),\n config: patchConfigForArtifactsUpdate(\n config,\n manager,\n packageFile.path,\n ),\n });\n processUpdateArtifactResults(\n results,\n updatedArtifacts,\n artifactErrors,\n artifactNotices,\n );\n if (isNonEmptyArray(results)) {\n await checkForPendingVersions(\n manager,\n packageFile.path,\n packageFile.contents!.toString(),\n updatedDeps,\n artifactErrors,\n config,\n );\n }\n }\n }\n }\n const nonUpdatedPackageFiles: FileAddition[] = Object.keys(\n nonUpdatedFileContents,\n ).map((name) => ({\n type: 'addition',\n path: name,\n contents: nonUpdatedFileContents[name],\n }));\n if (isNonEmptyArray(nonUpdatedPackageFiles)) {\n logger.debug('updateArtifacts for nonUpdatedPackageFiles');\n const nonUpdatedPackageFileManagers = getManagersForPackageFiles(\n nonUpdatedPackageFiles,\n managerPackageFiles,\n );\n for (const manager of nonUpdatedPackageFileManagers) {\n const packageFilesForManager = getPackageFilesForManager(\n nonUpdatedPackageFiles,\n managerPackageFiles[manager],\n );\n sortPackageFiles(config, manager, packageFilesForManager);\n for (const packageFile of packageFilesForManager) {\n const updatedDeps = packageFileUpdatedDeps[packageFile.path];\n const results = await managerUpdateArtifacts(manager, {\n packageFileName: packageFile.path,\n updatedDeps,\n // TODO #22198\n newPackageFileContent: packageFile.contents!.toString(),\n config: patchConfigForArtifactsUpdate(\n config,\n manager,\n packageFile.path,\n ),\n });\n processUpdateArtifactResults(\n results,\n updatedArtifacts,\n artifactErrors,\n artifactNotices,\n );\n if (isNonEmptyArray(results)) {\n updatedPackageFiles.push(packageFile);\n await checkForPendingVersions(\n manager,\n packageFile.path,\n packageFile.contents!.toString(),\n updatedDeps,\n artifactErrors,\n config,\n );\n }\n }\n }\n }\n if (!reuseExistingBranch) {\n const lockFileMaintenancePackageFiles: FilePath[] =\n lockFileMaintenanceFiles.map((name) => ({\n path: name,\n }));\n // Only perform lock file maintenance if it's a fresh commit\n if (isNonEmptyArray(lockFileMaintenanceFiles)) {\n logger.debug('updateArtifacts for lockFileMaintenanceFiles');\n const lockFileMaintenanceManagers = getManagersForPackageFiles(\n lockFileMaintenancePackageFiles,\n managerPackageFiles,\n );\n for (const manager of lockFileMaintenanceManagers) {\n const packageFilesForManager = getPackageFilesForManager(\n lockFileMaintenancePackageFiles,\n managerPackageFiles[manager],\n );\n sortPackageFiles(config, manager, packageFilesForManager);\n for (const packageFile of packageFilesForManager) {\n const contents =\n updatedFileContents[packageFile.path] ||\n (await getFile(packageFile.path, config.baseBranch));\n const results = await managerUpdateArtifacts(manager, {\n packageFileName: packageFile.path,\n updatedDeps: [],\n newPackageFileContent: contents!,\n config: patchConfigForArtifactsUpdate(\n config,\n manager,\n packageFile.path,\n ),\n });\n processUpdateArtifactResults(\n results,\n updatedArtifacts,\n artifactErrors,\n artifactNotices,\n );\n }\n }\n }\n }\n return {\n reuseExistingBranch, // Need to overwrite original config\n updatedPackageFiles,\n updatedArtifacts,\n artifactErrors,\n artifactNotices,\n };\n}\n\n// workaround, see #27319\nfunction patchConfigForArtifactsUpdate(\n config: BranchConfig,\n manager: string,\n packageFileName: string,\n): UpdateArtifactsConfig {\n // drop any lockFiles that happen to be defined on the branch config\n const updatedConfig = { ...config };\n delete updatedConfig.lockFiles;\n if (isNonEmptyArray(updatedConfig.packageFiles?.[manager])) {\n const managerPackageFiles: PackageFile[] =\n updatedConfig.packageFiles?.[manager];\n const packageFile = managerPackageFiles.find(\n (p) => p.packageFile === packageFileName,\n );\n if (packageFile && isNonEmptyArray(packageFile.lockFiles)) {\n updatedConfig.lockFiles = packageFile.lockFiles;\n }\n }\n return updatedConfig;\n}\n\nasync function managerUpdateArtifacts(\n manager: string,\n updateArtifact: UpdateArtifact,\n): Promise<UpdateArtifactsResult[] | null> {\n const updateArtifacts = get(manager, 'updateArtifacts');\n if (!updateArtifacts) {\n return null;\n }\n\n if (updateArtifact.config.skipArtifactsUpdate) {\n logger.debug(\n { manager, packageFileName: updateArtifact.packageFileName },\n 'Skipping artifact update',\n );\n return null;\n }\n\n return await updateArtifacts(updateArtifact);\n}\n\nfunction processUpdateArtifactResults(\n results: UpdateArtifactsResult[] | null,\n updatedArtifacts: FileChange[],\n artifactErrors: ArtifactError[],\n artifactNotices: ArtifactNotice[],\n): void {\n if (isNonEmptyArray(results)) {\n for (const res of results) {\n const { file, notice, artifactError } = res;\n if (file) {\n updatedArtifacts.push(file);\n }\n\n if (artifactError) {\n artifactErrors.push(artifactError);\n }\n\n if (notice) {\n artifactNotices.push(notice);\n }\n }\n }\n}\n\n/**\n * When using Minimum Release Age, and a package manager that doesn't support being told an explicit version to update to (#41624) it is possible that an artifact update leads to a different version of a dependency being used compared to what Renovate is expecting.\n *\n * We should report these cases more explicitly with an Artifact Error, to allow the reviewers to decide what to do with the changes.\n */\nasync function checkForPendingVersions(\n manager: string,\n packageFileName: string,\n packageFileContent: string,\n updatedDeps: BranchUpgradeConfig[],\n artifactErrors: ArtifactError[],\n config: BranchConfig,\n): Promise<void> {\n const depNameToUpgradeInfo = new Map<\n string,\n {\n pendingVersions: Set<string>;\n newVersion: string | undefined;\n }\n >();\n for (const dep of updatedDeps) {\n if (dep.depName && isNonEmptyArray(dep.pendingVersions)) {\n depNameToUpgradeInfo.set(dep.depName, {\n pendingVersions: new Set(dep.pendingVersions),\n newVersion: dep.newVersion,\n });\n }\n }\n if (!depNameToUpgradeInfo.size) {\n return;\n }\n\n const extracted = await extractPackageFile(\n manager,\n packageFileContent,\n packageFileName,\n config,\n );\n if (!extracted) {\n logger.warn(\n { packageFile: packageFileName, manager },\n 'Could not re-extract the packageFile after updating it',\n );\n return;\n }\n\n for (const dep of extracted.deps) {\n const depName = dep.depName ?? dep.packageName;\n // shouldn't ever happen\n if (!depName) {\n logger.error(\n {\n packageFile: packageFileName,\n manager,\n branchName: config.branchName,\n depName: dep.depName,\n },\n `No depName found after updating '${packageFileName}'`,\n );\n throw new Error(WORKER_FILE_UPDATE_FAILED);\n }\n\n const upgradeInfo = depNameToUpgradeInfo.get(depName);\n if (!upgradeInfo) {\n continue;\n }\n const resolvedVersion =\n dep.lockedVersion ??\n dep.newVersion ??\n dep.currentVersion ??\n dep.currentValue;\n if (!resolvedVersion) {\n logger.error(\n {\n packageFile: packageFileName,\n manager,\n branchName: config.branchName,\n depName,\n newVersion: resolvedVersion,\n },\n `No new version found for '${depName}' after updating '${packageFileName}'`,\n );\n throw new Error(WORKER_FILE_UPDATE_FAILED);\n }\n\n if (resolvedVersion && upgradeInfo.pendingVersions.has(resolvedVersion)) {\n const expectedVersion = upgradeInfo.newVersion;\n /* v8 ignore next if -- should not happen */\n if (!expectedVersion) {\n logger.error(\n {\n packageFile: packageFileName,\n manager,\n branchName: config.branchName,\n depName,\n newVersion: resolvedVersion,\n expectedVersion,\n },\n `No expectedVersion found for '${depName}' after updating '${packageFileName}'`,\n );\n continue;\n }\n\n if (config.minimumReleaseAgeBehaviour === 'timestamp-optional') {\n logger.once.warn(\n {\n packageFileName,\n depName,\n expectedVersion,\n resolvedVersion,\n },\n \"Artifact error would be reported due to a pending version in use which hasn't passed Minimum Release Age, but as we're running with minimumReleaseAgeBehaviour=timestamp-optional, proceeding. See debug logs for more information\",\n );\n continue;\n }\n\n logger.debug(\n {\n packageFileName,\n depName,\n expectedVersion,\n resolvedVersion,\n },\n 'Artifact update introduced a pending version',\n );\n let stderr = `Artifact update for ${depName} resolved to version ${resolvedVersion}, which is a pending version that has not yet passed the Minimum Release Age threshold.`;\n stderr += `\\nRenovate was attempting to update to ${expectedVersion}`;\n stderr += `\\nThis is (likely) not a bug in Renovate, but due to the way your project pins dependencies, _and_ how Renovate calls your package manager to update them.\\nUntil Renovate supports specifying an exact update to your package manager (https://github.com/renovatebot/renovate/issues/41624), it is recommended to directly pin your dependencies (with \\`rangeStrategy=pin\\` for apps, or \\`rangeStrategy=widen\\` for libraries)\\nSee also: https://docs.renovatebot.com/dependency-pinning/`;\n\n artifactErrors.push({\n fileName: packageFileName,\n stderr,\n });\n }\n }\n}\n\nasync function applyManagerBumpPackageVersion(\n packageFileContent: string | null,\n upgrade: BranchUpgradeConfig,\n): Promise<string | null> {\n const bumpPackageVersion = get(upgrade.manager, 'bumpPackageVersion');\n if (\n !bumpPackageVersion ||\n !packageFileContent ||\n !upgrade.bumpVersion ||\n !upgrade.packageFileVersion\n ) {\n return packageFileContent;\n }\n\n const result = await bumpPackageVersion(\n packageFileContent,\n upgrade.packageFileVersion,\n upgrade.bumpVersion,\n upgrade.packageFile!,\n );\n\n return result.bumpedContent;\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"get-updated.js","names":[],"sources":["../../../../../lib/workers/repository/update/branch/get-updated.ts"],"sourcesContent":["import { isNonEmptyArray } from '@sindresorhus/is';\nimport { WORKER_FILE_UPDATE_FAILED } from '../../../../constants/error-messages.ts';\nimport { logger } from '../../../../logger/index.ts';\nimport { extractPackageFile, get } from '../../../../modules/manager/index.ts';\nimport type {\n ArtifactError,\n ArtifactNotice,\n PackageFile,\n UpdateArtifact,\n UpdateArtifactsConfig,\n UpdateArtifactsResult,\n} from '../../../../modules/manager/types.ts';\nimport { getFile } from '../../../../util/git/index.ts';\nimport type { FileAddition, FileChange } from '../../../../util/git/types.ts';\nimport { coerceString } from '../../../../util/string.ts';\nimport type { BranchConfig, BranchUpgradeConfig } from '../../../types.ts';\nimport { doAutoReplace } from './auto-replace.ts';\n\nexport interface PackageFilesResult {\n artifactErrors: ArtifactError[];\n reuseExistingBranch?: boolean;\n updatedPackageFiles: FileChange[];\n updatedArtifacts: FileChange[];\n artifactNotices: ArtifactNotice[];\n}\n\nasync function getFileContent(\n updatedFileContents: Record<string, string>,\n filePath: string,\n config: BranchConfig,\n): Promise<string | null> {\n let fileContent: string | null = updatedFileContents[filePath];\n if (!fileContent) {\n fileContent = await getFile(\n filePath,\n config.reuseExistingBranch ? config.branchName : config.baseBranch,\n );\n }\n return fileContent;\n}\n\nfunction sortPackageFiles(\n config: BranchConfig,\n manager: string,\n packageFiles: FilePath[],\n): void {\n const managerPackageFiles = config.packageFiles?.[manager];\n if (!managerPackageFiles) {\n return;\n }\n packageFiles.sort((lhs, rhs) => {\n const lhsIndex = managerPackageFiles.findIndex(\n (entry) => entry.packageFile === lhs.path,\n );\n const rhsIndex = managerPackageFiles.findIndex(\n (entry) => entry.packageFile === rhs.path,\n );\n return lhsIndex - rhsIndex;\n });\n}\n\nfunction hasAny(set: Set<string>, targets: Iterable<string>): boolean {\n for (const target of targets) {\n if (set.has(target)) {\n return true;\n }\n }\n return false;\n}\n\ntype FilePath = Pick<FileChange, 'path'>;\n\nfunction getManagersForPackageFiles<T extends FilePath>(\n packageFiles: T[],\n managerPackageFiles: Record<string, Set<string>>,\n): Set<string> {\n const packageFileNames = packageFiles.map((packageFile) => packageFile.path);\n return new Set(\n Object.keys(managerPackageFiles).filter((manager) =>\n hasAny(managerPackageFiles[manager], packageFileNames),\n ),\n );\n}\n\nfunction getPackageFilesForManager<T extends FilePath>(\n packageFiles: T[],\n managerPackageFiles: Set<string>,\n): T[] {\n return packageFiles.filter((packageFile) =>\n managerPackageFiles.has(packageFile.path),\n );\n}\n\nexport async function getUpdatedPackageFiles(\n config: BranchConfig,\n): Promise<PackageFilesResult> {\n logger.trace({ config });\n const reuseExistingBranch = config.reuseExistingBranch!;\n logger.debug(\n `manager.getUpdatedPackageFiles() reuseExistingBranch=${reuseExistingBranch}`,\n );\n let updatedFileContents: Record<string, string> = {};\n const nonUpdatedFileContents: Record<string, string> = {};\n const managerPackageFiles: Record<string, Set<string>> = {};\n const packageFileUpdatedDeps: Record<string, BranchUpgradeConfig[]> = {};\n const lockFileMaintenanceFiles: string[] = [];\n let firstUpdate = true;\n for (const upgrade of config.upgrades) {\n const manager = upgrade.manager;\n const packageFile = upgrade.packageFile!;\n const depName = upgrade.depName!;\n // TODO: fix types, can be undefined (#22198)\n const newVersion = upgrade.newVersion!;\n const currentVersion = upgrade.currentVersion!;\n const updateLockedDependency = get(manager, 'updateLockedDependency')!;\n managerPackageFiles[manager] ??= new Set<string>();\n managerPackageFiles[manager].add(packageFile);\n packageFileUpdatedDeps[packageFile] ??= [];\n packageFileUpdatedDeps[packageFile].push({ ...upgrade });\n const packageFileContent = await getFileContent(\n updatedFileContents,\n packageFile,\n config,\n );\n let lockFileContent: string | null = null;\n const lockFile = upgrade.lockFile ?? upgrade.lockFiles?.[0] ?? '';\n if (lockFile) {\n lockFileContent = await getFileContent(\n updatedFileContents,\n lockFile,\n config,\n );\n }\n // istanbul ignore if\n if (\n reuseExistingBranch &&\n (!packageFileContent || (lockFile && !lockFileContent))\n ) {\n logger.debug(\n { packageFile, depName },\n 'Rebasing branch after file not found',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n if (upgrade.updateType === 'lockFileMaintenance') {\n lockFileMaintenanceFiles.push(packageFile);\n } else if (upgrade.isRemediation) {\n const { status, files } = await updateLockedDependency({\n ...upgrade,\n depName,\n newVersion,\n currentVersion,\n packageFile,\n packageFileContent: packageFileContent!,\n lockFile,\n lockFileContent: lockFileContent!,\n allowParentUpdates: true,\n allowHigherOrRemoved: true,\n });\n if (reuseExistingBranch && status !== 'already-updated') {\n logger.debug(\n { lockFile, depName, status },\n 'Need to retry branch as it is not already up-to-date',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n if (files) {\n updatedFileContents = { ...updatedFileContents, ...files };\n Object.keys(files).forEach(\n (file) => delete nonUpdatedFileContents[file],\n );\n }\n if (status === 'update-failed' || status === 'unsupported') {\n upgrade.remediationNotPossible = true;\n }\n } else if (upgrade.isLockfileUpdate) {\n if (updateLockedDependency) {\n const { status, files } = await updateLockedDependency({\n ...upgrade,\n depName,\n newVersion,\n currentVersion,\n packageFile,\n packageFileContent: packageFileContent!,\n lockFile,\n lockFileContent: lockFileContent!,\n allowParentUpdates: false,\n });\n if (status === 'unsupported') {\n // incompatible lock file\n if (!updatedFileContents[packageFile]) {\n nonUpdatedFileContents[packageFile] = packageFileContent!;\n }\n } else if (status === 'already-updated') {\n logger.debug(\n `Upgrade of ${depName} to ${newVersion} is already done in existing branch`,\n );\n } else {\n // something changed\n if (reuseExistingBranch) {\n logger.debug(\n { lockFile, depName, status },\n 'Need to retry branch as upgrade requirements are not mets',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n if (files) {\n updatedFileContents = { ...updatedFileContents, ...files };\n Object.keys(files).forEach(\n (file) => delete nonUpdatedFileContents[file],\n );\n }\n }\n } else {\n logger.debug(\n { manager },\n 'isLockFileUpdate without updateLockedDependency',\n );\n if (!updatedFileContents[packageFile]) {\n nonUpdatedFileContents[packageFile] = packageFileContent!;\n }\n }\n } else {\n const updateDependency = get(manager, 'updateDependency');\n if (!updateDependency) {\n let res = await doAutoReplace(\n upgrade,\n packageFileContent!,\n reuseExistingBranch,\n firstUpdate,\n );\n firstUpdate = false;\n if (res) {\n res = await applyManagerBumpPackageVersion(res, upgrade);\n if (res === packageFileContent) {\n logger.debug({ packageFile, depName }, 'No content changed');\n } else {\n logger.debug({ packageFile, depName }, 'Contents updated');\n updatedFileContents[packageFile] = res!;\n delete nonUpdatedFileContents[packageFile];\n }\n continue;\n } else if (reuseExistingBranch) {\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n logger.error({ packageFile, depName }, 'Could not autoReplace');\n throw new Error(WORKER_FILE_UPDATE_FAILED);\n }\n let newContent = await updateDependency({\n packageFile,\n fileContent: packageFileContent!,\n upgrade,\n });\n newContent = await applyManagerBumpPackageVersion(newContent, upgrade);\n if (!newContent) {\n if (reuseExistingBranch) {\n logger.debug(\n { packageFile, depName },\n 'Rebasing branch after error updating content',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n logger.debug(\n { existingContent: packageFileContent, config: upgrade },\n 'Error updating file',\n );\n throw new Error(WORKER_FILE_UPDATE_FAILED);\n }\n if (newContent !== packageFileContent) {\n if (reuseExistingBranch) {\n // This ensure it's always 1 commit from the bot\n logger.debug(\n { packageFile, depName },\n 'Need to update package file so will rebase first',\n );\n return getUpdatedPackageFiles({\n ...config,\n reuseExistingBranch: false,\n });\n }\n logger.debug(\n `Updating ${depName} in ${coerceString(packageFile, lockFile)}`,\n );\n updatedFileContents[packageFile] = newContent;\n delete nonUpdatedFileContents[packageFile];\n }\n if (newContent === packageFileContent) {\n if (upgrade.manager === 'git-submodules') {\n updatedFileContents[packageFile] = newContent;\n delete nonUpdatedFileContents[packageFile];\n }\n }\n }\n }\n const updatedPackageFiles: FileAddition[] = Object.keys(\n updatedFileContents,\n ).map((name) => ({\n type: 'addition',\n path: name,\n contents: updatedFileContents[name],\n }));\n const updatedArtifacts: FileChange[] = [];\n const artifactErrors: ArtifactError[] = [];\n const artifactNotices: ArtifactNotice[] = [];\n if (isNonEmptyArray(updatedPackageFiles)) {\n logger.debug('updateArtifacts for updatedPackageFiles');\n const updatedPackageFileManagers = getManagersForPackageFiles(\n updatedPackageFiles,\n managerPackageFiles,\n );\n for (const manager of updatedPackageFileManagers) {\n const packageFilesForManager = getPackageFilesForManager(\n updatedPackageFiles,\n managerPackageFiles[manager],\n );\n sortPackageFiles(config, manager, packageFilesForManager);\n for (const packageFile of packageFilesForManager) {\n const updatedDeps = packageFileUpdatedDeps[packageFile.path];\n const results = await managerUpdateArtifacts(manager, {\n packageFileName: packageFile.path,\n updatedDeps,\n // TODO #22198\n newPackageFileContent: packageFile.contents!.toString(),\n config: patchConfigForArtifactsUpdate(\n config,\n manager,\n packageFile.path,\n ),\n });\n processUpdateArtifactResults(\n results,\n updatedArtifacts,\n artifactErrors,\n artifactNotices,\n );\n if (isNonEmptyArray(results)) {\n await checkForPendingVersions(\n manager,\n packageFile.path,\n packageFile.contents!.toString(),\n updatedDeps,\n artifactErrors,\n config,\n );\n }\n }\n }\n }\n const nonUpdatedPackageFiles: FileAddition[] = Object.keys(\n nonUpdatedFileContents,\n ).map((name) => ({\n type: 'addition',\n path: name,\n contents: nonUpdatedFileContents[name],\n }));\n if (isNonEmptyArray(nonUpdatedPackageFiles)) {\n logger.debug('updateArtifacts for nonUpdatedPackageFiles');\n const nonUpdatedPackageFileManagers = getManagersForPackageFiles(\n nonUpdatedPackageFiles,\n managerPackageFiles,\n );\n for (const manager of nonUpdatedPackageFileManagers) {\n const packageFilesForManager = getPackageFilesForManager(\n nonUpdatedPackageFiles,\n managerPackageFiles[manager],\n );\n sortPackageFiles(config, manager, packageFilesForManager);\n for (const packageFile of packageFilesForManager) {\n const updatedDeps = packageFileUpdatedDeps[packageFile.path];\n const results = await managerUpdateArtifacts(manager, {\n packageFileName: packageFile.path,\n updatedDeps,\n // TODO #22198\n newPackageFileContent: packageFile.contents!.toString(),\n config: patchConfigForArtifactsUpdate(\n config,\n manager,\n packageFile.path,\n ),\n });\n processUpdateArtifactResults(\n results,\n updatedArtifacts,\n artifactErrors,\n artifactNotices,\n );\n if (isNonEmptyArray(results)) {\n updatedPackageFiles.push(packageFile);\n await checkForPendingVersions(\n manager,\n packageFile.path,\n packageFile.contents!.toString(),\n updatedDeps,\n artifactErrors,\n config,\n );\n }\n }\n }\n }\n if (!reuseExistingBranch) {\n const lockFileMaintenancePackageFiles: FilePath[] =\n lockFileMaintenanceFiles.map((name) => ({\n path: name,\n }));\n // Only perform lock file maintenance if it's a fresh commit\n if (isNonEmptyArray(lockFileMaintenanceFiles)) {\n logger.debug('updateArtifacts for lockFileMaintenanceFiles');\n const lockFileMaintenanceManagers = getManagersForPackageFiles(\n lockFileMaintenancePackageFiles,\n managerPackageFiles,\n );\n for (const manager of lockFileMaintenanceManagers) {\n const packageFilesForManager = getPackageFilesForManager(\n lockFileMaintenancePackageFiles,\n managerPackageFiles[manager],\n );\n sortPackageFiles(config, manager, packageFilesForManager);\n for (const packageFile of packageFilesForManager) {\n const contents =\n updatedFileContents[packageFile.path] ||\n (await getFile(packageFile.path, config.baseBranch));\n const results = await managerUpdateArtifacts(manager, {\n packageFileName: packageFile.path,\n updatedDeps: [],\n newPackageFileContent: contents!,\n config: patchConfigForArtifactsUpdate(\n config,\n manager,\n packageFile.path,\n ),\n });\n processUpdateArtifactResults(\n results,\n updatedArtifacts,\n artifactErrors,\n artifactNotices,\n );\n }\n }\n }\n }\n return {\n reuseExistingBranch, // Need to overwrite original config\n updatedPackageFiles,\n updatedArtifacts,\n artifactErrors,\n artifactNotices,\n };\n}\n\n// workaround, see #27319\nfunction patchConfigForArtifactsUpdate(\n config: BranchConfig,\n manager: string,\n packageFileName: string,\n): UpdateArtifactsConfig {\n // drop any lockFiles that happen to be defined on the branch config\n const updatedConfig = { ...config };\n delete updatedConfig.lockFiles;\n if (isNonEmptyArray(updatedConfig.packageFiles?.[manager])) {\n const managerPackageFiles: PackageFile[] =\n updatedConfig.packageFiles?.[manager];\n const packageFile = managerPackageFiles.find(\n (p) => p.packageFile === packageFileName,\n );\n if (packageFile && isNonEmptyArray(packageFile.lockFiles)) {\n updatedConfig.lockFiles = packageFile.lockFiles;\n }\n }\n return updatedConfig;\n}\n\nasync function managerUpdateArtifacts(\n manager: string,\n updateArtifact: UpdateArtifact,\n): Promise<UpdateArtifactsResult[] | null> {\n const updateArtifacts = get(manager, 'updateArtifacts');\n if (!updateArtifacts) {\n return null;\n }\n\n if (updateArtifact.config.skipArtifactsUpdate) {\n logger.debug(\n { manager, packageFileName: updateArtifact.packageFileName },\n 'Skipping artifact update',\n );\n return null;\n }\n\n return await updateArtifacts(updateArtifact);\n}\n\nfunction processUpdateArtifactResults(\n results: UpdateArtifactsResult[] | null,\n updatedArtifacts: FileChange[],\n artifactErrors: ArtifactError[],\n artifactNotices: ArtifactNotice[],\n): void {\n if (isNonEmptyArray(results)) {\n for (const res of results) {\n const { file, notice, artifactError } = res;\n if (file) {\n updatedArtifacts.push(file);\n }\n\n if (artifactError) {\n artifactErrors.push(artifactError);\n }\n\n if (notice) {\n artifactNotices.push(notice);\n }\n }\n }\n}\n\n/**\n * When using Minimum Release Age, and a package manager that doesn't support being told an explicit version to update to (#41624) it is possible that an artifact update leads to a different version of a dependency being used compared to what Renovate is expecting.\n *\n * We should report these cases more explicitly with an Artifact Error, to allow the reviewers to decide what to do with the changes.\n */\nasync function checkForPendingVersions(\n manager: string,\n packageFileName: string,\n packageFileContent: string,\n updatedDeps: BranchUpgradeConfig[],\n artifactErrors: ArtifactError[],\n config: BranchConfig,\n): Promise<void> {\n const depNameToUpgradeInfo = new Map<\n string,\n {\n pendingVersions: Set<string>;\n newVersion: string | undefined;\n }\n >();\n for (const dep of updatedDeps) {\n if (dep.depName && isNonEmptyArray(dep.pendingVersions)) {\n depNameToUpgradeInfo.set(dep.depName, {\n pendingVersions: new Set(dep.pendingVersions),\n newVersion: dep.newVersion,\n });\n }\n }\n if (!depNameToUpgradeInfo.size) {\n return;\n }\n\n const extracted = await extractPackageFile(\n manager,\n packageFileContent,\n packageFileName,\n config,\n );\n if (!extracted) {\n logger.warn(\n { packageFile: packageFileName, manager },\n 'Could not re-extract the packageFile after updating it',\n );\n return;\n }\n\n for (const dep of extracted.deps) {\n const depName = dep.depName ?? dep.packageName;\n // shouldn't ever happen\n if (!depName) {\n logger.error(\n {\n packageFile: packageFileName,\n manager,\n branchName: config.branchName,\n depName: dep.depName,\n },\n `No depName found after updating '${packageFileName}'`,\n );\n throw new Error(WORKER_FILE_UPDATE_FAILED);\n }\n\n const upgradeInfo = depNameToUpgradeInfo.get(depName);\n if (!upgradeInfo) {\n continue;\n }\n const resolvedVersion =\n dep.lockedVersion ??\n dep.newVersion ??\n dep.currentVersion ??\n dep.currentValue;\n if (!resolvedVersion) {\n logger.warn(\n {\n packageFile: packageFileName,\n manager,\n branchName: config.branchName,\n depName,\n },\n `Could not determine resolved version for '${depName}' after updating '${packageFileName}'; skipping pending-version check`,\n );\n continue;\n }\n\n if (resolvedVersion && upgradeInfo.pendingVersions.has(resolvedVersion)) {\n const expectedVersion = upgradeInfo.newVersion;\n /* v8 ignore next if -- should not happen */\n if (!expectedVersion) {\n logger.error(\n {\n packageFile: packageFileName,\n manager,\n branchName: config.branchName,\n depName,\n newVersion: resolvedVersion,\n expectedVersion,\n },\n `No expectedVersion found for '${depName}' after updating '${packageFileName}'`,\n );\n continue;\n }\n\n if (config.minimumReleaseAgeBehaviour === 'timestamp-optional') {\n logger.once.warn(\n {\n packageFileName,\n depName,\n expectedVersion,\n resolvedVersion,\n },\n \"Artifact error would be reported due to a pending version in use which hasn't passed Minimum Release Age, but as we're running with minimumReleaseAgeBehaviour=timestamp-optional, proceeding. See debug logs for more information\",\n );\n continue;\n }\n\n logger.debug(\n {\n packageFileName,\n depName,\n expectedVersion,\n resolvedVersion,\n },\n 'Artifact update introduced a pending version',\n );\n let stderr = `Artifact update for ${depName} resolved to version ${resolvedVersion}, which is a pending version that has not yet passed the Minimum Release Age threshold.`;\n stderr += `\\nRenovate was attempting to update to ${expectedVersion}`;\n stderr += `\\nThis is (likely) not a bug in Renovate, but due to the way your project pins dependencies, _and_ how Renovate calls your package manager to update them.\\nUntil Renovate supports specifying an exact update to your package manager (https://github.com/renovatebot/renovate/issues/41624), it is recommended to directly pin your dependencies (with \\`rangeStrategy=pin\\` for apps, or \\`rangeStrategy=widen\\` for libraries)\\nSee also: https://docs.renovatebot.com/dependency-pinning/`;\n\n artifactErrors.push({\n fileName: packageFileName,\n stderr,\n });\n }\n }\n}\n\nasync function applyManagerBumpPackageVersion(\n packageFileContent: string | null,\n upgrade: BranchUpgradeConfig,\n): Promise<string | null> {\n const bumpPackageVersion = get(upgrade.manager, 'bumpPackageVersion');\n if (\n !bumpPackageVersion ||\n !packageFileContent ||\n !upgrade.bumpVersion ||\n !upgrade.packageFileVersion\n ) {\n return packageFileContent;\n }\n\n const result = await bumpPackageVersion(\n packageFileContent,\n upgrade.packageFileVersion,\n upgrade.bumpVersion,\n upgrade.packageFile!,\n );\n\n return result.bumpedContent;\n}\n"],"mappings":"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"}
|