Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dependency Injection docs #51

Open
webleaf opened this issue Mar 15, 2024 · 4 comments
Open

Dependency Injection docs #51

webleaf opened this issue Mar 15, 2024 · 4 comments

Comments

@webleaf
Copy link

webleaf commented Mar 15, 2024

I would like more documentation (with examples) on Dependency Injection. In what cases and how to use it correctly. Explanation of all Registry interface methods is required. For example, I don’t understand in what cases the requireAll() method is needed in practice. In what cases should you use create(), and in what cases register()? Why is optional() needed?
I also don’t understand the meaning of this test:

@Test fun `use existing instance even for arguments with default values`() {
class Subject(val nonDefault: BodyParser = TextBodyParser(), val default: FormUrlEncodedParser = FormUrlEncodedParser())
val registeredParser = TextBodyParser()
registry.register<BodyParser>(registeredParser)
expect(registry.require<Subject>()) {
its { nonDefault }.toBeTheInstance(registeredParser)
its { default }.notToBeTheInstance(registry.require())
}
}

In general, I need yet another small tutorial on DI. And more detailed documentation with real-life examples of your implementation.

angryziber added a commit that referenced this issue Apr 2, 2024
…not be used directly. Use `require<MyClass>()` instead.
@angryziber
Copy link
Member

@webleaf thanks for feedback, I've made some small improvements in the docs, however IMHO all methods of Registry should be quite obvious if you have used a different DI framework before. Basically, it allows you to register class instances and get them back using require.

Also, you can look at SimpleRegistry implementation to make it totally clear what exactly do they do - it's only a few lines of code. DependencyInjectingRegistry would also auto-create instances using constructor parameters, so that you don't need to register instances manually if there is only one implementation.

As you can see from requireAll() test, it's needed to get all implementations of a particular interface from the registry, it's used by Klite itself internally as is intended for plugin-like functionaility.

create() was a more internal method, I've marked it as protected to avoid confusion. require() is create + register and is what you need in most cases.

@angryziber
Copy link
Member

Regarding the use existing instance even for arguments with default values test: it does exactly what is written in the name: it provides registered instances to constructor arguments even if they have default values defined. I have changed the name a bit, but it is quite precise.

Does this answer your questions?

@webleaf
Copy link
Author

webleaf commented Apr 13, 2024

@angryziber thanks for answer.
It looks like I don't understand the purpose of a DI container at all.
I still hope to see a good explanation in the documentation for some DI implementation.
But I still can’t find an explanation why Constructor Injection is not enough? Apparently I haven’t had to write such a large project where this becomes insufficient.

Do I understand correctly that the DI container allows you to replace Constructor Injection by injecting a class directly into the body of a function and moving its configuration to a centralized storage (configuration file)?

@angryziber
Copy link
Member

The Registry's here implement constructor injection. Of course, you can call constructors manually and create all the objects in the system, but the base Registry here is still useful for holding of these created objects, so that others can access them without having to know the details on how are they created (with which exactly constructor parameters).

Registry is basically a generic holder of singletons in the app.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants