- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当 Fitnesse 实例化一个夹具时,它会寻找一个默认的公共(public)构造函数。
但是,我想在构造函数中注入(inject)我想在夹具中使用的任何应用程序服务。
即我想这样写我的装置......
public class MyColumnFixture : ColumnFixture {
private readonly IApplicationService _applicationService;
public ManualExitSetupFixture(IApplicationService applicationService) {
_applicationService = applicationService;
}
public void DoStuff(string arg1) {
_applicationService.DoStuff(arg1);
}
}
到目前为止,我想出的最好办法是将容器公开为单例(见下文)。 但必须有更好的方法。 Autofac 与我们使用的许多其他技术完美集成。
public class AutofacIntegration {
private static IContainer _container;
public static IContainer Container {
get {
if (_container == null) {
var builder = new ContainerBuilder();
builder.RegisterModule<MyApplicationModule>();
_container = builder.Build();
}
return _container;
}
}
}
public class MyColumnFixture : ColumnFixture {
private readonly IApplicationService _applicationService;
public ManualExitSetupFixture() {
_applicationService = AutofacIntegration.Container.Resolve<IApplicationService>();
}
public void DoStuff(string arg1) {
_applicationService.DoStuff(arg1);
}
}
编辑:包括我在 Mike 的协助下尝试完成这项工作的更多细节......
我创建了一个类,它是从 Fitsharp 反编译的 CreateDefault 反编译代码中复制粘贴的...
public class CreateDefault<T, P> : Operator<T, P>, CreateOperator<T> where P : class, Processor<T>
{
public bool CanCreate(NameMatcher memberName, Tree<T> parameters)
{
return true;
}
public TypedValue Create(NameMatcher memberName, Tree<T> parameters)
{
...
}
}
...并在 SuiteConfig.xml 中注册...
<suiteConfig>
<ApplicationUnderTest>
<AddAssembly>..\..\Services\Win\MyProj.Fitnesse\MyProj.Fitnesse\bin\Debug\MyProj.Fitnesse.dll</AddAssembly>
</ApplicationUnderTest>
<Fit.Operators>
<Add>MyProj.Fitnesse.CreateDefault`2</Add>
</Fit.Operators>
</suiteConfig>
...这会在尝试加载我的 CreateDefault<,> 类时出现以下异常。
System.Reflection.TargetInvocationException: Exception has been thrown by the target of an invocation. ---> System.Reflection.TargetInvocationException: Exception has been thrown by the target of an invocation. ---> fitSharp.Machine.Exception.CreateException: Constructor with 0 parameter(s) failed for type 'MyProj.Fitnesse.CreateDefault`2'. ---> System.ArgumentException: Cannot create an instance of MyProj.Fitnesse.CreateDefault`2[T,P] because Type.ContainsGenericParameters is true.
at System.RuntimeType.CreateInstanceCheckThis()
at System.RuntimeType.CreateInstanceImpl(BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes, StackCrawlMark& stackMark)
at System.Activator.CreateInstance(Type type, BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes)
at System.Reflection.Assembly.CreateInstance(String typeName, Boolean ignoreCase, BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes)
at fitSharp.Machine.Engine.RuntimeType.CreateInstance()
at fitSharp.Machine.Engine.CreateDefault`2.CreateWithoutParameters(RuntimeType runtimeType)
--- End of inner exception stack trace ---
at fitSharp.Machine.Engine.CreateDefault`2.CreateWithoutParameters(RuntimeType runtimeType)
at fitSharp.Machine.Engine.CreateDefault`2.Create(NameMatcher memberName, Tree`1 parameters)
--- End of inner exception stack trace ---
at System.RuntimeMethodHandle.InvokeMethod(Object target, Object[] arguments, Signature sig, Boolean constructor)
at System.Reflection.RuntimeMethodInfo.UnsafeInvokeInternal(Object obj, Object[] parameters, Object[] arguments)
at System.Reflection.RuntimeMethodInfo.Invoke(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture)
at System.RuntimeType.InvokeMember(String name, BindingFlags bindingFlags, Binder binder, Object target, Object[] providedArgs, ParameterModifier[] modifiers, CultureInfo culture, String[] namedParams)
at fitSharp.Machine.Engine.MethodMember.TryInvoke(Object[] parameters)
at fitSharp.Machine.Engine.ReflectionMember.Invoke(Object[] parameters)
at fitSharp.Machine.Engine.ProcessorBase`2.Operate[O](Object[] parameters)
at fitSharp.Machine.Engine.Operators`2.Add(String operatorName)
--- End of inner exception stack trace ---
at fitSharp.Machine.Engine.ProcessorExtension.InvokeWithThrow[T](Processor`1 processor, TypedValue instance, MemberName memberName, Tree`1 parameters)
at fitSharp.Machine.Application.SuiteConfiguration.LoadNode(String typeName, XmlNode methodNode)
at fitSharp.Machine.Application.SuiteConfiguration.LoadXml(String configurationXml)
at fitSharp.Machine.Application.ArgumentParser.InvokeArgumentHandler(String switch, String argumentValue)
at fitSharp.Machine.Application.ArgumentParser.Parse(IList`1 commandLineArguments)
at fitSharp.Machine.Application.Shell.Run(IList`1 commandLineArguments)
编辑:非常感谢迈克,这现在正在发挥作用。
实现真的很简单,我相信它可以改进,但这里有一个快速的操作方法......
我的 CreateOperator 代码...
public class AutofacCreateOperator : CellOperator, CreateOperator<Cell>
{
private static IContainer _container;
public AutofacCreateOperator()
{
var builder = new ContainerBuilder();
builder.RegisterModule<FitnesseModule>();
_container = builder.Build();
}
public bool CanCreate(NameMatcher memberName, Tree<Cell> parameters)
{
return _container.ComponentRegistry.IsRegistered(new TypedService(Type.GetType(memberName.MatchName)));
}
public TypedValue Create(NameMatcher memberName, Tree<Cell> parameters)
{
return new TypedValue(_container.Resolve(Type.GetType(memberName.MatchName)));
}
}
最佳答案
这可以做到——您需要编写一个自定义类来处理 fitSharp 的创建操作。它将实现这个接口(interface):
public interface CreateOperator<T> {
bool CanCreate(NameMatcher memberName, Tree<T> parameters);
TypedValue Create(NameMatcher memberName, Tree<T> parameters);
}
然后你告诉 fitSharp 在套件配置文件中使用这个类:
<suiteConfig>
<Fit.Operators>
<Add>My.Create.Operator</Add>
</Fit.Operators>
...
</suiteConfig>
作为陈述点,这里有一个非常简单的创建运算符。您将对其进行修改以进行 AutoFac 注入(inject)。
public class TestCreateOperator: CellOperator, CreateOperator<Cell> {
public bool CanCreate(NameMatcher memberName, Tree<Cell> parameters) {
return memberName.Matches("testname");
}
public TypedValue Create(NameMatcher memberName, Tree<Cell> parameters) {
return new TypedValue("mytestname");
}
}
仅供引用,这是创建夹具的内置类。
public class CreateDefault<T,P>: Operator<T, P>, CreateOperator<T> where P: class, Processor<T> {
public bool CanCreate(NameMatcher memberName, Tree<T> parameters) {
return true;
}
public TypedValue Create(NameMatcher memberName, Tree<T> parameters) {
var runtimeType = Processor.ApplicationUnderTest.FindType(memberName);
return parameters.Branches.Count == 0
? CreateWithoutParameters(runtimeType)
: CreateWithParameters(parameters, runtimeType);
}
static TypedValue CreateWithoutParameters(RuntimeType runtimeType) {
try {
return runtimeType.CreateInstance();
}
catch (System.Exception e) {
throw new CreateException(runtimeType.Type, 0, e.InnerException ?? e);
}
}
TypedValue CreateWithParameters(Tree<T> parameters, RuntimeType runtimeType) {
RuntimeMember member = runtimeType.GetConstructor(parameters.Branches.Count);
object[] parameterList = new ParameterList<T>(Processor).GetParameterList(TypedValue.Void, parameters, member);
try {
return member.Invoke(parameterList);
}
catch (System.Exception e) {
throw new CreateException(runtimeType.Type, parameterList.Length, e.InnerException ?? e);
}
}
}
关于c# - 如何将 Fitnesse 与 Autofac/IOC 集成?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26176050/
我开始认真考虑使用 IoC 容器会引发创建过度设计的解决方案(至少它会促使我尝试使用各种不必要的功能:)。 是时候将我的“IoC”反模式列表与社区列表同步了。 我短暂的经验告诉我们,在启动时每个应用程
我一直在阅读有关控制反转框架的内容,而我只是在玩弄这个问题:“我到底为什么需要一个框架来做到这一点?” 不要误解我的问题...该模式是我们程序员经常使用的,但是...一个功能齐全的框架可以做到这一点?
想要改进这篇文章?提供这个问题的详细答案,包括引文和解释为什么你的答案是正确的。没有足够细节的答案可能会被编辑或删除。 我正在尝试确定是否需要付出额外的努力来封装我的 IoC 容器。经验告诉我,我应该
有人建议我,在使用 IOC 容器时,我应该改变这个: class Foobar: IFoobar, IDisposable {}; 进入这个: interface IFoobar: IDisposab
《畜牧代码》播客第 68 期有人,http://herdingcode.com/herding-code-68-new-year-shenanigans/ ,表示 IOC 容器不适合使用 Python
我们正在使用 NInject 框架在我们的应用程序中实现 IoC/DI。我们有具有内部方法的内部类。要实现 IoC/DI,我们必须提取接口(interface)。但是如果我们在一个内部类中只有内部方法
Spring IOC 相关接口分析 1.BeanFactory Spring 中 Bean 的创建是典型的工厂模式,这一系列的 Bean 工厂,即 IOC 容器,为开发者管理对象之间的依赖关系提供了很
MEF is not an IoC container .不过好像是差不多 一个 IoC 容器。似乎我可以很容易地让 MEF 表现得像一个 IoC 容器(见下面的例子),而且让 MEF 成为一个完整的
只是想继续了解 IOC 的原则。 Q1:静态方法 - 具有静态辅助方法的实用程序类是否应该与 IOC 连接? 例如,如果我有一个带有许多静态方法的 HttpUtils 类,我是否应该尝试通过 IOC
众所周知,在asp.net Startup 类中有一个方法ConfigureServices,我们可以添加自定义服务。服务通过依赖注入(inject)提供。 ASP.NET Core includes
所以..我一直在深入研究 IoC 容器和服务定位器。 我认为 IoC 容器是 IoC 容器,而不是服务定位器,因为 您使用它的方式。您将服务定位器传递给需要依赖项的类,然后通过容器检索依赖项。另一方面
阅读许多有关这三个成语之间差异的帖子。但是比较困惑,然后我遇到了这篇文章: http://martinfowler.com/articles/injection.html 只是想看看我是否做对了。如果
我正在寻找用于 asp.net webapi 的 ioc 容器。我们正在寻找的几个关键功能如下 自定义生命周期 对网络请求生命周期的内置支持 在管理依赖项注册方面与 Web API 的良好集成。 最佳
我很难跟随 FP。当人们说“更惯用的风格”时,我必须明白:99% 的 Java 库不适用于 Kotlin 和 Scala 的 FP 惯用风格,对吧?好吧,我需要 Spring Boot 来快速启动 V
目录 1、Spring 1.1、简介 1.2、优点 1.3、组成 1.4、扩展 2、IO
重要提示:请注意,我并不是说单例具有私有(private)构造函数和静态实例变量(或有人建议使用静态类),而是单例在应用程序生命周期内从控制容器的反转返回相同的实例。 许多容器默认使用较短的生命周期。
Closed. This question needs to be more focused。它当前不接受答案。 想要改善这个问题吗?更新问题,使它仅关注editing this post的一个问题。
松耦合当然很棒,但我经常想知道使用 IoC 容器(例如 CaSTLe Windsor)动态连接的开销对紧耦合系统有什么影响? 我知道详细的答案将取决于 IoC 的用途,但我真的只是想了解 IoC 工作
我正在努力让 IOC 在远程处理场景中工作。我将我的应用程序服务器设置为发布通过 XML 配置的服务(SingleCall)。 众所周知,这就像这样: RemotingConfiguration.Co
我使用 IoC (DI) 方法并且通常有参数,这些参数由最低层(数据库层等)从配置设置(即连接字符串、静态值等)中读取。最好的方法是什么? 直接在这个最底层读取,即: string sendGridA
我是一名优秀的程序员,十分优秀!