Skip to content
Snippets Groups Projects
Select Git revision
  • 6c7fd8df29cb019480fdfcfa18f6987af38e177e
  • main default protected
  • next
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • 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.32.1
  • 41.32.0
  • 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 results

object.spec.ts

Blame
  • fetch.ts 4.13 KiB
    import { hrtime } from 'process';
    import pAll from 'p-all';
    import {
      ManagerConfig,
      RenovateConfig,
      getManagerConfig,
      mergeChildConfig,
    } from '../../../config';
    import { getDefaultConfig } from '../../../datasource';
    import { logger } from '../../../logger';
    import { getPackageUpdates } from '../../../manager';
    import { PackageDependency, PackageFile } from '../../../manager/common';
    import { SkipReason } from '../../../types';
    import { clone } from '../../../util/clone';
    import { applyPackageRules } from '../../../util/package-rules';
    import { LookupUpdateConfig, lookupUpdates } from './lookup';
    
    async function fetchDepUpdates(
      packageFileConfig: ManagerConfig & PackageFile,
      indep: PackageDependency
    ): Promise<PackageDependency> {
      const dep = clone(indep);
      dep.updates = [];
      if (dep.skipReason) {
        return dep;
      }
      const { manager, packageFile } = packageFileConfig;
      const { depName, currentValue } = dep;
      // TODO: fix types
      let depConfig = mergeChildConfig(packageFileConfig, dep);
      const datasourceDefaultConfig = await getDefaultConfig(depConfig.datasource);
      depConfig = mergeChildConfig(depConfig, datasourceDefaultConfig);
      depConfig = applyPackageRules(depConfig);
      if (depConfig.ignoreDeps.includes(depName)) {
        logger.debug({ dependency: dep.depName }, 'Dependency is ignored');
        dep.skipReason = SkipReason.Ignored;
      } else if (
        depConfig.internalPackages &&
        depConfig.internalPackages.includes(depName)
      ) {
        logger.debug(
          { dependency: dep.depName },
          'Dependency is ignored due to being internal'
        );
        dep.skipReason = SkipReason.InternalPackage;
      } else if (depConfig.enabled === false) {
        logger.debug({ dependency: dep.depName }, 'Dependency is disabled');
        dep.skipReason = SkipReason.Disabled;
      } else {
        if (depConfig.datasource) {
          Object.assign(dep, await lookupUpdates(depConfig as LookupUpdateConfig));
        } else {
          dep.updates = await getPackageUpdates(manager, depConfig);
        }
        dep.updates = dep.updates || [];
        // istanbul ignore if
        if (dep.updates.length) {
          logger.trace(
            { dependency: depName },
            `${dep.updates.length} result(s): ${dep.updates.map(
              (upgrade) => upgrade.newValue
            )}`
          );
        }
        logger.trace({
          packageFile,
          manager,
          depName,
          currentValue,
          updates: dep.updates,
        });
      }
      return dep;
    }
    
    async function fetchManagerPackagerFileUpdates(
      config: RenovateConfig,
      managerConfig: ManagerConfig,
      pFile: PackageFile
    ): Promise<void> {
      const { packageFile } = pFile;
      const packageFileConfig = mergeChildConfig(managerConfig, pFile);
      const { manager } = packageFileConfig;
      const queue = pFile.deps.map((dep) => (): Promise<PackageDependency> =>
        fetchDepUpdates(packageFileConfig, dep)
      );
      logger.trace(
        { manager, packageFile, queueLength: queue.length },
        'fetchManagerPackagerFileUpdates starting with concurrency'
      );
      // eslint-disable-next-line no-param-reassign
      pFile.deps = await pAll(queue, { concurrency: 5 });
      logger.trace({ packageFile }, 'fetchManagerPackagerFileUpdates finished');
    }
    
    async function fetchManagerUpdates(
      config: RenovateConfig,
      packageFiles: Record<string, PackageFile[]>,
      manager: string
    ): Promise<void> {
      const managerConfig = getManagerConfig(config, manager);
      const queue = packageFiles[manager].map((pFile) => (): Promise<void> =>
        fetchManagerPackagerFileUpdates(config, managerConfig, pFile)
      );
      logger.trace(
        { manager, queueLength: queue.length },
        'fetchManagerUpdates starting'
      );
      await pAll(queue, { concurrency: 5 });
      logger.trace({ manager }, 'fetchManagerUpdates finished');
    }
    
    export async function fetchUpdates(
      config: RenovateConfig,
      packageFiles: Record<string, PackageFile[]>
    ): Promise<void> {
      const managers = Object.keys(packageFiles);
      const startTime = hrtime();
      const allManagerJobs = managers.map((manager) =>
        fetchManagerUpdates(config, packageFiles, manager)
      );
      await Promise.all(allManagerJobs);
      const duration = hrtime(startTime);
      const seconds = Math.round(duration[0] + duration[1] / 1e9);
      logger.info({ seconds }, 'Package releases lookups complete');
    }