Single Responsibility Principle
Last updated
Last updated
Robert C. Martin's Definition: There should never be more than one reason for a class to change.
Wikipedia's Definition: Every module, class, or function should have responsibility for a single part of the functionality provided by the software, and that responsibility should be entirely encapsulated by the class.
Requirements changes typically map to responsibilities
More responsibilities in a class == The class is more likely to have changes
Having multiple responsibilities within a single class means that these responsibilities are coupled
Now let's see the problems introduced in this example:
The Validation logic for the salary was put inside the Employee class, so if there's a change to this validation logic the employee must be changed.
The business logic for tax calculation is also in the Employee class, so it will be very complex to put more than one tax calculation strategy or even change it as it's coupled with the Employee class.
Now the testing for Employee Unit will force you to test all of the three units together due to their coupling (The Employee itself, the Validation Logic, and the Tax Calculation logic).
Now every piece of logic is decoupled, and the dependencies are explicit, the TaxCalculator and the Validator can now be treated as strategies that can be changed at anytime, they can even be automatically injected in the constructor or put to default values for simplicity.
As for the unit testing of those 3 modules, we can now test each unit separately to be sure which of them fails or succeeds.