Skip to content
Snippets Groups Projects
Select Git revision
  • ad52ac9b13e7fdd87fbfcedfdfbfcf44a052ae0e
  • 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.31.1
  • 41.31.0
  • 41.30.5
  • 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 results

deprecated.ts

Blame
  • user avatar
    Sergio Zharinov authored and GitHub committed
    ad52ac9b
    History
    deprecated.ts 2.95 KiB
    import { RenovateConfig } from '../../../config';
    import { logger } from '../../../logger';
    import { PackageFile } from '../../../manager/common';
    import { platform } from '../../../platform';
    
    export async function raiseDeprecationWarnings(
      config: RenovateConfig,
      packageFiles: Record<string, PackageFile[]>
    ): Promise<void> {
      if (!config.repoIsOnboarded) {
        return;
      }
      if (config.suppressNotifications?.includes('deprecationWarningIssues')) {
        return;
      }
      for (const [manager, files] of Object.entries(packageFiles)) {
        const deprecatedPackages: Record<
          string,
          { deprecationMessage?: string; depPackageFiles: string[] }
        > = {};
        for (const packageFile of files) {
          for (const dep of packageFile.deps) {
            const { deprecationMessage } = dep;
            if (deprecationMessage) {
              deprecatedPackages[dep.depName] = deprecatedPackages[dep.depName] || {
                deprecationMessage,
                depPackageFiles: [],
              };
              deprecatedPackages[dep.depName].depPackageFiles.push(
                packageFile.packageFile
              );
            }
          }
        }
    
        logger.debug({ deprecatedPackages });
        const issueTitleList: string[] = [];
        const issueTitlePrefix = 'Dependency deprecation warning:';
        for (const [depName, val] of Object.entries(deprecatedPackages)) {
          const { deprecationMessage, depPackageFiles } = val;
          logger.debug(
            {
              depName,
              deprecationMessage,
              packageFiles: depPackageFiles,
            },
            'dependency is deprecated'
          );
          const issueTitle = `${issueTitlePrefix} ${depName} (${manager})`;
          issueTitleList.push(issueTitle);
          let issueBody = deprecationMessage;
          issueBody += `\n\nAffected package file(s): ${depPackageFiles
            .map((f) => '`' + f + '`')
            .join(', ')}`;
          issueBody += `\n\nIf you don't care about this, you can close this issue and not be warned about \`${depName}\`'s deprecation again. If you would like to completely disable all future deprecation warnings then add the following to your config:\n\n\`\`\`\n"suppressNotifications": ["deprecationWarningIssues"]\n\`\`\`\n\n`;
          // istanbul ignore if
          if (config.dryRun) {
            logger.info('DRY-RUN: Ensure deprecation warning issue for ' + depName);
          } else {
            const ensureOnce = true;
            await platform.ensureIssue({
              title: issueTitle,
              body: issueBody,
              once: ensureOnce,
            });
          }
        }
        logger.debug(
          'Checking for existing deprecated package issues missing in current deprecatedPackages'
        );
        const issueList = await platform.getIssueList();
        if (issueList?.length) {
          const deprecatedIssues = issueList.filter(
            (i) => i.title.startsWith(issueTitlePrefix) && i.state === 'open'
          );
          for (const i of deprecatedIssues) {
            if (!issueTitleList.includes(i.title)) {
              await platform.ensureIssueClosing(i.title);
            }
          }
        }
      }
    }