Skip to content
Snippets Groups Projects
Select Git revision
  • 4da0c7b8dd1c4415ffb1eb0a14217270cffeb30d
  • master default protected
  • gh-pages
  • dependabot/npm_and_yarn/neostandard-0.12.2
  • dependabot/npm_and_yarn/eslint-plugin-import-2.32.0
  • dependabot/npm_and_yarn/typescript-eslint/parser-8.36.0
  • dependabot/npm_and_yarn/nock-14.0.5
  • dependabot/npm_and_yarn/react-19.1.0
  • dependabot/npm_and_yarn/react-dom-19.1.0
  • server-2025-02-01-6100669a
  • server-2024-11-01-87cba042
  • server-2024-10-01-6875b7c8
  • dependabot/npm_and_yarn/path-to-regexp-8.2.0
  • server-2024-09-01-3d52575c
  • daily-tests-gha2
  • daily-tests-gha
  • server-2023-12-01-92d8fb8e
  • server-2023-11-01-a80c93fd
  • server-2023-10-01-31096085
  • coc-v2
  • server-2023-09-01-8edc3810
  • server-2025-07-01
  • 5.0.2
  • 5.0.1
  • 5.0.0
  • server-2025-06-01
  • server-2025-05-01
  • server-2025-04-03
  • server-2025-03-02
  • server-2025-03-01
  • server-2025-02-02
  • server-2025-01-01
  • server-2024-12-01
  • server-2024-11-02
  • 4.1.0
  • server-2024-09-25
  • server-2024-09-02
  • server-2024-08-01
  • server-2024-07-01
  • 4.0.0
  • server-2024-06-01
41 results

entrypoint.spec.js

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');
    }