Fitness Test using Net Arch Test in ASP.NET WEB API
Web API
20 Articles
Table of Contents
What we gonna do?
In the realm of software development, maintaining a robust and consistent architecture is paramount. As projects expand, ensuring that the structural integrity of the codebase remains intact becomes increasingly challenging. Even as of writing this I joined a project which was started six months ago with Clean Architecture in mind, but now it's follows a name sake Clean Architecture and the architecture is already eroding. The codebase is riddled with inconsistencies, and the architecture is far from the initial vision. This is because of pressure and deadline and on the other hand new developers joining the team without knowledge of clean architecture. This is a common problem in software development.
This is where fitness test or fitness functions come into play, serving as vigilant gatekeepers, preserving the essence of your software blueprint. In this blog post, we will delve deep into NetArchTest, a powerful tool designed to validate your software's architectural design, exploring its significance, implementation, advantages, and more.
NetArchTest is a sophisticated library that empowers developers to write fitness tests effortlessly. By leveraging NetArchTest, developers can enforce architectural rules and validate design decisions. The library scans the imported namespaces of your types, allowing you to define both positive and negative conditions for your architecture. Whether you're aiming to enforce dependencies between layers, validate design rules, or maintain design integrity, NetArchTest provides a simple and effective mechanism to achieve these goals.
Why we gonna do?
Before we explore the intricacies of NetArchTest, it's crucial to understand the 'why' behind its adoption. NetArchTest project allows you create tests that enforce conventions for class design, naming and dependency in .Net code bases. These can be used with any unit test framework and incorporated into a build pipeline. It uses a fluid API that allows you to string together readable rules that can be used in test assertions.
There are plenty of static analysis tools that can evaluate application structure, but they are aimed more at enforcing generic best practice rather than application-specific conventions. The better tools in this space can be press-ganged into creating custom rules for a specific architecture, but the intention here is to incorporate rules into a test suite and create a self-testing architecture.
Software architecture, akin to a well-thought-out blueprint, is essential for a robust system. However, as deadlines loom and pressure mounts, corners might be cut, leading to architectural erosion. NetArchTest acts as a safeguard, ensuring that your architecture doesn't crumble under the weight of compromises. By automating the verification process, it guarantees that your software adheres to the predefined architectural patterns and rules, even amidst rapid development cycles.
The advantages of Architecture tests are as follows,
- Maintain Design Integrity: NetArchTest acts as a guardian, preserving the consistent design and structure of your software as it evolves over time. It prevents architectural drift, ensuring that your initial vision remains intact.
- Early Issue Detection: By catching architectural discrepancies early in the development process, NetArchTest prevents potential complications that might arise due to structural flaws. Early detection translates to easier debugging and resolution.
- Improved Collaboration: Clear architectural rules and automated tests make it easier for developers to comprehend the system's design. This shared understanding fosters smoother collaboration, particularly in large teams or when onboarding new members.
- Quality Assurance: A robust architecture is the cornerstone of high-quality software. NetArchTest contributes significantly to the overall quality and reliability of your software by validating structural decisions and enforcing design rules.
How we gonna do?
Implementing NetArchTest in your project is seamless. Start by creating a new test project within your development environment. Then, install the NetArchTest.Rules NuGet package, which equips you with the necessary boilerplate code to initiate your tests. The library's core revolves around the Types class, enabling you to load and filter types based on various criteria. Once your types are selected, you can define rules using Should or ShouldNot conditions, ensuring that your architecture aligns with your predefined specifications. Here are some of the conventions I prefer to implement in my projects.
Note: If you have not done so already, I recommend you read the article on Request Endpoint Response (REPR) pattern in ASP.NET WEB API.
Code Sample - Fitness Test to Enforce REPR Pattern in Endpoints
Code Sample - Fitness Test to Enforce Clean Architecture
Code Sample - Fitness Test to Enforce rules for Commands and Queries
Code Sample - Fitness Test to Enforce Encapsulation in Domain Entities
The above code snippets demonstrate how you can enforce architectural rules using NetArchTest. By defining rules that align with your architectural vision, you can ensure that your software remains consistent and resilient. Whether you're enforcing the REPR pattern in your endpoints, validating Clean Architecture principles, or enforcing encapsulation in domain entities, NetArchTest provides a robust mechanism to safeguard your architectural integrity.
But sometimes it will be difficult to debug these test to understand which class is making the violations. To identify them easily you can use the below policy extension to report and write failures to Test Output Logs.
Code Sample - Policy Extension to report and write failures to Test Output Logs
Here are some design rules that you can enforce:
- Domain entities must be encapsulated
- Services must be internal
- Entities and Value objects must be sealed
- Controllers can't depend on repositories directly
- Command (or query) handlers must follow a naming convention
- Following naming conventions for classes