Skip to content
Snippets Groups Projects
Select Git revision
  • 012561f69afe0baebc689b045df7a1c65b31a567
  • 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

limits.ts

Blame
  • user avatar
    Rhys Arkins authored and GitHub committed
    Co-authored-by: default avatarMichael Kriese <michael.kriese@visualon.de>
    012561f6
    History
    limits.ts 2.22 KiB
    import moment from 'moment';
    import { RenovateConfig } from '../../../config';
    import { logger } from '../../../logger';
    import { platform } from '../../../platform';
    import { branchExists } from '../../../util/git';
    import { BranchConfig } from '../../common';
    
    export async function getPrHourlyRemaining(
      config: RenovateConfig
    ): Promise<number> {
      if (config.prHourlyLimit) {
        logger.debug('Calculating hourly PRs remaining');
        const prList = await platform.getPrList();
        const currentHourStart = moment({
          hour: moment().hour(),
        });
        logger.debug('currentHourStart=' + currentHourStart);
        try {
          const soFarThisHour = prList.filter(
            (pr) =>
              pr.branchName !== config.onboardingBranch &&
              moment(pr.createdAt).isAfter(currentHourStart)
          );
          const prsRemaining = config.prHourlyLimit - soFarThisHour.length;
          logger.debug(`PR hourly limit remaining: ${prsRemaining}`);
          // istanbul ignore if
          if (prsRemaining <= 0) {
            logger.debug(
              {
                prs: prsRemaining,
              },
              'Creation of new PRs is blocked by existing PRs'
            );
          }
          return prsRemaining;
        } catch (err) {
          logger.error('Error checking PRs created per hour');
        }
      }
      return 99;
    }
    
    export function getConcurrentPrsRemaining(
      config: RenovateConfig,
      branches: BranchConfig[]
    ): number {
      if (config.prConcurrentLimit) {
        logger.debug(`Enforcing prConcurrentLimit (${config.prConcurrentLimit})`);
        let currentlyOpen = 0;
        for (const branch of branches) {
          if (branchExists(branch.branchName)) {
            currentlyOpen += 1;
          }
        }
        logger.debug(`${currentlyOpen} PRs are currently open`);
        const concurrentRemaining = config.prConcurrentLimit - currentlyOpen;
        logger.debug(`PR concurrent limit remaining: ${concurrentRemaining}`);
        return concurrentRemaining;
      }
      return 99;
    }
    
    export async function getPrsRemaining(
      config: RenovateConfig,
      branches: BranchConfig[]
    ): Promise<number> {
      const hourlyRemaining = await getPrHourlyRemaining(config);
      const concurrentRemaining = getConcurrentPrsRemaining(config, branches);
      return hourlyRemaining < concurrentRemaining
        ? hourlyRemaining
        : concurrentRemaining;
    }