我在Typhoon中定义了一个ApplicationAssembly。
所以我想要做的是:“这个类X需要注入符合Foo协议的东西。这是一个RealFoo,这是一个TestFoo。当我在现实生活中运行X时,我想要它得到一个RealFoo,但是当我运行我的集成测试时,我希望它能得到一个TestFoo“。
我该怎么做?
答案 0 :(得分:6)
有几种推荐的方法可以做到这一点:
使用Typhoon Patcher
Typhoon-patcher允许加载基本程序集,但是使用另一个定义或给定对象实例修补一个或多个组件。以下是使用模拟修补组件的示例:
MiddleAgesAssembly* assembly = [MiddleAgesAssembly assembly];
TyphoonComponentFactory* factory = [TyphoonBlockComponentFactory factoryWithAssembly:assembly];
TyphoonPatcher* patcher = [[TyphoonPatcher alloc] init];
[patcher patchDefinition:[assembly knight] withObject:^id
{
Knight* mockKnight = mock([Knight class]);
[given([mockKnight favoriteDamsels]) willReturn:@[
@"Mary",
@"Janezzz"
]];
return mockKnight;
}];
[factory attachPostProcessor:patcher];
Knight* knight = [factory componentForKey:@"knight"];
将环境相关的组件放在一起
另一种方法是将依赖于环境的组件组合在一起。如果您正在使用XML样式程序集,则可以为生产与测试方案加载不同的文件集,包括基本程序集和任何依赖于环境的文件。
在基于块的装配中可以实现同样的目的,如下所示:
TyphoonComponentFactory* factory = [[TyphoonBlockComponentFactory alloc] initWithAssemblies:@[
[MiddleAgesAssembly assembly],
[StarWarsAssembly assembly]
]];
Knight* cavalryMan = [(MiddleAgesAssembly*) factory cavalryMan];
Knight* stormTrooper = [(StarWarsAssembly*) factory stormTrooper];
有关详细信息,请参阅Typhoon documentation中的 程序集的模块化 ,或查看sample app,其中包含此示例。
使用TyphoonConfig
另一种方法是使用TyphoonConfig。此功能的详细信息为here。
修改强>
以上示例适用于Typhoon 2.0。这对于Typhoon 3.0来说仍然可以正常工作,但有点整洁就是装配激活:
MiddleAgesAssembly *assembly = [[MiddleAgesAssembly new] activate];
Knight *knight = [assembly knight];
[assembly.colloaboratingAssembly stormTrooper]