mirror of
https://github.com/pnpm/pnpm.git
synced 2025-12-27 00:58:11 -05:00
140 lines
4.1 KiB
TypeScript
140 lines
4.1 KiB
TypeScript
import { PnpmError } from '@pnpm/error'
|
|
import { create, dlx } from '../src'
|
|
import { DLX_DEFAULT_OPTS as DEFAULT_OPTS } from './utils'
|
|
|
|
jest.mock('../src/dlx', () => ({ handler: jest.fn() }))
|
|
|
|
beforeEach((dlx.handler as jest.Mock).mockClear)
|
|
|
|
it('throws an error if called without arguments', async () => {
|
|
await expect(create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, [])).rejects.toThrow(PnpmError)
|
|
expect(dlx.handler).not.toHaveBeenCalled()
|
|
})
|
|
|
|
it(
|
|
'appends `create-` to an unscoped package that doesn\'t start with `create-`',
|
|
async () => {
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['some-app'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['create-some-app'])
|
|
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['create_no_dash'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['create-create_no_dash'])
|
|
}
|
|
)
|
|
|
|
it(
|
|
'does not append `create-` to an unscoped package that starts with `create-`',
|
|
async () => {
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['create-some-app'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['create-some-app'])
|
|
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['create-'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['create-'])
|
|
}
|
|
)
|
|
|
|
it(
|
|
'appends `create-` to a scoped package that doesn\'t start with `create-`',
|
|
async () => {
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope/some-app'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create-some-app'])
|
|
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope/create_no_dash'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create-create_no_dash'])
|
|
}
|
|
)
|
|
|
|
it(
|
|
'does not append `create-` to a scoped package that starts with `create-`',
|
|
async () => {
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope/create-some-app'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create-some-app'])
|
|
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope/create-'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create-'])
|
|
}
|
|
)
|
|
|
|
it('infers a package name from a plain scope', async () => {
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create'])
|
|
})
|
|
|
|
it('passes the remaining arguments to `dlx`', async () => {
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['some-app', 'directory/', '--silent'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['create-some-app', 'directory/', '--silent'])
|
|
})
|
|
|
|
it(
|
|
'appends `create` to package with preferred version`',
|
|
async () => {
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['foo@2.0.0'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['create-foo@2.0.0'])
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['foo@latest'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['create-foo@latest'])
|
|
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope@2.0.0'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create@2.0.0'])
|
|
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope@next'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create@next'])
|
|
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope/foo@2.0.0'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create-foo@2.0.0'])
|
|
|
|
await create.handler({
|
|
...DEFAULT_OPTS,
|
|
dir: process.cwd(),
|
|
}, ['@scope/create-a@2.0.0'])
|
|
expect(dlx.handler).toHaveBeenCalledWith(expect.anything(), ['@scope/create-a@2.0.0'])
|
|
}
|
|
)
|