2

我们正在我的公司开始一个新的绿地项目,并且已经决定我们将使用 Microsoft 的 Moles 框架来进行我们在单元测试中的所有模拟。理想情况下,我的经理不想引入任何其他 Mocking 框架,例如 NSubstitute 或 Moq 来使项目复杂化。但是我发现,由于 Moles 生成 Mocks 和 Stub 的性质,它不能很好地与重构工具一起使用。

例如,我们使用 resharper,如果我有以下接口,moles 将生成一个像这样的存根:

IMyInterface -> SIMyInterface

现在,如果我要将 IMyInterface 重构为另一个名称,例如:IMyNewInterface

然后在我的单元测试中,Stub 类显然不会被重构,因为它从根本上具有不同的名称。

我可以看到,一旦我们得到许多单元测试的排列组合,这将是一个大问题,重构将成为一场噩梦,而口头禅将是“不要改变任何东西!”

有没有人有类似的经验或知道可以处理 Moles 的重构工具?


感谢梅林和迈克。我的团队决定妥协并仅将 Moles 用于我们无法使用标准工具模拟的类型,然后将其他框架(例如 NSubstitute)用于其他所有内容。

4

2 回答 2

1

2012 年 8 月 16 日更新 - 请使用假货而不是痣。Fakes 随 Visual Studio 2012 提供,是 Moles 的完全支持的产品版本。

Moles 没有第三方供应商支持;因为,它不是官方发布和支持的技术,而且还在不断变化。我创建了一些生成 Moles 和 Pex 属性和测试方法的 CodeRush 模板;但是,这对重构类型名称没有帮助。

我同意,您在代码和测试程序集中重构名称的想法是一个很好的想法。具有讽刺意味的是,mole 类型无法重构,因为它们来自已编译的程序集。您能做的最好的事情就是重构代码,然后在测试项目中执行搜索和替换(糟糕)。是的,这很难看,尤其是在重构了几件事之后。


痣建议:

我建议 RiSE 调整 moles(再次)以生成未编译的 Moles 项目,而不是生成已编译的程序集。我知道组装的事情要容易得多,但我预见到这将允许开发人员在 moole 类中重构 mole 和 stub 类型名称。此外,重构工具,例如 Refactor! Pro 应该能够跨代码、mole 和测试项目自动重构代码和mole 类型名称。

于 2011-09-20T18:13:47.697 回答
0

根据Microsoft Moles 参考手册,在“代码生成配置”下,第 11 页:

也可以禁用编译,在这种情况下,Moles 代码生成器会将生成的 C# 源代码插入项目中。

似乎禁用所述编译的方法是添加一个Compilation元素作为(根)Moles元素的子元素(如果不存在),并向所述子元素添加一个ProjectTemplate属性,将其值设置为 .csproj 文件的路径。这是基于我对 Visual Studio 中 XML 编辑器显示的所述属性的 IntelliSense 描述的阅读(取自 Moles 架构中的文档,在我的计算机上位于C:\Program Files\Microsoft Visual Studio 10.0\Xml\Schemas\moles.xsd),内容如下:

将用于创建 Moles 程序集项目以进行编译的空 C# 项目文件的路径

于 2011-09-28T22:24:02.153 回答