This project focuses on automating the deployment of a React UI library to a private npm registry (Verdaccio) using Jenkins.
The pipeline is triggered by GitHub webhooks on code pushes to the repository. After a successful build and test process in Jenkins, the updated UI library is automatically published to Verdaccio for easy consumption by other internal projects. This ensures that developers always have access to the latest stable version of UI components while maintaining private and secure package management.
The setup uses a Red Hat 8 system and includes tools such as Java, Jenkins, Git, and Node.js to create a streamlined development workflow.
A detailed diagram outlining the entire system flow:
This diagram illustrates the end-to-end automation pipeline. It starts with GitHub, triggers the Jenkins build, and ends with Verdaccio for secure UI library management. Here's an overview:
GitHub Repository: Code pushes trigger Jenkins via a webhook to start the build process.
Jenkins Pipeline: Jenkins compiles, tests, and ensures code quality before proceeding.
Verdaccio Registry: On success, Jenkins publishes the UI library to the private Verdaccio registry for internal use.
Consuming Applications: Internal apps fetch the latest stable version of the library from Verdaccio.
This diagram highlights the seamless flow from development to deployment within a secure and automated pipeline.
Documentation is essential for clear communication and collaboration in any project. It ensures stakeholders understand the system, its components, and workflows, reducing confusion and empowering teams to work independently.
For this project, I’ve created three tailored documentation sets:
DevOps Team Documentation: Covers the infrastructure, CI/CD pipeline setup, and system architecture, providing guidance on maintaining and troubleshooting the deployment pipeline.
React Library Developers Documentation: Offers instructions on contributing to the library, managing the build and deployment process, and integrating the library into the CI/CD pipeline.
React Library Users Documentation: Provides guidance for internal developers on installing and using the library from Verdaccio, including troubleshooting tips and integration examples.
These documents ensure each group has the information needed for efficient development and usage of the React UI library.