Skip to content
Snippets Groups Projects
Select Git revision
  • a4490add1edf87c7854e1068f39716d1f9ebe356
  • main default protected
  • renovate/main-renovatebot-github-action-43.x
  • next
  • 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
  • fix/32307-global-extends-merging
  • fix/32307-global-extends-repositories
  • gh-readonly-queue/next/pr-35009-046ebf7cb84ab859f7fefceb5fa53a54ce9736f8
  • 41.45.0
  • 41.44.0
  • 41.43.7
  • 41.43.6
  • 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 results

npm.js

  • npm.js 1.24 KiB
    const fs = require('fs-extra');
    const cp = require('child_process');
    const path = require('path');
    
    module.exports = {
      generateLockFile,
    };
    
    async function generateLockFile(tmpDir, logger) {
      logger.debug(`Spawning npm install to create ${tmpDir}/package-lock.json`);
      let lockFile = null;
      let result = {};
      try {
        const startTime = process.hrtime();
        const npmBin = path.resolve('./node_modules/.bin/npm');
        const npmOptions = [npmBin, 'install', '--ignore-scripts'];
        result = cp.spawnSync('node', npmOptions, {
          cwd: tmpDir,
          shell: true,
          env: { NODE_ENV: 'dev' },
        });
        logger.debug(`npm stdout:\n${String(result.stdout)}`);
        logger.debug(`npm stderr:\n${String(result.stderr)}`);
        const duration = process.hrtime(startTime);
        const durationSeconds = Math.round(duration[0] + duration[1] / 1e9);
        lockFile = fs.readFileSync(path.join(tmpDir, 'package-lock.json'), 'utf8');
        logger.info(
          { durationSeconds, lockFile: 'package-lock.json' },
          'Generated lockfile'
        );
      } catch (err) /* istanbul ignore next */ {
        logger.warn(
          {
            err,
            stdout: String(result.stdout),
            stderr: String(result.stderr),
          },
          'npm install error'
        );
      }
      return lockFile;
    }