Skip to content
Snippets Groups Projects
Select Git revision
  • 1a477cde98f427d6fd436c932f46c3e4868634af
  • master default protected
  • gh-pages
  • dependabot/npm_and_yarn/nock-14.0.6
  • 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-2023-08-01-75858a03
  • server-2023-07-01-02183d8d
  • test-9317
  • 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

module-core_service-test-runner_infer-pull-request.html

Blame
  • npm.js 2.49 KiB
    const fs = require('fs-extra');
    const upath = require('upath');
    const { getInstalledPath } = require('get-installed-path');
    const { exec } = require('child-process-promise');
    
    module.exports = {
      generateLockFile,
    };
    
    async function generateLockFile(tmpDir) {
      logger.debug(`Spawning npm install to create ${tmpDir}/package-lock.json`);
      let lockFile = null;
      let stdout;
      let stderr;
      try {
        const startTime = process.hrtime();
        let cmd;
        try {
          // See if renovate is installed locally
          const installedPath = upath.join(
            await getInstalledPath('npm', {
              local: true,
            }),
            'bin/npm-cli.js'
          );
          cmd = `node ${installedPath}`;
        } catch (localerr) {
          logger.debug('No locally installed npm found');
          // Look inside globally installed renovate
          try {
            const renovateLocation = await getInstalledPath('renovate');
            const installedPath = upath.join(
              await getInstalledPath('npm', {
                local: true,
                cwd: renovateLocation,
              }),
              'bin/npm-cli.js'
            );
            cmd = `node ${installedPath}`;
          } catch (nestederr) {
            logger.debug('Could not find globally nested npm');
            // look for global npm
            try {
              const installedPath = upath.join(
                await getInstalledPath('npm'),
                'bin/npm-cli.js'
              );
              cmd = `node ${installedPath}`;
            } catch (globalerr) {
              logger.warn('Could not find globally installed npm');
              cmd = 'npm';
            }
          }
        }
        logger.debug(`Using npm: ${cmd}`);
        cmd = `ls -l && ${cmd} --version && ${cmd} install --package-lock-only`;
        // TODO: Switch to native util.promisify once using only node 8
        ({ stdout, stderr } = await exec(cmd, {
          cwd: tmpDir,
          shell: true,
          env: { NODE_ENV: 'dev', PATH: process.env.PATH },
        }));
        logger.debug(`npm stdout:\n${stdout}`);
        logger.debug(`npm stderr:\n${stderr}`);
        const duration = process.hrtime(startTime);
        const seconds = Math.round(duration[0] + duration[1] / 1e9);
        lockFile = await fs.readFile(
          upath.join(tmpDir, 'package-lock.json'),
          'utf8'
        );
        logger.info(
          { seconds, type: 'package-lock.json', stdout, stderr },
          'Generated lockfile'
        );
      } catch (err) /* istanbul ignore next */ {
        logger.warn(
          {
            err,
            stdout,
            stderr,
          },
          'npm install error'
        );
        return { error: true, stderr };
      }
      return { lockFile };
    }