1
0
mirror of https://github.com/verdaccio/verdaccio.git synced 2024-11-13 03:35:52 +01:00
verdaccio/e2e/cli
Juan Picado 3bc24bc4a7
chore: update versions (next-7) (#4703)
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2024-07-07 18:45:32 +02:00
..
cli-commons chore: update versions (next-7) (#4703) 2024-07-07 18:45:32 +02:00
e2e-npm6 fix(deps): update all package managers (#4557) 2024-03-23 21:21:52 +01:00
e2e-npm7 fix(deps): update all package managers (#4557) 2024-03-23 21:21:52 +01:00
e2e-npm8 fix(deps): update all package managers (#4557) 2024-03-23 21:21:52 +01:00
e2e-npm9 fix(deps): update all package managers (#4557) 2024-03-23 21:21:52 +01:00
e2e-npm10 fix(deps): update all package managers (#4557) 2024-03-23 21:21:52 +01:00
e2e-pnpm8 chore: enable pnpm e2e ci (#4554) 2024-03-23 11:32:13 +01:00
e2e-pnpm9 chore: enable pnpm e2e ci (#4554) 2024-03-23 11:32:13 +01:00
e2e-yarn1 fix(deps): update all package managers (#4557) 2024-03-23 21:21:52 +01:00
e2e-yarn2 fix(deps): update all package managers (master) (#4511) 2024-02-18 11:33:07 +01:00
e2e-yarn3 fix(deps): update all package managers (#4557) 2024-03-23 21:21:52 +01:00
e2e-yarn4 fix(deps): update all package managers (#4557) 2024-03-23 21:21:52 +01:00
jest.config.js e2e: npm search and ping commands (#3386) 2022-09-19 23:10:38 +02:00
README.md chore: enable pnpm e2e ci (#4554) 2024-03-23 11:32:13 +01:00

E2E CLI Testing

What is included on these test?

  • Default configuration only
  • Test with all popular package managers

Commands Tested

cmd npm6 npm7 npm8 npm9 npm10 pnpm8 pnpm9 (beta) yarn1 yarn2 yarn3 yarn4
publish
info
audit
install
deprecate
ping
search
star
stars
dist-tag

notes:

  • yarn search cmd exist in modern but, it do not uses the search registry endpoint.
  • yarn modern has two info commands, the one used here is yarn npm info

= no tested = tested = no supported

How it works?

Every package manager + version is a package in the monorepo.

The package @verdaccio/test-cli-commons contains helpers used for each package manager.

import { addRegistry, initialSetup, prepareGenericEmptyProject } from '@verdaccio/test-cli-commons';

The registry can be executed with the following commands, the port is automatically assigned.

// setup
const setup = await initialSetup();
registry = setup.registry;
await registry.init();
// teardown
registry.stop();

The full url can be get from registry.getRegistryUrl(). The yarn modern does not allows the --registry so need a more complex step, while others is just enough adding the following to every command.

await yarn({ cwd: tempFolder }, 'install', ...addRegistry(registry.getRegistryUrl()));

The most of the command allow return output in JSON format which helps with the expects.

const resp = await yarn(
  { cwd: tempFolder },
  'audit',
  '--json',
  ...addRegistry(registry.getRegistryUrl())
);
const parsedBody = JSON.parse(resp.stdout as string);
expect(parsedBody.type).toEqual('auditSummary');

Every command should test either console output or in special cases look up the storage manually.

What should not included on these tests?

  • Anything is unrelated with client commands usage, eg: (auth permissions, third party integrations, hooks, plugins)