0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2024-12-30 22:34:10 -05:00
verdaccio/test/cli/e2e-npm8
Juan Picado a4c17858bf
test: add more packages managers to e2e cli (#3283)
* test: add more packages managers to e2e cli

* chore: remove old conf files

* Update ci.yml
2022-08-03 08:01:27 +02:00
..
.babelrc test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +02:00
.eslintrc test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +02:00
info.spec.ts test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +02:00
jest.config.js test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +02:00
LICENSE test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +02:00
package.json test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +02:00
README.md test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +02:00
tsconfig.json test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +02:00
utils.ts test: add more packages managers to e2e cli (#3283) 2022-08-03 08:01:27 +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)