1
0
mirror of https://github.com/verdaccio/verdaccio.git synced 2024-11-13 03:35:52 +01:00
verdaccio/e2e/cli
renovate[bot] 422bf8dba5
fix(deps): update dependency npm to v10.2.4 (#4121)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2023-11-29 21:21:02 +01:00
..
cli-commons chore: update versions (next) (#4093) 2023-10-28 17:22:01 +02:00
e2e-npm6 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-npm7 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-npm8 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-npm9 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-npm10 fix(deps): update dependency npm to v10.2.4 (#4121) 2023-11-29 21:21:02 +01:00
e2e-pnpm6 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-pnpm7 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-pnpm8 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-yarn1 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-yarn2 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-yarn3 feat!: bump to v7 2023-08-21 17:38:13 +02:00
e2e-yarn4 feat!: bump to v7 2023-08-21 17:38:13 +02:00
jest.config.js e2e: npm search and ping commands (#3386) 2022-09-19 23:10:38 +02:00
README.md chore: add e2e npm 10 e2e (#4036) 2023-09-24 12:44:39 +02: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 pnpm6 pnpm7 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)