キャッスルが例外を食べているのを見ることができる唯一の理由は、セッションがプロパティとして注入されている場合です。これにより、キャッスルはそれをオプションと見なします。
これを修正した方法は次のとおりです...プロパティの値の設定に失敗したときに例外をスローするアクティベーターを作成しました。
public class StrictComponentActivator : DefaultComponentActivator
{
public StrictComponentActivator(ComponentModel model, IKernelInternal kernel,
ComponentInstanceDelegate onCreation,
ComponentInstanceDelegate onDestruction)
: base(model, kernel, onCreation, onDestruction) { }
protected override void SetUpProperties(object instance, CreationContext context)
{
instance = ProxyUtil.GetUnproxiedInstance(instance);
var resolver = Kernel.Resolver;
foreach(var property in Model.Properties)
{
var value = ObtainPropertyValue(context, property, resolver);
if(value != null)
{
var setMethod = property.Property.GetSetMethod();
try
{
setMethod.Invoke(instance, new[] { value });
}
catch(Exception ex)
{
throw new ComponentActivatorException(
string.Format(
"Error setting property {1}.{0} " +
"in component {2}. " +
"See inner exception for more information. " +
"If you don't want Windsor to set this property " +
"you can do it by either decorating it with " +
"DoNotWireAttribute or via registration API.",
property.Property.Name,
instance.GetType().Name,
Model.Name),
ex, Model);
}
}
}
}
private object ObtainPropertyValue(CreationContext context, PropertySet property, IDependencyResolver resolver)
{
if(property.Dependency.IsOptional == false ||
resolver.CanResolve(context, context.Handler, Model, property.Dependency))
{
try
{
return resolver.Resolve(context, context.Handler, Model, property.Dependency);
}
catch(Exception e)
{
if(property.Dependency.IsOptional == false)
{
throw;
}
Kernel.Logger.Warn(
string.Format("Exception when resolving optional dependency {0} on component {1}.",
property.Dependency, Model.Name), e);
}
}
return null;
}
}
そして、ほとんどのコンポーネントを次のように構成しました.Activator<StrictComponentActivator>()