0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2025-01-20 22:52:46 -05:00
verdaccio/test/e2e-cli
2021-06-23 20:08:22 +02:00
..
config enable CLI E2e on 5.x (#2011) 2021-04-09 17:54:28 +02:00
projects build: configure prettier as formatter for json, yaml and markdown (#1930) 2021-04-09 17:54:19 +02:00
setup build: upgrade to jest 27 (#2297) 2021-06-13 09:14:04 +02:00
test_bk feat: flexible user interface generator (#2070) 2021-04-09 17:54:38 +02:00
utils enable CLI E2e on 5.x (#2011) 2021-04-09 17:54:28 +02:00
.babelrc enable CLI E2e on 5.x (#2011) 2021-04-09 17:54:28 +02:00
.eslintrc chore: extend lint rules to root 2021-04-09 17:54:12 +02:00
CHANGELOG.md chore: update versions (alpha) (#2053) 2021-04-09 17:54:33 +02:00
env_babel.js chore: extend lint rules to root 2021-04-09 17:54:12 +02:00
env_setup.js chore: extend lint rules to root 2021-04-09 17:54:12 +02:00
env_teardown.js chore: extend lint rules to root 2021-04-09 17:54:12 +02:00
jest.config.e2e.cli.js enable CLI E2e on 5.x (#2011) 2021-04-09 17:54:28 +02:00
LICENSE enable CLI E2e on 5.x (#2011) 2021-04-09 17:54:28 +02:00
package.json chore: update dependencies (#2304) 2021-06-23 20:08:22 +02:00
README.md refactor: enable e2e for UI (#2036) 2021-04-09 17:54:29 +02:00
tsconfig.json enable CLI E2e on 5.x (#2011) 2021-04-09 17:54:28 +02:00

E2E CLI Testing

What is included on these test?

  • Default configuration only
  • Basic commands eg (install / add, info, publish).
  • Test with 3 package managers (yarn classic, pnpm and npm@7)

How it works?

On run test suites, there is a global setup where will install the local source code of verdaccio in a temporary folder. Each suite will install.

  1. spawn a registry on port 6001 using _bootstrap_verdaccio.yaml which block any local package being fetched from remote upstream.
  2. Publish local project to the spawned registry (with global pnpm)

The published verdaccio should be fetch by each suite to ensure reliability of each test.

How to write test?

Each of the suite must use a package manager command (eg: npm install) and validate the output according what the user see, either verifying the outcome in JSON form, run a command (eg: jest ..) and the expected result.

Each Test should start with the initial setup, this step does the following

  • beforeAll: Install verdaccio to the suite context that returns a Setup object.
  • afterAll: Stop the child process that runs verdaccio.
beforeAll(async () => {
  setup = await initialSetup(tempRootFolder, port);
  console.log('--setup', setup.install);
});

stop the process is the final step that should occur in every suite.

afterAll(async () => {
  setup.child.kill();
});

What should not included on these tests?

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