我最近刚刚读完 Michael Feathers 的书 有效处理遗留代码。这是一本关于如何有效创建测试接缝并利用它们来测试现有代码的好书。
他谈到的技术之一是使用“连接缝”。基本上的想法是,如果您的代码依赖于另一个库,您可以使用链接器插入不同的库用于测试而不是用于生产。这将允许您通过模拟库感知测试条件,或避免调用具有现实世界效果的库(数据库、电子邮件等)等。
他给出的例子是用C++编写的。我很好奇这种技术(或类似的技术)是否可以在 .NET / C# 中实现?
是的,在.Net 中这是可能的。在最简单的情况下,您只需将一个程序集替换为另一个同名程序集即可。
对于强命名的程序集,您应该更改版本号,然后配置程序集绑定以覆盖编译时“链接”版本。这可以在企业、机器、用户或目录级别上完成。
有一些与安全相关的注意事项。如果您要替换的程序集已被强命名,那么您将需要在签署程序集时重新创建相同的公钥。
换句话说,如果您作为应用程序开发人员不希望您的库被“模拟”(或者可能被恶意代码替换),那么您必须确保程序集已签名并且私钥不公开。
这就是为什么你不能模拟 DateTime ——因为微软已经强烈命名了 .Net 的核心库。