From 2722eedd80cbc243e32c5625bbf9bc9cf0a3874a Mon Sep 17 00:00:00 2001 From: Artem Zakirullin Date: Sat, 28 Sep 2024 07:35:40 +0300 Subject: [PATCH] add note about the law of implicit interfaces --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index a720fcf..f7f3f56 100644 --- a/README.md +++ b/README.md @@ -264,6 +264,8 @@ This architecture was something that made intuitive sense at first, but every ti > Do not add layers of abstractions for the sake of an architecture. Add them whenever you need an extension point that is justified for practical reasons. **[Layers of abstraction aren't free of charge](https://blog.jooq.org/why-you-should-not-implement-layered-architecture), they are to be held in our working memory**. +If you think that such architectures allow you to quickly swap out different databases or whatever other dependencies you have, you haven't touched the reality. Even upgrading the same database management system to a few major versions causes lots of issues, and believe us, having the right abstractions for the data access layer is the least of your worries. At best, abstractions can save somewhat 10% of your time (if any), the real pain is in [implicit interfaces](https://www.hyrumslaw.com/). So, why pay the price of high cognitive load for such abstractions, if it doesn't pay off in the future? Plus, in most cases that future of replacing some core component never happens. + Even though these layered architectures have accelerated an important shift from traditional database-centric applications to a somewhat infrastructure-independent approach, where the core business logic is independent of anything external, the idea is by no means novel. These architectures are not fundamental, they are just subjective, biased consequences of more fundamental principles. Why rely on those subjective interpretations? Follow the fundamental rules instead: dependency inversion principle, cognitive load and information hiding.