Skip to content
Advertisement

Resolving dependencies without a dependency injection container

I have a project in plain PHP and there is a class which is dependent on external library.

I don’t feel like passing it to constructor everywhere is a good idea (it’s called mainly in tests, but the users of the package will have to pass it to constructor).

I don’t have any DI containers and don’t think I should have because the project is a small package and will only have a few classes.

So I’ve come up with this approach and was wondering if there any consequences or drawbacks of this approach or if there any other solution to this?

JavaScript

Advertisement

Answer

I don’t see any major issue with that. Your class simply falls back to a default Client implementation if one isn’t injected into it, but since you’re not enforcing it, it retains the appropriate flexibility/testability.

I would however go a bit further and implement Dependency Inversion:

JavaScript

Change your Client class to implement it:

JavaScript

Then change the constructor to this:

JavaScript

This way your class doesn’t even depend on any implementation at all. It just happens to default to Client if it isn’t explicitly given one.

User contributions licensed under: CC BY-SA
6 People found this is helpful
Advertisement