Skip to content
Snippets Groups Projects
Select Git revision
  • cc52c205338d105267c1b4e682abdd150670c3dd
  • main default protected
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • next
  • revert-31645-feat/rename-gradle-wrapper-validation-action
  • renovate/main-redis-5.x
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • fix/36615-branch-reuse-bug
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • fix/32307-global-extends-merging
  • 41.30.4
  • 41.30.3
  • 41.30.2
  • 41.30.1
  • 41.30.0
  • 41.29.1
  • 41.29.0
  • 41.28.2
  • 41.28.1
  • 41.28.0
  • 41.27.1
  • 41.27.0
  • 41.26.2
  • 41.26.1
  • 41.26.0
  • 41.25.1
  • 41.25.0
  • 41.24.0
  • 41.23.5
  • 41.23.4
41 results

utils.ts

Blame
  • get-updated.ts 9.57 KiB
    import is from '@sindresorhus/is';
    import { WORKER_FILE_UPDATE_FAILED } from '../../constants/error-messages';
    import { logger } from '../../logger';
    import { get } from '../../manager';
    import type { ArtifactError, PackageDependency } from '../../manager/types';
    import { File, getFile } from '../../util/git';
    import type { BranchConfig } from '../types';
    import { doAutoReplace } from './auto-replace';
    
    export interface PackageFilesResult {
      artifactErrors: ArtifactError[];
      reuseExistingBranch?: boolean;
      updatedPackageFiles: File[];
      updatedArtifacts: File[];
    }
    
    export async function getUpdatedPackageFiles(
      config: BranchConfig
    ): Promise<PackageFilesResult> {
      logger.trace({ config });
      const { reuseExistingBranch } = config;
      logger.debug(
        `manager.getUpdatedPackageFiles() reuseExistinbranch=${reuseExistingBranch}`
      );
      let updatedFileContents: Record<string, string> = {};
      const nonUpdatedFileContents: Record<string, string> = {};
      const packageFileManagers: Record<string, string> = {};
      const packageFileUpdatedDeps: Record<string, PackageDependency[]> = {};
      const lockFileMaintenanceFiles = [];
      for (const upgrade of config.upgrades) {
        const { manager, packageFile, lockFile, depName } = upgrade;
        packageFileManagers[packageFile] = manager;
        packageFileUpdatedDeps[packageFile] =
          packageFileUpdatedDeps[packageFile] || [];
        packageFileUpdatedDeps[packageFile].push({ ...upgrade });
        let packageFileContent = updatedFileContents[packageFile];
        if (!packageFileContent) {
          packageFileContent = await getFile(
            packageFile,
            reuseExistingBranch ? config.branchName : config.baseBranch
          );
        }
        // istanbul ignore if
        if (reuseExistingBranch && !packageFileContent) {
          logger.debug(
            { packageFile, depName },
            'Rebasing branch after file not found'
          );
          return getUpdatedPackageFiles({
            ...config,
            reuseExistingBranch: false,
          });
        }
        if (upgrade.updateType === 'lockFileMaintenance') {
          lockFileMaintenanceFiles.push(packageFile);
        } else if (upgrade.isRemediation) {
          let lockFileContent = updatedFileContents[lockFile];
          if (!lockFileContent) {
            lockFileContent = await getFile(
              lockFile,
              reuseExistingBranch ? config.branchName : config.baseBranch
            );
          }
          // istanbul ignore if: to hard to test
          if (reuseExistingBranch && !lockFileContent) {
            logger.debug(
              { lockFile, depName },
              'Rebasing branch after lock file not found'
            );
            return getUpdatedPackageFiles({