We often design our code so that one procedure comprises many classes, often grouped by layers. For example, in web dev, that could be controllers, models, repositories, etc:
data:image/s3,"s3://crabby-images/83bfc/83bfc0bf6b51004d322e01cb8a65f15e0a6645bb" alt=""
Layers are good. Often at least two layers are desirable for maintainability: domain and low-level. If you’re like me, you like 2-5 layers but not too many.
Now how do you test such code? It comes naturally to want to test each component separately and mock out the collaborators from other layers. I believe it’s because unit tests are said to be run “in isolation”:
data:image/s3,"s3://crabby-images/87736/87736a84b8e5d540def4b2c5e125198b1e44e331" alt=""
My advice – don’t automatically do this. Aim for this instead:
data:image/s3,"s3://crabby-images/57f53/57f534255190d9090a992916ef9a2fcbe8b5c99a" alt=""
Recent Comments