mirror of
https://github.com/mbierlee/poodinis.git
synced 2024-11-15 04:04:01 +01:00
Throw exception when resolving non-registered type
This commit is contained in:
parent
27d86ce8c7
commit
423f21230a
|
@ -1,6 +1,7 @@
|
|||
module poodinis.container;
|
||||
|
||||
import std.string;
|
||||
import std.array;
|
||||
|
||||
struct Registration {
|
||||
TypeInfo registeredType = null;
|
||||
|
@ -17,6 +18,12 @@ class RegistrationException : Exception {
|
|||
}
|
||||
}
|
||||
|
||||
class ResolveException : Exception {
|
||||
this(string message, TypeInfo resolveType) {
|
||||
super(format("Exception while resolving type %s: %s", resolveType.toString(), message));
|
||||
}
|
||||
}
|
||||
|
||||
class Container {
|
||||
|
||||
private static Registration[TypeInfo] registrations;
|
||||
|
@ -44,12 +51,21 @@ class Container {
|
|||
private static void checkValidity(InterfaceType)(TypeInfo registeredType, TypeInfo_Class instanceType) {
|
||||
InterfaceType instanceCanBeCastToInterface = cast(InterfaceType) instanceType.create();
|
||||
if (!instanceCanBeCastToInterface) {
|
||||
string errorMessage = format("%s cannot be cast to %s", instanceType.name, registeredType.toString());
|
||||
string errorMessage = format("%s cannot be cast to %s.", instanceType.name, registeredType.toString());
|
||||
throw new RegistrationException(errorMessage, registeredType, instanceType);
|
||||
}
|
||||
}
|
||||
|
||||
public static ClassType resolve(ClassType)() {
|
||||
return cast(ClassType) registrations[typeid(ClassType)].getInstance();
|
||||
TypeInfo resolveType = typeid(ClassType);
|
||||
Registration* registration = resolveType in registrations;
|
||||
if (!registration) {
|
||||
throw new ResolveException("Type not registered.", resolveType);
|
||||
}
|
||||
return cast(ClassType) registration.getInstance();
|
||||
}
|
||||
|
||||
public static void clearRegistrations() {
|
||||
registrations.clear();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -14,12 +14,14 @@ version(unittest) {
|
|||
|
||||
unittest {
|
||||
// Test register concrete type
|
||||
Container.clearRegistrations();
|
||||
auto registration = Container.register!(TestClass)();
|
||||
assert(registration.registeredType == typeid(TestClass), "Type of registered type not the same");
|
||||
}
|
||||
|
||||
unittest {
|
||||
// Test resolve registered type
|
||||
Container.clearRegistrations();
|
||||
Container.register!(TestClass)();
|
||||
TestClass actualInstance = Container.resolve!(TestClass)();
|
||||
assert(actualInstance !is null, "Resolved type is null");
|
||||
|
@ -28,6 +30,7 @@ version(unittest) {
|
|||
|
||||
unittest {
|
||||
// Test register interface
|
||||
Container.clearRegistrations();
|
||||
Container.register!(TestInterface, TestClass)();
|
||||
TestInterface actualInstance = Container.resolve!(TestInterface)();
|
||||
assert(actualInstance !is null, "Resolved type is null");
|
||||
|
@ -36,12 +39,20 @@ version(unittest) {
|
|||
|
||||
unittest {
|
||||
// Test register unrelated types fails
|
||||
Container.clearRegistrations();
|
||||
assertThrown!RegistrationException(Container.register!(UnrelatedClass, TestClass)(), "Registering unrelated types does not fail");
|
||||
}
|
||||
|
||||
unittest {
|
||||
// Test register unrelated types with disabled check on registration
|
||||
Container.clearRegistrations();
|
||||
assertNotThrown!RegistrationException(Container.register!(UnrelatedClass, TestClass)(false), "Registering unrelated types while disabling type validity fails");
|
||||
}
|
||||
|
||||
unittest {
|
||||
// Test resolve non-registered type
|
||||
Container.clearRegistrations();
|
||||
assertThrown!ResolveException(Container.resolve!(TestClass)(), "Resolving non-registered type does not fail");
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in a new issue