Skip to content
Snippets Groups Projects
Select Git revision
  • f9dcf36cbc710faf59ebd3fda8cdbfefad00817c
  • main default protected
  • next
  • 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
  • fix/32307-global-extends-repositories
  • gh-readonly-queue/next/pr-35009-046ebf7cb84ab859f7fefceb5fa53a54ce9736f8
  • gh-readonly-queue/next/pr-35009-9d5e583b7d7251148ab0d11ee8dd38149618d162
  • 41.17.2
  • 41.17.1
  • 41.17.0
  • 41.16.3
  • 41.16.2
  • 41.16.1
  • 41.16.0
  • 41.15.0
  • 41.14.0
  • 41.13.1
  • 41.13.0
  • 41.12.1
  • 41.12.0
  • 41.11.1
  • 41.11.0
  • 41.10.1
  • 41.10.0
  • 41.9.0
  • 41.8.0
  • 41.7.2
41 results

pnpm.spec.ts

Blame
  • pnpm.spec.ts 1.99 KiB
    import { exec as _exec } from 'child_process';
    import _fs from 'fs-extra';
    import { envMock, mockExecAll } from '../../../../test/execUtil';
    import { mocked } from '../../../../test/util';
    import * as _env from '../../../util/exec/env';
    import { PostUpdateConfig } from '../../common';
    import * as _pnpmHelper from './pnpm';
    
    jest.mock('fs-extra');
    jest.mock('child_process');
    jest.mock('../../../util/exec/env');
    
    const exec: jest.Mock<typeof _exec> = _exec as any;
    const env = mocked(_env);
    const fs = mocked(_fs);
    const pnpmHelper = mocked(_pnpmHelper);
    delete process.env.NPM_CONFIG_CACHE;
    
    describe('generateLockFile', () => {
      let config: PostUpdateConfig;
      beforeEach(() => {
        config = { cacheDir: 'some-cache-dir' };
        env.getChildProcessEnv.mockReturnValue(envMock.basic);
      });
      it('generates lock files', async () => {
        config.dockerMapDotfiles = true;
        const execSnapshots = mockExecAll(exec);
        fs.readFile = jest.fn(() => 'package-lock-contents') as never;
        const res = await pnpmHelper.generateLockFile('some-dir', {}, config);
        expect(fs.readFile).toHaveBeenCalledTimes(1);
        expect(res.lockFile).toEqual('package-lock-contents');
        expect(execSnapshots).toMatchSnapshot();
      });
      it('catches errors', async () => {
        const execSnapshots = mockExecAll(exec);
        fs.readFile = jest.fn(() => {
          throw new Error('not found');
        }) as never;
        const res = await pnpmHelper.generateLockFile('some-dir', {}, config);
        expect(fs.readFile).toHaveBeenCalledTimes(1);
        expect(res.error).toBe(true);
        expect(res.lockFile).not.toBeDefined();
        expect(execSnapshots).toMatchSnapshot();
      });
      it('finds pnpm globally', async () => {
        const execSnapshots = mockExecAll(exec);
        fs.readFile = jest.fn(() => 'package-lock-contents') as never;
        const res = await pnpmHelper.generateLockFile('some-dir', {}, config);
        expect(fs.readFile).toHaveBeenCalledTimes(1);
        expect(res.lockFile).toEqual('package-lock-contents');
        expect(execSnapshots).toMatchSnapshot();
      });
    });