StructureMap in ASP.NET Core doesn't handle primitives as expected
I have this demo I use for demonstrating the various DI lifecycles in ASP.NET Core. It looks like this:
public interface IOperation
Guid OperationId get;
public interface IOperationTransient : IOperation
public interface IOperationScoped : IOperation
public interface IOperationSingleton : IOperation
public interface IOperationInstance : IOperation
public class Operation : IOperationTransient, IOperationScoped,
IOperationSingleton, IOperationInstance
private Guid _guid;
public Operation(Guid? value = null)
_guid = value == null ? Guid.NewGuid() : value.Value;
public Guid OperationId => _guid;
The demo uses a Web API controller to show the difference between DI lifecycles:
[Route("api/[controller]")]
public class ValuesController : Controller
private readonly IOperationTransient _transientOperation;
private readonly IOperationTransient _transientOperation2;
private readonly IOperationScoped _scopedOperation;
private readonly IOperationScoped _scopedOperation2;
private readonly IOperationSingleton _singletonOperation;
private readonly IOperationInstance _instanceOperation;
public ValuesController(
IOperationTransient transientOperation, IOperationTransient transientOperation2,
IOperationScoped scopedOperation, IOperationScoped scopedOperation2,
IOperationSingleton singletonOperation, IOperationInstance instanceOperation)
_transientOperation = transientOperation;
_transientOperation2 = transientOperation2;
_scopedOperation = scopedOperation;
_scopedOperation2 = scopedOperation2;
_singletonOperation = singletonOperation;
_instanceOperation = instanceOperation;
[HttpGet]
public Dictionary<string, IOperation> Get() =>
new Dictionary<string, IOperation>
"Transient", _transientOperation ,
"Transient2", _transientOperation2 ,
"Scoped", _scopedOperation ,
"Scoped2", _scopedOperation2 ,
"Singleton", _singletonOperation ,
"Instance", _instanceOperation
;
Using ASP.NET Core's built-in DI framework I wire the dependencies up like this:
services.AddTransient<IOperationTransient, Operation>();
services.AddScoped<IOperationScoped, Operation>();
services.AddSingleton<IOperationSingleton, Operation>();
services.AddSingleton<IOperationInstance>(new Operation(Guid.Empty));
This displays JSON that shows a different GUID for each of the two transient implementations on every refresh, the same value for each of the two scoped implementations which changes on refresh, the same value for the singleton which doesn't change on refresh, and always an empty Guid for the instance registration.
I wanted to show the same demo using StructureMap's ASP.NET Core implementation described here.
Initially I registered my dependencies with StructureMap like this:
registry.For<IOperationTransient>().Use<Operation>().AlwaysUnique();
registry.For<IOperationScoped>().Use<Operation>().ContainerScoped();
registry.For<IOperationSingleton>().Use<Operation>().Singleton();
registry.For<IOperationInstance>().Use(new Operation(Guid.Empty));
But now when I run the app I see the following server exception:
ArgumentException: Byte array for GUID must be exactly 16 bytes long.
Parameter name: bSystem.Guid..ctor(Byte b)
lambda_method(Closure , IBuildSession , IContext )
StructureMapBuildException: Error while building type System.Guid
I tried switching from using a Guid?
to a string
for my OperationId
property and ran it again. This time I get the following exception:
StructureMapBuildPlanException: Unable to create a build plan for
concrete type BuiltinDIDemo.Operation
new Operation(String value) ┗ String value = Required primitive
dependency is not explicitly defined
1.) Attempting to create a BuildPlan for Instance of BuiltinDIDemo.IOperationTransient -- BuiltinDIDemo.Operation
2.) Container.GetInstance(BuiltinDIDemo.IOperationTransient)
3.) Container.TryGetInstance(BuiltinDIDemo.IOperationTransient)StructureMap.Pipeline.ConstructorInstance.ToBuilder(Type pluginType, Policies policies)
So how can I get StructureMap to handle Nullable<Guid>
's and primitives using defaults?
c# asp.net-core dependency-injection structuremap
|
show 1 more comment
I have this demo I use for demonstrating the various DI lifecycles in ASP.NET Core. It looks like this:
public interface IOperation
Guid OperationId get;
public interface IOperationTransient : IOperation
public interface IOperationScoped : IOperation
public interface IOperationSingleton : IOperation
public interface IOperationInstance : IOperation
public class Operation : IOperationTransient, IOperationScoped,
IOperationSingleton, IOperationInstance
private Guid _guid;
public Operation(Guid? value = null)
_guid = value == null ? Guid.NewGuid() : value.Value;
public Guid OperationId => _guid;
The demo uses a Web API controller to show the difference between DI lifecycles:
[Route("api/[controller]")]
public class ValuesController : Controller
private readonly IOperationTransient _transientOperation;
private readonly IOperationTransient _transientOperation2;
private readonly IOperationScoped _scopedOperation;
private readonly IOperationScoped _scopedOperation2;
private readonly IOperationSingleton _singletonOperation;
private readonly IOperationInstance _instanceOperation;
public ValuesController(
IOperationTransient transientOperation, IOperationTransient transientOperation2,
IOperationScoped scopedOperation, IOperationScoped scopedOperation2,
IOperationSingleton singletonOperation, IOperationInstance instanceOperation)
_transientOperation = transientOperation;
_transientOperation2 = transientOperation2;
_scopedOperation = scopedOperation;
_scopedOperation2 = scopedOperation2;
_singletonOperation = singletonOperation;
_instanceOperation = instanceOperation;
[HttpGet]
public Dictionary<string, IOperation> Get() =>
new Dictionary<string, IOperation>
"Transient", _transientOperation ,
"Transient2", _transientOperation2 ,
"Scoped", _scopedOperation ,
"Scoped2", _scopedOperation2 ,
"Singleton", _singletonOperation ,
"Instance", _instanceOperation
;
Using ASP.NET Core's built-in DI framework I wire the dependencies up like this:
services.AddTransient<IOperationTransient, Operation>();
services.AddScoped<IOperationScoped, Operation>();
services.AddSingleton<IOperationSingleton, Operation>();
services.AddSingleton<IOperationInstance>(new Operation(Guid.Empty));
This displays JSON that shows a different GUID for each of the two transient implementations on every refresh, the same value for each of the two scoped implementations which changes on refresh, the same value for the singleton which doesn't change on refresh, and always an empty Guid for the instance registration.
I wanted to show the same demo using StructureMap's ASP.NET Core implementation described here.
Initially I registered my dependencies with StructureMap like this:
registry.For<IOperationTransient>().Use<Operation>().AlwaysUnique();
registry.For<IOperationScoped>().Use<Operation>().ContainerScoped();
registry.For<IOperationSingleton>().Use<Operation>().Singleton();
registry.For<IOperationInstance>().Use(new Operation(Guid.Empty));
But now when I run the app I see the following server exception:
ArgumentException: Byte array for GUID must be exactly 16 bytes long.
Parameter name: bSystem.Guid..ctor(Byte b)
lambda_method(Closure , IBuildSession , IContext )
StructureMapBuildException: Error while building type System.Guid
I tried switching from using a Guid?
to a string
for my OperationId
property and ran it again. This time I get the following exception:
StructureMapBuildPlanException: Unable to create a build plan for
concrete type BuiltinDIDemo.Operation
new Operation(String value) ┗ String value = Required primitive
dependency is not explicitly defined
1.) Attempting to create a BuildPlan for Instance of BuiltinDIDemo.IOperationTransient -- BuiltinDIDemo.Operation
2.) Container.GetInstance(BuiltinDIDemo.IOperationTransient)
3.) Container.TryGetInstance(BuiltinDIDemo.IOperationTransient)StructureMap.Pipeline.ConstructorInstance.ToBuilder(Type pluginType, Policies policies)
So how can I get StructureMap to handle Nullable<Guid>
's and primitives using defaults?
c# asp.net-core dependency-injection structuremap
StructureMap can't inject aGuid?
. For your demo, changeOperation
to have a default constructor and simply always create a new Guid, as follows:public Operation() => _guid = Guid.NewGuid();
– Steven
Nov 13 '18 at 15:51
Thanks, yes this is what I did to get the demo working, but I'm very curious to understand why StructureMap doesn't handle these types.
– getsetcode
Nov 14 '18 at 10:27
1
Well, I can't speak for StructureMap, but I can speak for Simple Injector, which contains behaves the same in this respect. With Simple Injector we explicitly decided not to allow null to be injected, because constructor dependencies should not be optional. And in this case we're talking about a (nullable) primitive. Primitives can typically not be injected automatically by your container using auto-wiring, as their type is ambigious. Example: what is the exact meaning of thatGuid
? Is it a customer id? Product id? It can be anything. It's better to be explicit, which is why SI blocks this
– Steven
Nov 14 '18 at 11:09
I expect the philosophy to be similar with StructureMap.
– Steven
Nov 14 '18 at 11:09
1
It’s hard to comment on the incentive of that particular feature, but I’ve experienced two driving forces (or design philosophies) that to have influenced the built-in container’s design the most, which are: 1) It’s designed first and foremost for the ASP.NET framework itself and third-party components, instead of targeting application developers first. 2) It tries to mimic the API of the Autofac DI Container.
– Steven
Nov 14 '18 at 15:25
|
show 1 more comment
I have this demo I use for demonstrating the various DI lifecycles in ASP.NET Core. It looks like this:
public interface IOperation
Guid OperationId get;
public interface IOperationTransient : IOperation
public interface IOperationScoped : IOperation
public interface IOperationSingleton : IOperation
public interface IOperationInstance : IOperation
public class Operation : IOperationTransient, IOperationScoped,
IOperationSingleton, IOperationInstance
private Guid _guid;
public Operation(Guid? value = null)
_guid = value == null ? Guid.NewGuid() : value.Value;
public Guid OperationId => _guid;
The demo uses a Web API controller to show the difference between DI lifecycles:
[Route("api/[controller]")]
public class ValuesController : Controller
private readonly IOperationTransient _transientOperation;
private readonly IOperationTransient _transientOperation2;
private readonly IOperationScoped _scopedOperation;
private readonly IOperationScoped _scopedOperation2;
private readonly IOperationSingleton _singletonOperation;
private readonly IOperationInstance _instanceOperation;
public ValuesController(
IOperationTransient transientOperation, IOperationTransient transientOperation2,
IOperationScoped scopedOperation, IOperationScoped scopedOperation2,
IOperationSingleton singletonOperation, IOperationInstance instanceOperation)
_transientOperation = transientOperation;
_transientOperation2 = transientOperation2;
_scopedOperation = scopedOperation;
_scopedOperation2 = scopedOperation2;
_singletonOperation = singletonOperation;
_instanceOperation = instanceOperation;
[HttpGet]
public Dictionary<string, IOperation> Get() =>
new Dictionary<string, IOperation>
"Transient", _transientOperation ,
"Transient2", _transientOperation2 ,
"Scoped", _scopedOperation ,
"Scoped2", _scopedOperation2 ,
"Singleton", _singletonOperation ,
"Instance", _instanceOperation
;
Using ASP.NET Core's built-in DI framework I wire the dependencies up like this:
services.AddTransient<IOperationTransient, Operation>();
services.AddScoped<IOperationScoped, Operation>();
services.AddSingleton<IOperationSingleton, Operation>();
services.AddSingleton<IOperationInstance>(new Operation(Guid.Empty));
This displays JSON that shows a different GUID for each of the two transient implementations on every refresh, the same value for each of the two scoped implementations which changes on refresh, the same value for the singleton which doesn't change on refresh, and always an empty Guid for the instance registration.
I wanted to show the same demo using StructureMap's ASP.NET Core implementation described here.
Initially I registered my dependencies with StructureMap like this:
registry.For<IOperationTransient>().Use<Operation>().AlwaysUnique();
registry.For<IOperationScoped>().Use<Operation>().ContainerScoped();
registry.For<IOperationSingleton>().Use<Operation>().Singleton();
registry.For<IOperationInstance>().Use(new Operation(Guid.Empty));
But now when I run the app I see the following server exception:
ArgumentException: Byte array for GUID must be exactly 16 bytes long.
Parameter name: bSystem.Guid..ctor(Byte b)
lambda_method(Closure , IBuildSession , IContext )
StructureMapBuildException: Error while building type System.Guid
I tried switching from using a Guid?
to a string
for my OperationId
property and ran it again. This time I get the following exception:
StructureMapBuildPlanException: Unable to create a build plan for
concrete type BuiltinDIDemo.Operation
new Operation(String value) ┗ String value = Required primitive
dependency is not explicitly defined
1.) Attempting to create a BuildPlan for Instance of BuiltinDIDemo.IOperationTransient -- BuiltinDIDemo.Operation
2.) Container.GetInstance(BuiltinDIDemo.IOperationTransient)
3.) Container.TryGetInstance(BuiltinDIDemo.IOperationTransient)StructureMap.Pipeline.ConstructorInstance.ToBuilder(Type pluginType, Policies policies)
So how can I get StructureMap to handle Nullable<Guid>
's and primitives using defaults?
c# asp.net-core dependency-injection structuremap
I have this demo I use for demonstrating the various DI lifecycles in ASP.NET Core. It looks like this:
public interface IOperation
Guid OperationId get;
public interface IOperationTransient : IOperation
public interface IOperationScoped : IOperation
public interface IOperationSingleton : IOperation
public interface IOperationInstance : IOperation
public class Operation : IOperationTransient, IOperationScoped,
IOperationSingleton, IOperationInstance
private Guid _guid;
public Operation(Guid? value = null)
_guid = value == null ? Guid.NewGuid() : value.Value;
public Guid OperationId => _guid;
The demo uses a Web API controller to show the difference between DI lifecycles:
[Route("api/[controller]")]
public class ValuesController : Controller
private readonly IOperationTransient _transientOperation;
private readonly IOperationTransient _transientOperation2;
private readonly IOperationScoped _scopedOperation;
private readonly IOperationScoped _scopedOperation2;
private readonly IOperationSingleton _singletonOperation;
private readonly IOperationInstance _instanceOperation;
public ValuesController(
IOperationTransient transientOperation, IOperationTransient transientOperation2,
IOperationScoped scopedOperation, IOperationScoped scopedOperation2,
IOperationSingleton singletonOperation, IOperationInstance instanceOperation)
_transientOperation = transientOperation;
_transientOperation2 = transientOperation2;
_scopedOperation = scopedOperation;
_scopedOperation2 = scopedOperation2;
_singletonOperation = singletonOperation;
_instanceOperation = instanceOperation;
[HttpGet]
public Dictionary<string, IOperation> Get() =>
new Dictionary<string, IOperation>
"Transient", _transientOperation ,
"Transient2", _transientOperation2 ,
"Scoped", _scopedOperation ,
"Scoped2", _scopedOperation2 ,
"Singleton", _singletonOperation ,
"Instance", _instanceOperation
;
Using ASP.NET Core's built-in DI framework I wire the dependencies up like this:
services.AddTransient<IOperationTransient, Operation>();
services.AddScoped<IOperationScoped, Operation>();
services.AddSingleton<IOperationSingleton, Operation>();
services.AddSingleton<IOperationInstance>(new Operation(Guid.Empty));
This displays JSON that shows a different GUID for each of the two transient implementations on every refresh, the same value for each of the two scoped implementations which changes on refresh, the same value for the singleton which doesn't change on refresh, and always an empty Guid for the instance registration.
I wanted to show the same demo using StructureMap's ASP.NET Core implementation described here.
Initially I registered my dependencies with StructureMap like this:
registry.For<IOperationTransient>().Use<Operation>().AlwaysUnique();
registry.For<IOperationScoped>().Use<Operation>().ContainerScoped();
registry.For<IOperationSingleton>().Use<Operation>().Singleton();
registry.For<IOperationInstance>().Use(new Operation(Guid.Empty));
But now when I run the app I see the following server exception:
ArgumentException: Byte array for GUID must be exactly 16 bytes long.
Parameter name: bSystem.Guid..ctor(Byte b)
lambda_method(Closure , IBuildSession , IContext )
StructureMapBuildException: Error while building type System.Guid
I tried switching from using a Guid?
to a string
for my OperationId
property and ran it again. This time I get the following exception:
StructureMapBuildPlanException: Unable to create a build plan for
concrete type BuiltinDIDemo.Operation
new Operation(String value) ┗ String value = Required primitive
dependency is not explicitly defined
1.) Attempting to create a BuildPlan for Instance of BuiltinDIDemo.IOperationTransient -- BuiltinDIDemo.Operation
2.) Container.GetInstance(BuiltinDIDemo.IOperationTransient)
3.) Container.TryGetInstance(BuiltinDIDemo.IOperationTransient)StructureMap.Pipeline.ConstructorInstance.ToBuilder(Type pluginType, Policies policies)
So how can I get StructureMap to handle Nullable<Guid>
's and primitives using defaults?
c# asp.net-core dependency-injection structuremap
c# asp.net-core dependency-injection structuremap
edited Nov 13 '18 at 15:48
Steven
127k17216334
127k17216334
asked Nov 13 '18 at 14:20
getsetcodegetsetcode
1,68011434
1,68011434
StructureMap can't inject aGuid?
. For your demo, changeOperation
to have a default constructor and simply always create a new Guid, as follows:public Operation() => _guid = Guid.NewGuid();
– Steven
Nov 13 '18 at 15:51
Thanks, yes this is what I did to get the demo working, but I'm very curious to understand why StructureMap doesn't handle these types.
– getsetcode
Nov 14 '18 at 10:27
1
Well, I can't speak for StructureMap, but I can speak for Simple Injector, which contains behaves the same in this respect. With Simple Injector we explicitly decided not to allow null to be injected, because constructor dependencies should not be optional. And in this case we're talking about a (nullable) primitive. Primitives can typically not be injected automatically by your container using auto-wiring, as their type is ambigious. Example: what is the exact meaning of thatGuid
? Is it a customer id? Product id? It can be anything. It's better to be explicit, which is why SI blocks this
– Steven
Nov 14 '18 at 11:09
I expect the philosophy to be similar with StructureMap.
– Steven
Nov 14 '18 at 11:09
1
It’s hard to comment on the incentive of that particular feature, but I’ve experienced two driving forces (or design philosophies) that to have influenced the built-in container’s design the most, which are: 1) It’s designed first and foremost for the ASP.NET framework itself and third-party components, instead of targeting application developers first. 2) It tries to mimic the API of the Autofac DI Container.
– Steven
Nov 14 '18 at 15:25
|
show 1 more comment
StructureMap can't inject aGuid?
. For your demo, changeOperation
to have a default constructor and simply always create a new Guid, as follows:public Operation() => _guid = Guid.NewGuid();
– Steven
Nov 13 '18 at 15:51
Thanks, yes this is what I did to get the demo working, but I'm very curious to understand why StructureMap doesn't handle these types.
– getsetcode
Nov 14 '18 at 10:27
1
Well, I can't speak for StructureMap, but I can speak for Simple Injector, which contains behaves the same in this respect. With Simple Injector we explicitly decided not to allow null to be injected, because constructor dependencies should not be optional. And in this case we're talking about a (nullable) primitive. Primitives can typically not be injected automatically by your container using auto-wiring, as their type is ambigious. Example: what is the exact meaning of thatGuid
? Is it a customer id? Product id? It can be anything. It's better to be explicit, which is why SI blocks this
– Steven
Nov 14 '18 at 11:09
I expect the philosophy to be similar with StructureMap.
– Steven
Nov 14 '18 at 11:09
1
It’s hard to comment on the incentive of that particular feature, but I’ve experienced two driving forces (or design philosophies) that to have influenced the built-in container’s design the most, which are: 1) It’s designed first and foremost for the ASP.NET framework itself and third-party components, instead of targeting application developers first. 2) It tries to mimic the API of the Autofac DI Container.
– Steven
Nov 14 '18 at 15:25
StructureMap can't inject a
Guid?
. For your demo, change Operation
to have a default constructor and simply always create a new Guid, as follows: public Operation() => _guid = Guid.NewGuid();
– Steven
Nov 13 '18 at 15:51
StructureMap can't inject a
Guid?
. For your demo, change Operation
to have a default constructor and simply always create a new Guid, as follows: public Operation() => _guid = Guid.NewGuid();
– Steven
Nov 13 '18 at 15:51
Thanks, yes this is what I did to get the demo working, but I'm very curious to understand why StructureMap doesn't handle these types.
– getsetcode
Nov 14 '18 at 10:27
Thanks, yes this is what I did to get the demo working, but I'm very curious to understand why StructureMap doesn't handle these types.
– getsetcode
Nov 14 '18 at 10:27
1
1
Well, I can't speak for StructureMap, but I can speak for Simple Injector, which contains behaves the same in this respect. With Simple Injector we explicitly decided not to allow null to be injected, because constructor dependencies should not be optional. And in this case we're talking about a (nullable) primitive. Primitives can typically not be injected automatically by your container using auto-wiring, as their type is ambigious. Example: what is the exact meaning of that
Guid
? Is it a customer id? Product id? It can be anything. It's better to be explicit, which is why SI blocks this– Steven
Nov 14 '18 at 11:09
Well, I can't speak for StructureMap, but I can speak for Simple Injector, which contains behaves the same in this respect. With Simple Injector we explicitly decided not to allow null to be injected, because constructor dependencies should not be optional. And in this case we're talking about a (nullable) primitive. Primitives can typically not be injected automatically by your container using auto-wiring, as their type is ambigious. Example: what is the exact meaning of that
Guid
? Is it a customer id? Product id? It can be anything. It's better to be explicit, which is why SI blocks this– Steven
Nov 14 '18 at 11:09
I expect the philosophy to be similar with StructureMap.
– Steven
Nov 14 '18 at 11:09
I expect the philosophy to be similar with StructureMap.
– Steven
Nov 14 '18 at 11:09
1
1
It’s hard to comment on the incentive of that particular feature, but I’ve experienced two driving forces (or design philosophies) that to have influenced the built-in container’s design the most, which are: 1) It’s designed first and foremost for the ASP.NET framework itself and third-party components, instead of targeting application developers first. 2) It tries to mimic the API of the Autofac DI Container.
– Steven
Nov 14 '18 at 15:25
It’s hard to comment on the incentive of that particular feature, but I’ve experienced two driving forces (or design philosophies) that to have influenced the built-in container’s design the most, which are: 1) It’s designed first and foremost for the ASP.NET framework itself and third-party components, instead of targeting application developers first. 2) It tries to mimic the API of the Autofac DI Container.
– Steven
Nov 14 '18 at 15:25
|
show 1 more comment
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53283094%2fstructuremap-in-asp-net-core-doesnt-handle-primitives-as-expected%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53283094%2fstructuremap-in-asp-net-core-doesnt-handle-primitives-as-expected%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
StructureMap can't inject a
Guid?
. For your demo, changeOperation
to have a default constructor and simply always create a new Guid, as follows:public Operation() => _guid = Guid.NewGuid();
– Steven
Nov 13 '18 at 15:51
Thanks, yes this is what I did to get the demo working, but I'm very curious to understand why StructureMap doesn't handle these types.
– getsetcode
Nov 14 '18 at 10:27
1
Well, I can't speak for StructureMap, but I can speak for Simple Injector, which contains behaves the same in this respect. With Simple Injector we explicitly decided not to allow null to be injected, because constructor dependencies should not be optional. And in this case we're talking about a (nullable) primitive. Primitives can typically not be injected automatically by your container using auto-wiring, as their type is ambigious. Example: what is the exact meaning of that
Guid
? Is it a customer id? Product id? It can be anything. It's better to be explicit, which is why SI blocks this– Steven
Nov 14 '18 at 11:09
I expect the philosophy to be similar with StructureMap.
– Steven
Nov 14 '18 at 11:09
1
It’s hard to comment on the incentive of that particular feature, but I’ve experienced two driving forces (or design philosophies) that to have influenced the built-in container’s design the most, which are: 1) It’s designed first and foremost for the ASP.NET framework itself and third-party components, instead of targeting application developers first. 2) It tries to mimic the API of the Autofac DI Container.
– Steven
Nov 14 '18 at 15:25