This project provides a simple REST API for a library management system, developed using Spring Boot. The API allows for efficient management of books, authors, and copies, enabling operations such as adding, updating, deleting, and retrieving information.
- Full CRUD Functionality: Comprehensive Create, Read, Update, and Delete operations.
- Data Transfer Object (DTO) Pattern: Efficient data exchange between layers.
- PostgreSQL Database Integration: Robust and scalable data storage solution.
- Advanced Error Handling: Custom exceptions for specific scenarios and global error handling for consistent responses.
- Comprehensive Testing Suite: Integration tests using TestContainers and unit tests with Mockito and JUnit 5.
- API Documentation: Interactive API documentation using Swagger/OpenAPI.
- Best Practices Implementation: Adherence to software design principles and industry standards.
We appreciate your interest in contributing to Library Management System. Here's how you can get started:
- Find Issues or Create Your Own: Solve existing issues or create new ones in the repository's issues tab.
- Fork the Repository: Click the "Fork" button at the top of this repository to create a copy in your GitHub account.
- Clone Your Fork: Clone your fork to your local machine with:
git clone https://github.com/<your_github_username>/Library-Management-System.git
- Change the Working Directory:
cd Library-Management-System
- Add an Upstream Link to the Main Branch:
git remote add upstream https://github.com/<your_github_username>/Library-Management-System.git
- Keep Your Fork Updated:
git pull upstream main
- Create a New Branch:
git checkout -b <branch-name>
- Make Changes: Implement your desired feature or fix a bug.
- Track and Stage Your Changes:
git status git add .
- Commit Your Changes:
git commit -m "<your-commit-message>"
- Push the Changes for Review:
git push origin <branch-name>
- Open a Pull Request: Create a pull request from your fork to this repository. Provide a concise title and description.
We'll review your contribution and collaborate to merge it into the project. Please adhere to our code of conduct and guidelines. If you have questions or need assistance, feel free to open an issue.
- Running PostgreSQL for Integration Testing with Docker Desktop: Download Docker Desktop from the official website: Docker Desktop
- Configure the Application Properties:
Update the following properties in your application configuration file:
spring.datasource.url=jdbc:postgresql://<HOST>:<PORT>/<DATABASE_NAME> spring.datasource.username=<USERNAME> spring.datasource.password=<PASSWORD>
- Start The Application:
./mvnw spring-boot:run
- Start The Application:
./mvnw spring-boot:run
- Access API Documentation: Open your web browser and navigate to: Swagger UI