ExpenseTracker is an ambitious project aiming to leverage the Spring Boot framework, MySQL database, and React to create a robust web application dedicated to seamless budgeting and expense tracking. This comprehensive solution provides an intuitive user experience and efficient financial management. The project comprises various components and tasks that collectively contribute to its functionality.
Agile-Board:
Front-End:
- ReactJS
Backend:
- Java (Spring Boot Maven)
Database:
- MySQL
Internationalization:
- i18next
- react-i18next
API Documentation:
- Swagger
Test Cases:
- Confluence
-
Code Repository:
- GitHub
-
Testing (run tests on each pull request):
- Unit Testing, Integration Test:
- Backend -> JUnit
- Frontend -> Jest and React Testing Library
- End-to-end testing (E2E):
- Selenium (inside Docker container)
- Unit Testing, Integration Test:
-
Build Tools:
- Maven for Spring Boot
- NPM for React
-
Container:
- Docker
-
Image/Artifact Repository:
- JFrog Artifactory
-
Build Automation:
- GitHub Actions
- Jenkins
-
Deployment Server:
- Azure VM
-
Code Quality Assurance tool:
- SonarQube
-
Infrastructure-as-code:
- Terraform
- Java (version 17)
- Maven (version 3.8+)
- Node.js (version 20.x)
- npm or yarn
- MySQL
- Docker
- Clone the repository:
git clone https://github.com/your-repo/devops-expenditrack.git cd devops-expenditrack/backend
- Build the backend:
mvn clean install
- Run the backend server:
mvn spring-boot:run
- Clone the repository:
git clone https://github.com/your-repo/devops-expenditrack.git cd devops-expenditrack/frontend
- Install dependencies:
npm install
- Run the frontend server:
npm start
- Set up MySQL:
- Create a database named
Expendi
. - Set up environment variables for MySQL:
export MYSQL_DATABASE=Expendi export MYSQL_USER=sa export MYSQL_PASSWORD=password export MYSQL_ROOT_PASSWORD=password
- Run the SQL scripts located in
db/scripts
to initialize the schema and data.
- Create a database named
- Build and run Docker containers:
docker-compose up --build
The CI/CD pipeline for ExpenseTracker ensures continuous integration and deployment through a series of automated steps:
-
Triggering the Pipeline:
- The pipeline is triggered on pull requests targeting the
main
andAnalytics
branches.
- The pipeline is triggered on pull requests targeting the
-
Backend Testing:
- Uses GitHub Actions to set up JDK 17, build the backend using Maven, and run backend tests.
-
Frontend Testing:
- Uses GitHub Actions to set up Node.js, install dependencies, build the frontend, and run frontend tests.
-
Selenium End-to-End Testing:
- Uses Docker Compose to start necessary services (database, backend, frontend) and runs Selenium tests to verify end-to-end functionality.
- Logs are monitored for test completion, and services are cleaned up after tests.
-
Continuous Deployment:
- Jenkins is configured to handle continuous deployment, integrating with Terraform for infrastructure provisioning and SonarQube for code quality analysis.
The main
branch serves as the primary branch containing the basic version of the application. It includes the following features:
- Basic application setup
- Initial GitHub workflow for Selenium tests
- Initial commit and basic configuration files
- Docker-compose setup for deployment
- Exceptions tests and other fundamental features
The analytics
branch focuses on adding analytics and charts to the application. Features include:
- Integration of analytics tools and libraries
- Development of dashboards and charts for data visualization
- Enhancements to support backend data analysis and reporting
- UI/UX improvements for displaying analytical data
The jenkins
branch includes the following features:
- Jenkins pipeline setup for continuous integration and deployment
- Adding Jenkins configuration files and scripts
- Integration with backend, frontend, database, and Selenium branches
- Deployment and testing automation using Jenkins
The sonarqube
branch focuses on integrating SonarQube for code quality analysis. Features include:
- SonarQube analysis for backend and frontend code
- Dockerfile setup for SonarQube integration
- Jenkins pipeline stages for SonarQube code analysis
- Automated code quality checks and reports
The terraform
branch is dedicated to deploying the application using Terraform. Key features include:
- Terraform scripts for infrastructure provisioning
- Jenkins pipeline integration for automated deployment using Terraform
- Environment-specific configurations for deploying different stages
- Enhancements to support backend, frontend, and database deployments
To get started with the ExpenseTracker project, follow the instructions in the respective branches' README files for setup and deployment details.
This project is licensed under the MIT License. See the LICENSE file for more details.