mirror of
https://github.com/pnpm/pnpm.git
synced 2026-03-24 10:01:48 -04:00
Co-authored-by: Zoltan Kochan <z@kochan.io> Co-authored-by: David Michon <dmichon@microsoft.com>
147 lines
3.7 KiB
TypeScript
147 lines
3.7 KiB
TypeScript
import fs from 'fs'
|
|
import path from 'path'
|
|
import { prepareEmpty, preparePackages } from '@pnpm/prepare'
|
|
import { install, mutateModules } from '@pnpm/core'
|
|
import { testDefaults } from '../utils'
|
|
import { WANTED_LOCKFILE } from '@pnpm/constants'
|
|
import { ProjectManifest } from '@pnpm/types'
|
|
import { getCurrentBranch } from '@pnpm/git-utils'
|
|
import writeYamlFile from 'write-yaml-file'
|
|
|
|
jest.mock('@pnpm/git-utils', () => ({ getCurrentBranch: jest.fn() }))
|
|
|
|
test('install with git-branch-lockfile = true', async () => {
|
|
prepareEmpty()
|
|
|
|
const branchName: string = 'main-branch'
|
|
getCurrentBranch['mockReturnValue'](branchName)
|
|
|
|
const opts = await testDefaults({
|
|
useGitBranchLockfile: true,
|
|
})
|
|
|
|
await install({
|
|
dependencies: {
|
|
'is-positive': '^3.0.0',
|
|
},
|
|
}, opts)
|
|
|
|
expect(fs.existsSync(`pnpm-lock.${branchName}.yaml`)).toBe(true)
|
|
expect(fs.existsSync(WANTED_LOCKFILE)).toBe(false)
|
|
})
|
|
|
|
test('install with git-branch-lockfile = true and no lockfile changes', async () => {
|
|
prepareEmpty()
|
|
|
|
const branchName: string = 'main-branch'
|
|
getCurrentBranch['mockReturnValue'](branchName)
|
|
|
|
const manifest: ProjectManifest = {
|
|
dependencies: {
|
|
'is-positive': '^3.0.0',
|
|
},
|
|
}
|
|
|
|
const opts1 = await testDefaults({
|
|
useGitBranchLockfile: false,
|
|
})
|
|
await install(manifest, opts1)
|
|
|
|
expect(fs.existsSync(WANTED_LOCKFILE)).toBe(true)
|
|
|
|
const opts2 = await testDefaults({
|
|
useGitBranchLockfile: true,
|
|
})
|
|
await install(manifest, opts2)
|
|
expect(fs.existsSync(WANTED_LOCKFILE)).toBe(true)
|
|
// Git branch lockfile is created only if there are changes in the lockfile
|
|
expect(fs.existsSync(`pnpm-lock.${branchName}.yaml`)).toBe(false)
|
|
})
|
|
|
|
test('install a workspace with git-branch-lockfile = true', async () => {
|
|
const rootManifest: ProjectManifest = {
|
|
name: 'root',
|
|
}
|
|
const project1Manifest: ProjectManifest = {
|
|
name: 'project-1',
|
|
dependencies: { 'is-positive': '1.0.0' },
|
|
}
|
|
const project2Manifest: ProjectManifest = {
|
|
name: 'project-2',
|
|
dependencies: { 'is-positive': '1.0.0' },
|
|
}
|
|
preparePackages([
|
|
{
|
|
location: '.',
|
|
package: rootManifest,
|
|
},
|
|
{
|
|
location: 'project-1',
|
|
package: project1Manifest,
|
|
},
|
|
{
|
|
location: 'project-2',
|
|
package: project2Manifest,
|
|
},
|
|
])
|
|
|
|
const branchName: string = 'main-branch'
|
|
getCurrentBranch['mockReturnValue'](branchName)
|
|
|
|
const opts = await testDefaults({
|
|
useGitBranchLockfile: true,
|
|
})
|
|
|
|
await mutateModules([
|
|
{
|
|
buildIndex: 0,
|
|
manifest: rootManifest,
|
|
mutation: 'install',
|
|
rootDir: process.cwd(),
|
|
},
|
|
{
|
|
buildIndex: 0,
|
|
manifest: project1Manifest,
|
|
mutation: 'install',
|
|
rootDir: path.resolve('project-1'),
|
|
},
|
|
{
|
|
buildIndex: 0,
|
|
manifest: project2Manifest,
|
|
mutation: 'install',
|
|
rootDir: path.resolve('project-2'),
|
|
},
|
|
], opts)
|
|
|
|
expect(fs.existsSync(`pnpm-lock.${branchName}.yaml`)).toBe(true)
|
|
expect(fs.existsSync(WANTED_LOCKFILE)).toBe(false)
|
|
})
|
|
|
|
test('install with --merge-git-branch-lockfiles', async () => {
|
|
prepareEmpty()
|
|
|
|
const branchName: string = 'main-branch'
|
|
getCurrentBranch['mockReturnValue'](branchName)
|
|
|
|
const otherLockfilePath: string = path.resolve('pnpm-lock.other.yaml')
|
|
await writeYamlFile(otherLockfilePath, {
|
|
whatever: 'whatever',
|
|
})
|
|
|
|
expect(fs.existsSync(otherLockfilePath)).toBe(true)
|
|
expect(fs.existsSync(WANTED_LOCKFILE)).toBe(false)
|
|
|
|
const opts = await testDefaults({
|
|
useGitBranchLockfile: true,
|
|
mergeGitBranchLockfiles: true,
|
|
})
|
|
await install({
|
|
dependencies: {
|
|
'is-positive': '^3.0.0',
|
|
},
|
|
}, opts)
|
|
|
|
expect(fs.existsSync(otherLockfilePath)).toBe(false)
|
|
expect(fs.existsSync(WANTED_LOCKFILE)).toBe(true)
|
|
})
|