Skip to content
Snippets Groups Projects
Select Git revision
  • 363a2cc2e5ef6fbf85b71083a0273c1d54b79db5
  • main default protected
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • next
  • 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.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.25.1
  • 41.25.0
  • 41.24.0
  • 41.23.5
  • 41.23.4
41 results

lerna.js

Blame
  • user avatar
    Rhys Arkins authored
    Closes #1531
    b00af302
    History
    lerna.js 1.71 KiB
    const { exec } = require('child-process-promise');
    
    module.exports = {
      generateLockFiles,
    };
    
    async function generateLockFiles(manager, tmpDir, env) {
      logger.debug(`Spawning lerna to create lock files`);
      let stdout;
      let stderr;
      try {
        const startTime = process.hrtime();
        let lernaVersion;
        try {
          const pJson = JSON.parse(await platform.getFile('package.json'));
          lernaVersion =
            (pJson.dependencies && pJson.dependencies.lerna) ||
            (pJson.devDependencies && pJson.devDependencies.lerna);
        } catch (err) {
          logger.warn('Could not detect lerna version in package.json');
        }
        lernaVersion = lernaVersion || 'latest';
        logger.debug('Using lerna version ' + lernaVersion);
        const params =
          manager === 'npm'
            ? '--package-lock-only'
            : '--ignore-scripts --ignore-engines --ignore-platform --mutex network:31879';
        const cmd = `${manager} install ${params} && npx lerna@${lernaVersion} bootstrap -- ${params}`;
        logger.debug({ cmd });
        // TODO: Switch to native util.promisify once using only node 8
        ({ stdout, stderr } = await exec(cmd, {
          cwd: tmpDir,
          shell: true,
          env,
        }));
        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);
        logger.info(
          { type: 'lerna', seconds, manager, stdout, stderr },
          'Generated lockfile'
        );
      } catch (err) /* istanbul ignore next */ {
        logger.warn(
          {
            err,
            stdout,
            stderr,
          },
          'lerna bootstrap error'
        );
        return { error: true, stderr: stderr || err.stderr };
      }
      return { error: false };
    }