Files
pnpm/installing/commands/test/addRecursive.ts
Zoltan Kochan d0ae78821a refactor: rename workspace functions from packages to projects (#11002)
Align function, type, and file names with the packages-to-projects
rename in workspace packages (projects-filter, projects-reader,
projects-sorter).
2026-03-18 11:38:02 +01:00

181 lines
4.2 KiB
TypeScript

import path from 'node:path'
import { add } from '@pnpm/installing.commands'
import type { LockfileObject } from '@pnpm/lockfile.types'
import { preparePackages } from '@pnpm/prepare'
import type { ProjectId } from '@pnpm/types'
import { filterProjectsBySelectorObjectsFromDir } from '@pnpm/workspace.projects-filter'
import { readYamlFileSync } from 'read-yaml-file'
import { DEFAULT_OPTS } from './utils/index.js'
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 filterProjectsBySelectorObjectsFromDir(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 { default: manifest } = (await import(path.resolve('project-1/package.json')))
expect(
manifest.devDependencies
).toEqual(
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
)
expect(
manifest.peerDependencies
).toEqual(
{ 'is-negative': '1.0.0' }
)
expect(
projects['project-1'].readLockfile().importers['.'].devDependencies
).toEqual(
{
'is-positive': {
specifier: '1.0.0',
version: '1.0.0',
},
'is-negative': {
specifier: '1.0.0',
version: '1.0.0',
},
}
)
}
{
const { default: manifest } = (await import(path.resolve('project-2/package.json')))
expect(
manifest.devDependencies
).toEqual(
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
)
expect(
manifest.peerDependencies
).toEqual(
{ 'is-negative': '1.0.0' }
)
expect(
projects['project-2'].readLockfile().importers['.'].devDependencies
).toEqual(
{
'is-positive': {
specifier: '1.0.0',
version: '1.0.0',
},
'is-negative': {
specifier: '1.0.0',
version: '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 filterProjectsBySelectorObjectsFromDir(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 { default: manifest } = (await import(path.resolve('project-1/package.json')))
expect(
manifest.devDependencies
).toEqual(
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
)
expect(
manifest.peerDependencies
).toEqual(
{ 'is-negative': '1.0.0' }
)
}
{
const { default: manifest } = (await import(path.resolve('project-2/package.json')))
expect(
manifest.devDependencies
).toEqual(
{ 'is-positive': '1.0.0', 'is-negative': '1.0.0' }
)
expect(
manifest.peerDependencies
).toEqual(
{ 'is-negative': '1.0.0' }
)
}
const lockfile = readYamlFileSync<LockfileObject>('./pnpm-lock.yaml')
expect(
lockfile.importers['project-1' as ProjectId].devDependencies
).toEqual(
{
'is-positive': {
specifier: '1.0.0',
version: '1.0.0',
},
'is-negative': {
specifier: '1.0.0',
version: '1.0.0',
},
}
)
})