mirror of
https://github.com/pnpm/pnpm.git
synced 2026-02-01 10:42:28 -05:00
151 lines
3.6 KiB
TypeScript
151 lines
3.6 KiB
TypeScript
import path from 'path'
|
|
import { readProjects } from '@pnpm/filter-workspace-packages'
|
|
import { Lockfile } from '@pnpm/lockfile-types'
|
|
import { add } from '@pnpm/plugin-commands-installation'
|
|
import { preparePackages } from '@pnpm/prepare'
|
|
import readYamlFile from 'read-yaml-file'
|
|
import { DEFAULT_OPTS } from './utils'
|
|
|
|
test('recursive add --save-dev, --save-peer on workspace with multiple lockfiles', async () => {
|
|
const projects = preparePackages([
|
|
{
|
|
name: 'project-1',
|
|
version: '1.0.0',
|
|
},
|
|
{
|
|
name: 'project-2',
|
|
version: '1.0.0',
|
|
},
|
|
])
|
|
|
|
const { allProjects, selectedProjectsGraph } = await readProjects(process.cwd(), [])
|
|
|
|
await add.handler({
|
|
...DEFAULT_OPTS,
|
|
allProjects,
|
|
dir: process.cwd(),
|
|
recursive: true,
|
|
saveDev: true,
|
|
selectedProjectsGraph,
|
|
workspaceDir: process.cwd(),
|
|
}, ['is-positive@1.0.0'])
|
|
await add.handler({
|
|
...DEFAULT_OPTS,
|
|
allProjects,
|
|
dir: process.cwd(),
|
|
recursive: true,
|
|
savePeer: true,
|
|
selectedProjectsGraph,
|
|
workspaceDir: process.cwd(),
|
|
}, ['is-negative@1.0.0'])
|
|
|
|
{
|
|
const manifest = (await import(path.resolve('project-1/package.json')))
|
|
expect(
|
|
manifest.devDependencies
|
|
).toStrictEqual(
|
|
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
|
|
)
|
|
expect(
|
|
manifest.peerDependencies
|
|
).toStrictEqual(
|
|
{ 'is-negative': '1.0.0' }
|
|
)
|
|
expect(
|
|
(await projects['project-1'].readLockfile()).devDependencies
|
|
).toStrictEqual(
|
|
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
|
|
)
|
|
}
|
|
|
|
{
|
|
const manifest = (await import(path.resolve('project-2/package.json')))
|
|
expect(
|
|
manifest.devDependencies
|
|
).toStrictEqual(
|
|
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
|
|
)
|
|
expect(
|
|
manifest.peerDependencies
|
|
).toStrictEqual(
|
|
{ 'is-negative': '1.0.0' }
|
|
)
|
|
expect(
|
|
(await projects['project-2'].readLockfile()).devDependencies
|
|
).toStrictEqual(
|
|
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
|
|
)
|
|
}
|
|
})
|
|
|
|
test('recursive add --save-dev, --save-peer on workspace with single lockfile', async () => {
|
|
preparePackages([
|
|
{
|
|
name: 'project-1',
|
|
version: '1.0.0',
|
|
},
|
|
{
|
|
name: 'project-2',
|
|
version: '1.0.0',
|
|
},
|
|
])
|
|
|
|
const { allProjects, selectedProjectsGraph } = await readProjects(process.cwd(), [])
|
|
|
|
await add.handler({
|
|
...DEFAULT_OPTS,
|
|
allProjects,
|
|
dir: process.cwd(),
|
|
lockfileDir: process.cwd(),
|
|
recursive: true,
|
|
saveDev: true,
|
|
selectedProjectsGraph,
|
|
workspaceDir: process.cwd(),
|
|
}, ['is-positive@1.0.0'])
|
|
await add.handler({
|
|
...DEFAULT_OPTS,
|
|
allProjects,
|
|
dir: process.cwd(),
|
|
lockfileDir: process.cwd(),
|
|
recursive: true,
|
|
savePeer: true,
|
|
selectedProjectsGraph,
|
|
workspaceDir: process.cwd(),
|
|
}, ['is-negative@1.0.0'])
|
|
|
|
{
|
|
const manifest = (await import(path.resolve('project-1/package.json')))
|
|
expect(
|
|
manifest.devDependencies
|
|
).toStrictEqual(
|
|
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
|
|
)
|
|
expect(
|
|
manifest.peerDependencies
|
|
).toStrictEqual(
|
|
{ 'is-negative': '1.0.0' }
|
|
)
|
|
}
|
|
|
|
{
|
|
const manifest = (await import(path.resolve('project-2/package.json')))
|
|
expect(
|
|
manifest.devDependencies
|
|
).toStrictEqual(
|
|
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
|
|
)
|
|
expect(
|
|
manifest.peerDependencies
|
|
).toStrictEqual(
|
|
{ 'is-negative': '1.0.0' }
|
|
)
|
|
}
|
|
|
|
const lockfile = await readYamlFile<Lockfile>('./pnpm-lock.yaml')
|
|
expect(
|
|
lockfile.importers['project-1'].devDependencies
|
|
).toStrictEqual(
|
|
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
|
|
)
|
|
})
|