Skip to content

Latest commit

 

History

History
170 lines (118 loc) · 6.67 KB

README.md

File metadata and controls

170 lines (118 loc) · 6.67 KB

Mauro Gioberti

Appointments Microservice 🚀

A fun-to-use C# microservice built with .NET 8.
It’s all about testing, automation, and making developers’ lives easier.

⭐ Leave a star if you like it! 💰 Found a bug? Report it here!

Built with .NET and Testing Focus


🚀 What’s This About?

The Appointments Microservice is a testing playground disguised as a backend app. It’s built to show off Unit Testing, Functional Testing, and Automation. Sure, it uses Clean Architecture, but the star of the show is making sure everything is fully tested and automated for reliability.

Why Testing and Automation?

  • Unit Testing: Keeps your core logic solid, even when the code changes.
  • Functional Testing: Makes sure the app behaves how it should in the real world.
  • Automation: 🚀 This is where the fun begins! Verifies the integrity of the microservice implementation by hitting endpoints or interacting with bus services.

📂 How It’s Organized

This app keeps things clean, testable, and easy to automate:

/Microservice.Appointments.sln # Main solution
/Microservice.Appointments.IntegrityAssurance.sln # Testing solution
/src
├── Api               # Your API controllers, middlewares
├── Application       # Use cases, DTOs, and services
├── Domain            # Core business logic like entities and events
├── Infrastructure    # Database, repositories, and external integrations
/tests
├── FunctionalTests   # End-to-end tests for APIs
├── UnitTests         # Isolated tests for logic and services
└── IntegrationTests  # Tests that touch the database or external services

🚦 Get Started Quickly

  1. Clone this repo:

    git clone https://github.com/maurogioberti/microservice-appointments.git
    cd microservice-appointments
  2. Restore dependencies:

    dotnet restore
  3. Set up and run the solutions:

Main Solution:

  1. Open Microservice.Appointments.sln in Visual Studio or your preferred IDE.
  2. Set Microservice.Appointments.Api as the startup project.
  3. Ensure Docker is running to support the EventBus (RabbitMQ) and Database (SQL Server) containers.
  4. Run the project to host the API locally (by default on http://localhost:[port]).

IntegrityAssurance Solution:

  1. Open Microservice.Appointments.IntegrityAssurance.sln.
  2. Navigate to the Microservice.Appointments.IntegrationTests project.
  3. Ensure the Microservice.Appointments.Api is running in IntegrityAssurance mode.
  4. Execute the tests and validate the workflows.

🐳 Docker Containers

This project uses Docker to simplify the infrastructure setup. Make sure Docker is running, and the app will handle everything for you automatically.

Take a coffee ☕ and relax while the app spins up the containers. Here's what's included:

  1. EventBus (RabbitMQ): Handles asynchronous messaging for domain events like AppointmentCreatedEvent.
  2. Database (SQL Server): Stores appointment data and ensures persistence for the service.

Everything is pre-configured and ready to go. Just hit "Run" and start testing! 😎


🧪 Testing Is Everything

Consistency is key, and this project follows the Given_When_Then naming convention for tests to ensure maintainability.

Test Naming Pattern:

Given_[Condition]_When_[Action]_Then_[ExpectedOutcome]

  • Example: Given_Valid_Parameters_When_ExecuteAsync_Called_Then_Returns_Expected_Result.

🎩 Unit Testing

Unit tests keep things predictable:

  • Test the logic in your services, entities, domains, and use cases.

🔀 Functional Testing

Functional tests check the big picture:

  • Validate that API endpoints respond the way they’re supposed to.
  • Mock those infrastructure dependencies so tests don’t need a database.

🧬 Automation Is Your Best Friend

Automation makes life easier. Here’s what this microservice automates:

  • API Testing: Every endpoint gets tested, so you don’t miss a thing.

🖓 Why Testing and Automation Matter

  1. Saves Time: Automating tests means less debugging and more time for coding cool features. 😎
  2. Confidence in Changes: Know your updates won’t break the app. 😁
  3. Smooth Deployments: Automating checks makes the app stable and easy to scale. 🪜

🚌 Event Bus: Messaging Made Simple

This microservice uses RabbitMQ 🐇 to handle domain events asynchronously.

Where to manage it?
👉 Go to RabbitMQ Management UI and log in to see everything in action.

Queues you’ll find:

  • appointment.created 🟢: Triggered when a new appointment is created.
  • appointment.changed 🔄: Handles updates to appointments.
  • appointment.deleted ❌: Removes appointment data from the system.
  • appointment.notification 📩: Processes notifications and updates relevant data.

💡 The appointment.notification queue listens for incoming events and automatically updates appointments when it receives a notification.


🤖 Continuous Integration: Built for Reliability

This project features a lightweight CI pipeline to keep everything stable and running smoothly.

🛠️ Steps in the Pipeline:

  1. 🧪 Run Unit Tests: Ensures all core logic behaves as expected.
  2. 🔀 Run Functional Tests: Validates that endpoints and workflows are working correctly.

💡 With these automated steps, you can push with confidence knowing the app won’t break! 🤓


📓 License

This project is under the MIT License, so feel free to use it, share it, or break it—just don’t forget to give credit!


If you're a dev 👨‍💻 and you've never done something like this... 🤔 What are you waiting for? 💥 Improve your quality and get excited to dive in! 🚀