Changes for page Testable Design
Last modified by chrisby on 2024/09/19 10:50
Summary
-
Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -27,3 +27,12 @@ 27 27 ** Develop self-contained modules: Each module should be a self-contained unit of functionality. New features should be introduced by creating new modules. 28 28 * **Avoid the singleton design pattern** because its private constructor prevents mocking. Consider a getInstance() method that returns an interface type instead. 29 29 * **Favor composition over inheritance.** Use inheritance only for polymorphism, as it is less flexible than composition. Composition should be the primary approach to code reuse. 30 + 31 + 32 +=== Testable Architecture === 33 + 34 +An important part of a testable architecture is the **Humble Object Pattern**: 35 + 36 +* The pattern emphasizes the isolation of complex to test aspects (such as GUI interactions), keeping them 'humble' with minimal logic. 37 +* **Minimize complex layers**: Keep complex layers such as GUIs and adapters as thin as possible, focusing mainly on interaction and routing. 38 +* **Maximize business logic**: Where possible, move logic to the business logic/service layer, which is easier to test, improving overall testability.