Skip to content
Snippets Groups Projects
Select Git revision
  • b23d25a7fd71252805d9ef2c84ad224741b29b83
  • main default protected
  • renovate/main-renovatebot-github-action-43.x
  • next
  • renovate/main-containerbase-internal-tools-3.x
  • renovate/main-lock-file-maintenance
  • renovate/main-docs-renovate-renovate-41.x
  • feat/gnupg
  • fix/36615b-branch-reuse-no-cache
  • renovate/main-redis-5.x
  • chore/punycode
  • 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
  • 41.43.5
  • 41.43.4
  • 41.43.3
  • 41.43.2
  • 41.43.1
  • 41.43.0
  • 41.42.12
  • 41.42.11
  • 41.42.10
  • 41.42.9
  • 41.42.8
  • 41.42.7
  • 41.42.6
  • 41.42.5
  • 41.42.4
  • 41.42.3
  • 41.42.2
  • 41.42.1
  • 41.42.0
  • 41.41.0
41 results

index.ts

Blame
  • index.ts 1.87 KiB
    import fs from 'fs-extra';
    
    import handleError from './error';
    import { platform } from '../../platform';
    import { logger, setMeta } from '../../logger';
    import { initRepo } from './init';
    import { ensureOnboardingPr } from './onboarding/pr';
    import { processResult, ProcessResult } from './result';
    import { processRepo } from './process';
    import { finaliseRepo } from './finalise';
    import { ensureMasterIssue } from './master-issue';
    import { RenovateConfig } from '../../config';
    
    let renovateVersion = 'unknown';
    try {
      renovateVersion = require('../../../package.json').version; // eslint-disable-line global-require
    } catch (err) /* istanbul ignore next */ {
      logger.debug({ err }, 'Error getting renovate version');
    }
    
    // istanbul ignore next
    export async function renovateRepository(
      repoConfig: RenovateConfig
    ): Promise<ProcessResult> {
      let config = { ...repoConfig };
      setMeta({ repository: config.repository });
      logger.info({ renovateVersion }, 'Repository started');
      logger.trace({ config });
      let repoResult: ProcessResult;
      try {
        await fs.ensureDir(config.localDir);
        logger.debug('Using localDir: ' + config.localDir);
        config = await initRepo(config);
        const { res, branches, branchList, packageFiles } = await processRepo(
          config
        );
        await ensureOnboardingPr(config, packageFiles, branches);
        if (res !== 'automerged') {
          await ensureMasterIssue(config, branches);
        }
        await finaliseRepo(config, branchList);
        repoResult = processResult(config, res);
      } catch (err) /* istanbul ignore next */ {
        setMeta({ repository: config.repository });
        const errorRes = await handleError(config, err);
        repoResult = processResult(config, errorRes);
      }
      await platform.cleanRepo();
      if (config.localDir && !config.persistRepoData) {
        await fs.remove(config.localDir);
      }
      logger.info('Repository finished');
      return repoResult;
    }