2021-07-11 15:42:56 +02:00
---
id: e2e
2022-12-25 18:48:18 +01:00
title: 'End to End testing'
2021-07-11 15:42:56 +02:00
---
2022-02-05 19:39:12 +01:00
### Testing the integrity of React components by publishing in a private registry
2021-09-13 22:14:09 +02:00
2022-12-25 18:48:18 +01:00
> 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.
2022-02-05 19:39:12 +01:00
< 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 >
2021-09-13 22:14:09 +02:00
- [Slides ](https://docs.google.com/presentation/d/1a2xkqj1KlUayR1Bva1bVYvavwOPVuLplxFtup9MI_U4/edit?usp=sharing )
- [Demo ](https://github.com/juanpicado/verdaccio-end-to-end-tests )
2022-02-05 19:39:12 +01:00
## End to End and Verdaccio
2021-09-13 22:14:09 +02:00
2022-02-05 19:39:12 +01:00
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** .
2021-07-11 15:42:56 +02:00
Such approach has been really hard to achieve considering:
2022-12-25 18:48:18 +01:00
- 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)
2021-07-11 15:42:56 +02:00
**Verdaccio** is a lightweight registry with zero-configuration that **fits perfectly in any E2E + CI workflow** .
2021-07-27 21:52:49 +02:00
## Implementation {#implementation}
2021-07-11 15:42:56 +02:00
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 ).
2022-02-05 19:39:12 +01:00
## Examples in Open Source
The following projects have examples using Verdaccio in Open Source
### Bash Examples
2024-05-10 11:30:51 +02:00
- [Bun data:image/s3,"s3://crabby-images/9a1c5/9a1c5711963d0cb90f9ecbf20b40b56adee6696c" alt="Stars "](https://github.com/oven-sh/bun/commits/main/test/cli/install/registry/verdaccio.yaml)
2024-05-04 18:39:20 +02:00
- [Babel.js data:image/s3,"s3://crabby-images/67bed/67bed2163f984bc654a43e39ed8943a281b889af" alt="Stars "](https://github.com/babel/babel)
- [Docusaurus data:image/s3,"s3://crabby-images/9869d/9869d6e98f23b239b0a5b50c781b8a10523bf9ef" alt="Stars "](https://github.com/facebook/docusaurus)
- [create-react-app data:image/s3,"s3://crabby-images/bc49a/bc49a5e1530a12b8c9dc62100a0334293045a7ae" 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/49f71/49f71e7814c82caeeb35ac72efec99df065c7a27" alt="Stars "](https://github.com/pnpm/pnpm)
- [Uppy data:image/s3,"s3://crabby-images/16f71/16f7179547322f1803bff81fdf3068a855edb041" alt="Stars "](https://github.com/transloadit/uppy)
- [ethereum/web3.js data:image/s3,"s3://crabby-images/7f4af/7f4afff1d8e72a5777a498d6c8feb96b3ade22b1" alt="Stars "](https://github.com/ethereum/web3.js)
- [adobe react-spectrum data:image/s3,"s3://crabby-images/00253/002534261593566bef4a2c03ad971ea74428a1b6" alt="Stars "](https://github.com/adobe/react-spectrum/pull/2432)
- [Mozilla Neutrino data:image/s3,"s3://crabby-images/f682f/f682f98578989642cfcc4a117365834f50899d8e" alt="Stars "](https://github.com/neutrinojs/neutrino)
2021-07-11 15:42:56 +02:00
2024-05-04 18:39:20 +02:00
This is the simplest example using Verdaccio in a bash script (extracted from _create-react-app_ ).
2021-07-11 15:42:56 +02:00
```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"
```
2022-02-05 19:39:12 +01:00
### Docker Examples
2021-07-11 15:42:56 +02:00
2022-12-25 18:48:18 +01:00
- [Hyperledger ](https://github.com/hyperledger/fabric-chaincode-node )
2022-02-05 19:39:12 +01:00
2023-01-03 10:29:56 +01:00
### Programmatically Examples
2021-07-11 15:42:56 +02:00
2024-05-04 18:39:20 +02:00
- [Storybook data:image/s3,"s3://crabby-images/5bbe1/5bbe18f42ef3028355bdbbaa2305142c32dcbad7" alt="Stars "](https://github.com/storybooks/storybook)
- [Gatsby data:image/s3,"s3://crabby-images/7cb39/7cb39a83a0b950054703a217bb39658132d4aa17" alt="Stars "](https://github.com/gatsbyjs/gatsby)
2022-02-05 19:39:12 +01:00
#### Verdaccio module
Via CLI:
2024-05-04 18:39:20 +02:00
- [Aurelia Framework data:image/s3,"s3://crabby-images/9e565/9e5650d347a0585cc4841b278aff4b1f7e5755c7" alt="Stars "](https://github.com/aurelia)
- [Netlify CLI data:image/s3,"s3://crabby-images/9b1a9/9b1a952dd9c9fd230e6b47b194dd26cd06873ea6" alt="Stars "](https://github.com/netlify/cli)
- [Embark data:image/s3,"s3://crabby-images/31bec/31bece3286b9fbb41cd68a228561fce0c9391edc" alt="Stars "](https://embark.status.im/)
- [Microsoft Beachball data:image/s3,"s3://crabby-images/e5ac4/e5ac4fdfb5d5b35ada788d634f12045dcf4d349c" alt="Stars "](https://github.com/microsoft/beachball)
2022-12-25 18:48:18 +01:00
2022-02-05 19:39:12 +01:00
#### Node.js `child_process` examples
2024-05-04 18:39:20 +02:00
- [Angular CLI data:image/s3,"s3://crabby-images/2be35/2be35d46d46a9c29c9bc17dc23ce173defe945c7" alt="Stars "](https://github.com/angular/angular-cli)
- [bit data:image/s3,"s3://crabby-images/652f5/652f58388bbac6a720213c78b8e7958051630be5" alt="Stars "](https://github.com/teambit/bit)
- [pnpm data:image/s3,"s3://crabby-images/49f71/49f71e7814c82caeeb35ac72efec99df065c7a27" alt="Stars "](https://github.com/pnpm/pnpm)
- [aws-sdk cli v3 data:image/s3,"s3://crabby-images/68ab8/68ab8e7e8271ec80b47e072cbd6cf65e53b50f33" alt="Stars "](https://github.com/aws/aws-sdk-js-v3)
- [angular-eslint data:image/s3,"s3://crabby-images/645b3/645b35e5c6204da11c26dfdd60e73f0825e899b1" alt="Stars "](https://github.com/angular-eslint/angular-eslint)
2022-02-05 19:39:12 +01:00
2022-12-25 18:48:18 +01:00
## Example repositories
2021-07-11 15:42:56 +02:00
2022-06-22 23:12:10 +02:00
- [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 )
2023-04-30 22:56:37 +02:00
- [simplified e2e testing using verdaccio ](https://github.com/rluvaton/e2e-verdaccio-example )