import { addRegistry, initialSetup, prepareGenericEmptyProject } from '@verdaccio/test-cli-commons'; import { pnpm } from './utils'; describe('deprecate a package', () => { jest.setTimeout(15000); let registry; async function bumbUp(tempFolder, registry) { await pnpm({ cwd: tempFolder }, 'version', 'minor', ...addRegistry(registry.getRegistryUrl())); } async function publish(tempFolder, pkgName, registry) { const resp = await pnpm( { cwd: tempFolder }, 'publish', '--json', ...addRegistry(registry.getRegistryUrl()) ); const parsedBody = JSON.parse(resp.stdout as string); expect(parsedBody.name).toEqual(pkgName); } async function deprecate(tempFolder, packageVersion, registry, message) { await pnpm( { cwd: tempFolder }, 'deprecate', packageVersion, message, '--json', ...addRegistry(registry.getRegistryUrl()) ); } async function getInfoVersions(pkgName, registry) { const infoResp = await pnpm( {}, 'info', pkgName, '--json', ...addRegistry(registry.getRegistryUrl()) ); const infoBody = JSON.parse(infoResp.stdout as string); return infoBody; } beforeAll(async () => { const setup = await initialSetup(); registry = setup.registry; await registry.init(); }); test.each([['@verdaccio/deprecated-1']])( 'should deprecate a single package %s', async (pkgName) => { const message = 'some message'; const { tempFolder } = await prepareGenericEmptyProject( pkgName, '1.0.0', registry.port, registry.getToken(), registry.getRegistryUrl() ); await publish(tempFolder, pkgName, registry); // deprecate one version await deprecate(tempFolder, `${pkgName}@1.0.0`, registry, message); // verify is deprecated const infoBody = await getInfoVersions(`${pkgName}`, registry); expect(infoBody.name).toEqual(pkgName); expect(infoBody.deprecated).toEqual(message); } ); test.each([['@verdaccio/deprecated-2']])('should un-deprecate a package %s', async (pkgName) => { const message = 'some message'; const { tempFolder } = await prepareGenericEmptyProject( pkgName, '1.0.0', registry.port, registry.getToken(), registry.getRegistryUrl() ); await publish(tempFolder, pkgName, registry); // deprecate one version await deprecate(tempFolder, `${pkgName}@1.0.0`, registry, message); // verify is deprecated const infoBody = await getInfoVersions(`${pkgName}`, registry); expect(infoBody.deprecated).toEqual(message); // empty string is same as undeprecate await deprecate(tempFolder, `${pkgName}@1.0.0`, registry, ''); const infoBody2 = await getInfoVersions(`${pkgName}`, registry); expect(infoBody2.deprecated).toBeUndefined(); }); test.each([['@verdaccio/deprecated-3']])( 'should deprecate a multiple packages %s', async (pkgName) => { const message = 'some message'; const { tempFolder } = await prepareGenericEmptyProject( pkgName, '1.0.0', registry.port, registry.getToken(), registry.getRegistryUrl() ); // publish 1.0.0 await publish(tempFolder, pkgName, registry); // publish 1.1.0 await bumbUp(tempFolder, registry); await publish(tempFolder, pkgName, registry); // publish 1.2.0 await bumbUp(tempFolder, registry); await publish(tempFolder, pkgName, registry); // publish 1.3.0 await bumbUp(tempFolder, registry); await publish(tempFolder, pkgName, registry); // // deprecate all version await deprecate(tempFolder, pkgName, registry, message); // verify is deprecated for (let v of ['1.0.0', '1.1.0', '1.2.0', '1.3.0']) { const infoResp = await getInfoVersions(`${pkgName}@${v}`, registry); expect(infoResp.deprecated).toEqual(message); } // publish normal version // publish 1.4.0 await bumbUp(tempFolder, registry); await publish(tempFolder, pkgName, registry); const infoResp = await getInfoVersions(`${pkgName}@1.4.0`, registry); // must be not deprecated expect(infoResp.deprecated).toBeUndefined(); } ); afterAll(async () => { registry.stop(); }); });