Skip to content

Commit

Permalink
Merge pull request #1205 from alistairjevans/develop
Browse files Browse the repository at this point in the history
Capture prop injection instance when the middleware runs
  • Loading branch information
tillig authored Sep 28, 2020
2 parents 0aa6e7a + 6cd646c commit 39696a9
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -584,11 +584,13 @@ public IRegistrationBuilder<TLimit, TActivatorData, TRegistrationStyle> Properti

if (allowCircularDependencies)
{
var capturedInstance = ctxt.Instance;

// If we are allowing circular deps, then we need to run when all requests have completed (similar to Activated).
ctxt.RequestCompleting += (o, args) =>
{
var evCtxt = args.RequestContext;
AutowiringPropertyInjector.InjectProperties(evCtxt, evCtxt.Instance!, propertySelector, evCtxt.Parameters);
AutowiringPropertyInjector.InjectProperties(evCtxt, capturedInstance!, propertySelector, evCtxt.Parameters);
};
}
else
Expand Down
49 changes: 49 additions & 0 deletions test/Autofac.Specification.Test/Features/PropertyInjectionTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -373,6 +373,22 @@ public void SetterInjectionPrivateGet()
Assert.False(instance.GetterCalled);
}

[Fact]
public void DecoratedInstanceWithPropertyInjectionAllowingCircularReferencesStillInjects()
{
var val = "Value";

var builder = new ContainerBuilder();
builder.RegisterInstance(val);
builder.RegisterType<DecoratedService>().As<IMyService>().PropertiesAutowired(PropertyWiringOptions.AllowCircularDependencies);
builder.RegisterDecorator<ServiceDecorator, IMyService>();

var container = builder.Build();
var instance = container.Resolve<IMyService>();

instance.AssertProp();
}

private class ConstructorParamNotAttachedToProperty
{
[SuppressMessage("SA1401", "SA1401")]
Expand Down Expand Up @@ -411,5 +427,38 @@ private get
}
}
}

private interface IMyService
{
void AssertProp();
}

private sealed class DecoratedService : IMyService
{
public string Prop { get; set; }

public void AssertProp()
{
if (Prop is null)
{
throw new NullReferenceException();
}
}
}

private sealed class ServiceDecorator : IMyService
{
private readonly IMyService _decorating;

public ServiceDecorator(IMyService decorating)
{
_decorating = decorating;
}

public void AssertProp()
{
_decorating.AssertProp();
}
}
}
}

0 comments on commit 39696a9

Please sign in to comment.