All architectures evolve, they have to, every system changes over time due to internal factors (technology changes, new use cases) and external factors (the industry changes, new markets, …). It only makes sense to look at your architecture as something that evolves over time for various reasons.
Evolutionary architecture defines the concept of a fitness function to measure certain architectural characteristics over time. By collecting this data from fitness functions, one can see how architectural characteristics are affected as the architecture evolves over time. With this data to your disposal, you can observe if changes negatively or positively affected your architecture. This observability of your architecture allows you to react and adjust accordingly the development of your architecture in a way that desired characteristics are conserved.
Fitness functions overlap many existing verification mechanisms, depending on the way they are used (as metrics, monitors, unit test libraries, chaos engineering, and so on.).
More on architectural characteristics
Remember: Change is constant, so might as well accept that and plan for it
Fitness Function: Any mechanism that performs an objective integrity assessment of some architecture characteristic or combination of architecture characteristics.
One implements fitness functions to build protections around unexpected change in architecture characteristics. The separation between fitness functions and unit tests provide a good scoping guideline for architects. Fitness functions validate architecture characteristics, not domain criteria; unit tests are the opposite.
You can decided wether a fitness function or unit test is needed by asking the question:
Is any domain knowledge required to execute this test? If “yes”, then a unit/function/user acceptance test is appropriate; if “no”, then a fitness function is needed.
Fitness functions are ideally automated, although in some occasions, manual work might be required.
Automated fitness functions certainly qualify well be a part of your continuous integration pipeline. Manual fitness functions depend on the use case an scope, but probably at some integration or user acceptance phase. Do what makes most sense to you.
Todo…
Todo…
Todo…
Todo…
Todo…
…mention that by doing the right decoupling and layers within a component or overal architecture, it allows to change things over time with a limited blast radius (e.g. swap out the database).