mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-02-17 23:45:29 -05:00
101 lines
5.7 KiB
Markdown
101 lines
5.7 KiB
Markdown
---
|
||
id: e2e
|
||
title: 'End to End testing'
|
||
---
|
||
|
||
### Testing the integrity of React components by publishing in a private registry
|
||
|
||
> The final stage of a react component is when it is being published and distributed. How can I ensure my packages won’t crash in production? This talk will help you to test your React components by publishing them to a private registry and running End-to-End tests against them.
|
||
|
||
<iframe width="300" height="600" src="https://www.youtube.com/embed/bRKZbrlQqLY" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
|
||
|
||
- [Slides](https://docs.google.com/presentation/d/1a2xkqj1KlUayR1Bva1bVYvavwOPVuLplxFtup9MI_U4/edit?usp=sharing)
|
||
- [Demo](https://github.com/juanpicado/verdaccio-end-to-end-tests)
|
||
|
||
## End to End and Verdaccio
|
||
|
||
Some projects organize packages in multi-packages repositories or [monorepos](https://github.com/babel/babel/blob/master/doc/design/monorepo.md). End to End testing is a topic that usually is only relevant for User Interfaces, but from a Node.js perspective, **publishing packages also need to be tested**.
|
||
|
||
Such approach has been really hard to achieve considering:
|
||
|
||
- Populate canary packages on public services seems not to be a good idea
|
||
- Some self-hosted OSS registries are too heavy
|
||
- Offline environments (private networks)
|
||
|
||
**Verdaccio** is a lightweight registry with zero-configuration that **fits perfectly in any E2E + CI workflow**.
|
||
|
||
## Implementation {#implementation}
|
||
|
||
There is no a silver bullet yet, each implementation seems to be specific for each project, you can check some of them in
|
||
the following thread [clicking here](https://stackoverflow.com/a/50222427/308341).
|
||
|
||
## Examples in Open Source
|
||
|
||
The following projects have examples using Verdaccio in Open Source
|
||
|
||
### Bash Examples
|
||
|
||
- [Bun data:image/s3,"s3://crabby-images/8ab4d/8ab4dcdb16a135ef5ec0306059536da6050e5adb" alt="Stars"](https://github.com/oven-sh/bun/commits/main/test/cli/install/registry/verdaccio.yaml)
|
||
- [Babel.js data:image/s3,"s3://crabby-images/f6f06/f6f06799e9c2f08d738985443583d0de121fee9b" alt="Stars"](https://github.com/babel/babel)
|
||
- [Docusaurus data:image/s3,"s3://crabby-images/a20b3/a20b3c3c69fb2f452d2fb24a209853f51b2b5eb3" alt="Stars"](https://github.com/facebook/docusaurus)
|
||
- [create-react-app data:image/s3,"s3://crabby-images/ec18a/ec18a0b756710f4ffa78932ce184357a4487d535" alt="Stars"](https://github.com/facebook/create-react-app/blob/master/CONTRIBUTING.md#contributing-to-e2e-end-to-end-tests)
|
||
- [pnpm data:image/s3,"s3://crabby-images/75892/758927e95c7be94dd1e620246aab6ddc0c3a5388" alt="Stars"](https://github.com/pnpm/pnpm)
|
||
- [Uppy data:image/s3,"s3://crabby-images/29d32/29d32659bb04326ce13e05802b99121daaa19f5a" alt="Stars"](https://github.com/transloadit/uppy)
|
||
- [ethereum/web3.js data:image/s3,"s3://crabby-images/47fec/47fec981bf2f228c1dabad6211552c3fe3257fea" alt="Stars"](https://github.com/ethereum/web3.js)
|
||
- [adobe react-spectrum data:image/s3,"s3://crabby-images/21ca9/21ca9830074f725a5818d683f123f287aed714a1" alt="Stars"](https://github.com/adobe/react-spectrum/pull/2432)
|
||
- [Mozilla Neutrino data:image/s3,"s3://crabby-images/6b9e3/6b9e3b7a4e9436f3879108e4cb5baff6415fda0d" alt="Stars"](https://github.com/neutrinojs/neutrino)
|
||
|
||
This is the simplest example using Verdaccio in a bash script (extracted from _create-react-app_).
|
||
|
||
```bash
|
||
#!/bin/sh
|
||
|
||
set -e
|
||
|
||
local_registry="http://0.0.0.0:4873"
|
||
|
||
# start local registry
|
||
tmp_registry_log=`mktemp`
|
||
sh -c "mkdir -p $HOME/.config/verdaccio"
|
||
sh -c "cp --verbose /config.yaml $HOME/.config/verdaccio/config.yaml"
|
||
sh -c "nohup verdaccio --config $HOME/.config/verdaccio/config.yaml &>$tmp_registry_log &"
|
||
# wait for `verdaccio` to boot
|
||
grep -q 'http address' <(tail -f $tmp_registry_log)
|
||
# login so we can publish packages
|
||
sh -c "npm-auth-to-token -u test -p test -e test@test.com -r $local_registry"
|
||
# Run nmp command
|
||
sh -c "npm --registry $local_registry publish"
|
||
```
|
||
|
||
### Docker Examples
|
||
|
||
- [Hyperledger](https://github.com/hyperledger/fabric-chaincode-node)
|
||
|
||
### Programmatically Examples
|
||
|
||
- [Storybook data:image/s3,"s3://crabby-images/d93c6/d93c654f62a1aa6e08dd8e9bef59d23820b31dd9" alt="Stars"](https://github.com/storybooks/storybook)
|
||
- [Gatsby data:image/s3,"s3://crabby-images/862a3/862a32e6a3140eab0b93eb242b76ae6106616218" alt="Stars"](https://github.com/gatsbyjs/gatsby)
|
||
|
||
#### Verdaccio module
|
||
|
||
Via CLI:
|
||
|
||
- [Aurelia Framework data:image/s3,"s3://crabby-images/a0cda/a0cda8f8a61a1dbc8d6d5ccc89141b4d5ccd582c" alt="Stars"](https://github.com/aurelia)
|
||
- [Netlify CLI data:image/s3,"s3://crabby-images/94571/94571c85e2872bcfe281f1b11d0f3182e64453eb" alt="Stars"](https://github.com/netlify/cli)
|
||
- [Embark data:image/s3,"s3://crabby-images/79891/79891f5d28560e91538b73bec3ba8d85ea8d387a" alt="Stars"](https://embark.status.im/)
|
||
- [Microsoft Beachball data:image/s3,"s3://crabby-images/c28fa/c28fa33ee6ec58d3f308a83d1a5e6be485439440" alt="Stars"](https://github.com/microsoft/beachball)
|
||
|
||
#### Node.js `child_process` examples
|
||
|
||
- [Angular CLI data:image/s3,"s3://crabby-images/ab323/ab323bc5c8fa5c0c9d0ca9e3fdfa92e0cc0d3cd1" alt="Stars"](https://github.com/angular/angular-cli)
|
||
- [bit data:image/s3,"s3://crabby-images/40539/4053978649748ed549bcf5a71f79305672eff093" alt="Stars"](https://github.com/teambit/bit)
|
||
- [pnpm data:image/s3,"s3://crabby-images/75892/758927e95c7be94dd1e620246aab6ddc0c3a5388" alt="Stars"](https://github.com/pnpm/pnpm)
|
||
- [aws-sdk cli v3 data:image/s3,"s3://crabby-images/dc213/dc213311bd0a244ce4c08b30d8c205d83025ea35" alt="Stars"](https://github.com/aws/aws-sdk-js-v3)
|
||
- [angular-eslint data:image/s3,"s3://crabby-images/96caa/96caa69fa0da5ed735233aef1901914f40680f00" alt="Stars"](https://github.com/angular-eslint/angular-eslint)
|
||
|
||
## Example repositories
|
||
|
||
- [e2e-ci-example-gh-actions](https://github.com/juanpicado/e2e-ci-example-gh-actions)
|
||
- [verdaccio-end-to-end-tests](https://github.com/juanpicado/verdaccio-end-to-end-tests)
|
||
- [verdaccio-fork](https://github.com/juanpicado/verdaccio-fork)
|
||
- [simplified e2e testing using verdaccio](https://github.com/rluvaton/e2e-verdaccio-example)
|