Files
pnpm/pkg-manager/plugin-commands-installation/test/linkRecursive.ts
Brandon Cheng 75a98e12b3 refactor: improve type checking when finding workspace packages (#8214)
---------

Co-authored-by: Zoltan Kochan <z@kochan.io>
2024-06-17 17:34:54 +02:00

138 lines
4.0 KiB
TypeScript

import fs from 'fs'
import path from 'path'
import { LOCKFILE_VERSION } from '@pnpm/constants'
import { filterPackagesFromDir } from '@pnpm/workspace.filter-packages-from-dir'
import { install, unlink } from '@pnpm/plugin-commands-installation'
import { preparePackages } from '@pnpm/prepare'
import { DEFAULT_OPTS } from './utils'
test('recursive linking/unlinking', async () => {
const projects = preparePackages([
{
name: 'project-1',
version: '1.0.0',
devDependencies: {
'is-positive': '1.0.0',
},
},
{
name: 'is-positive',
version: '1.0.0',
dependencies: {
'is-negative': '1.0.0',
},
},
])
const { allProjects, allProjectsGraph, selectedProjectsGraph } = await filterPackagesFromDir(process.cwd(), [])
await install.handler({
...DEFAULT_OPTS,
allProjects,
allProjectsGraph,
dir: process.cwd(),
recursive: true,
saveWorkspaceProtocol: false,
selectedProjectsGraph,
workspaceDir: process.cwd(),
})
expect(projects['is-positive'].requireModule('is-negative')).toBeTruthy()
expect(projects['project-1'].requireModule('is-positive/package.json').author).toBeFalsy()
{
const project1Lockfile = projects['project-1'].readLockfile()
expect(project1Lockfile.importers['.'].devDependencies?.['is-positive'].version).toBe('link:../is-positive')
}
await unlink.handler({
...DEFAULT_OPTS,
allProjects,
allProjectsGraph,
dir: process.cwd(),
recursive: true,
saveWorkspaceProtocol: false,
selectedProjectsGraph,
workspaceDir: process.cwd(),
}, [])
process.chdir('project-1')
expect(fs.existsSync(path.resolve('node_modules', 'is-positive', 'index.js'))).toBeTruthy()
{
const project1Lockfile = projects['project-1'].readLockfile()
expect(project1Lockfile.lockfileVersion).toBe(LOCKFILE_VERSION)
expect(project1Lockfile.importers['.'].devDependencies?.['is-positive'].version).toBe('1.0.0')
expect(project1Lockfile.packages['is-positive@1.0.0']).toBeTruthy()
}
const isPositiveLockfile = projects['is-positive'].readLockfile()
expect(isPositiveLockfile.lockfileVersion).toBe(LOCKFILE_VERSION)
})
test('recursive unlink specific package', async () => {
const projects = preparePackages([
{
name: 'project-1',
version: '1.0.0',
devDependencies: {
'is-positive': '1.0.0',
},
},
{
name: 'is-positive',
version: '1.0.0',
dependencies: {
'is-negative': '1.0.0',
},
},
])
const { allProjects, allProjectsGraph, selectedProjectsGraph } = await filterPackagesFromDir(process.cwd(), [])
await install.handler({
...DEFAULT_OPTS,
allProjects,
allProjectsGraph,
dir: process.cwd(),
recursive: true,
saveWorkspaceProtocol: false,
selectedProjectsGraph,
workspaceDir: process.cwd(),
})
expect(projects['is-positive'].requireModule('is-negative')).toBeTruthy()
expect(projects['project-1'].requireModule('is-positive/package.json').author).toBeFalsy()
{
const project1Lockfile = projects['project-1'].readLockfile()
expect(project1Lockfile.importers['.'].devDependencies?.['is-positive'].version).toBe('link:../is-positive')
}
await unlink.handler({
...DEFAULT_OPTS,
allProjects,
allProjectsGraph,
dir: process.cwd(),
recursive: true,
saveWorkspaceProtocol: false,
selectedProjectsGraph,
workspaceDir: process.cwd(),
}, ['is-positive'])
process.chdir('project-1')
expect(fs.existsSync(path.resolve('node_modules', 'is-positive', 'index.js'))).toBeTruthy()
{
const project1Lockfile = projects['project-1'].readLockfile()
expect(project1Lockfile.lockfileVersion).toBe(LOCKFILE_VERSION)
expect(project1Lockfile.importers['.'].devDependencies?.['is-positive'].version).toBe('1.0.0')
expect(project1Lockfile.packages['is-positive@1.0.0']).toBeTruthy()
}
const isPositiveLockfile = projects['is-positive'].readLockfile()
expect(isPositiveLockfile.lockfileVersion).toBe(LOCKFILE_VERSION)
})