mirror of
https://github.com/pnpm/pnpm.git
synced 2026-01-06 05:58:20 -05:00
166 lines
4.3 KiB
TypeScript
166 lines
4.3 KiB
TypeScript
import path from 'path'
|
|
import { filterPackagesFromDir } from '@pnpm/workspace.filter-packages-from-dir'
|
|
import { type LockfileFile } from '@pnpm/lockfile.types'
|
|
import { install, remove } from '@pnpm/plugin-commands-installation'
|
|
import { preparePackages } from '@pnpm/prepare'
|
|
import { sync as readYamlFile } from 'read-yaml-file'
|
|
import { DEFAULT_OPTS } from '../utils'
|
|
|
|
test('remove --filter only changes the specified dependency, when run with link-workspace-packages=false', async () => {
|
|
const projects = preparePackages([
|
|
{
|
|
name: 'project-1',
|
|
version: '1.0.0',
|
|
|
|
dependencies: {
|
|
'is-negative': '1.0.0',
|
|
},
|
|
},
|
|
{
|
|
name: 'project-2',
|
|
version: '1.0.0',
|
|
|
|
dependencies: {
|
|
'project-1': '1.0.0',
|
|
'is-negative': '1.0.0',
|
|
},
|
|
},
|
|
])
|
|
|
|
const sharedOpts = {
|
|
dir: process.cwd(),
|
|
recursive: true,
|
|
workspaceDir: process.cwd(),
|
|
lockfileDir: process.cwd(),
|
|
sharedWorkspaceLockfile: true,
|
|
linkWorkspacePackages: false,
|
|
}
|
|
|
|
await install.handler({
|
|
...DEFAULT_OPTS,
|
|
...await filterPackagesFromDir(process.cwd(), []),
|
|
...sharedOpts,
|
|
})
|
|
|
|
await remove.handler({
|
|
...DEFAULT_OPTS,
|
|
// Only remove is-negative from project-2
|
|
...await filterPackagesFromDir(process.cwd(), [{ namePattern: 'project-2' }]),
|
|
...sharedOpts,
|
|
}, ['is-negative'])
|
|
|
|
// project-1 should be unchanged
|
|
{
|
|
const pkg = await import(path.resolve('project-1/package.json'))
|
|
expect(pkg?.dependencies).toStrictEqual({
|
|
'is-negative': '1.0.0',
|
|
})
|
|
}
|
|
|
|
// project-2 has the is-negative dependency removed
|
|
{
|
|
const pkg = await import(path.resolve('project-2/package.json'))
|
|
expect(pkg?.dependencies).toStrictEqual({
|
|
'project-1': '1.0.0',
|
|
})
|
|
}
|
|
|
|
// Anything left can still be resolved
|
|
projects['project-1'].has('is-negative')
|
|
projects['project-2'].has('project-1')
|
|
projects['project-2'].hasNot('is-negative')
|
|
|
|
// The lockfile agrees with the above
|
|
const lockfile = readYamlFile<LockfileFile>('./pnpm-lock.yaml')
|
|
|
|
expect(lockfile.importers?.['project-1'].dependencies?.['is-negative']).toStrictEqual({
|
|
specifier: '1.0.0',
|
|
version: '1.0.0',
|
|
})
|
|
|
|
expect(lockfile.importers?.['project-2'].dependencies?.['project-1']).toStrictEqual({
|
|
specifier: '1.0.0',
|
|
version: '1.0.0',
|
|
})
|
|
})
|
|
|
|
test('remove from within a workspace package dir only affects the specified dependency, when run with link-workspace-packages=false', async () => {
|
|
const projects = preparePackages([
|
|
{
|
|
name: 'project-1',
|
|
version: '1.0.0',
|
|
|
|
dependencies: {
|
|
'is-negative': '1.0.0',
|
|
},
|
|
},
|
|
{
|
|
name: 'project-2',
|
|
version: '1.0.0',
|
|
|
|
dependencies: {
|
|
'project-1': '1.0.0',
|
|
'is-negative': '1.0.0',
|
|
},
|
|
},
|
|
])
|
|
|
|
const sharedOpts = {
|
|
dir: process.cwd(),
|
|
workspaceDir: process.cwd(),
|
|
lockfileDir: process.cwd(),
|
|
sharedWorkspaceLockfile: true,
|
|
linkWorkspacePackages: false,
|
|
}
|
|
|
|
await install.handler({
|
|
...DEFAULT_OPTS,
|
|
...await filterPackagesFromDir(process.cwd(), []),
|
|
...sharedOpts,
|
|
recursive: true,
|
|
})
|
|
|
|
await remove.handler({
|
|
...DEFAULT_OPTS,
|
|
...sharedOpts,
|
|
// In this scenario, remove is invoked from within a workspace directory,
|
|
// non-recursively
|
|
dir: projects['project-2'].dir(),
|
|
recursive: false,
|
|
}, ['is-negative'])
|
|
|
|
// project-1 should be unchanged
|
|
{
|
|
const pkg = await import(path.resolve('project-1/package.json'))
|
|
expect(pkg?.dependencies).toStrictEqual({
|
|
'is-negative': '1.0.0',
|
|
})
|
|
}
|
|
|
|
// project-2 has the is-negative dependency removed
|
|
{
|
|
const pkg = await import(path.resolve('project-2/package.json'))
|
|
expect(pkg?.dependencies).toStrictEqual({
|
|
'project-1': '1.0.0',
|
|
})
|
|
}
|
|
|
|
// Anything left can still be resolved
|
|
projects['project-1'].has('is-negative')
|
|
projects['project-2'].has('project-1')
|
|
projects['project-2'].hasNot('is-negative')
|
|
|
|
// The lockfile agrees with the above
|
|
const lockfile = readYamlFile<LockfileFile>('./pnpm-lock.yaml')
|
|
|
|
expect(lockfile.importers?.['project-1'].dependencies?.['is-negative']).toStrictEqual({
|
|
specifier: '1.0.0',
|
|
version: '1.0.0',
|
|
})
|
|
|
|
expect(lockfile.importers?.['project-2'].dependencies?.['project-1']).toStrictEqual({
|
|
specifier: '1.0.0',
|
|
version: '1.0.0',
|
|
})
|
|
})
|