
让我们忘记代码的气味,你不应该这样做….
从我所了解的我已经做了以下:
1)创建一个类库“MyMoqSamples”
2)添加了对Moq和NUnit的引用
3)编辑AssemblyInfo文件并添加
[assembly:InternalsVisibleto(“DynamicproxygenAssembly2”)]
[assembly:InternalsVisibleto(“MyMoqSamples”)]
4)现在需要测试一个私有方法,因为它是一种私有方法,它不是接口的一部分.
5)添加以下代码
[TestFixture]public class Can_test_my_private_method{ [Test] public voID Should_be_able_to_test_my_private_method() { // Todo how do I test my DoSomthing method? }}public class CustomerInfo{ public string name { get; set; } public string Surname { get; set; }}public interface ICustomerService{ List<CustomerInfo> GetCustomers();}public class CustomerService : ICustomerService{ public List<CustomerInfo> GetCustomers() { return new List<CustomerInfo> { new CustomerInfo { Surname = "Bloggs",name = "Jo" } }; } protected virtual voID DoSomething() { }} 你能给我一个例子,说明你如何测试我的私人方法?
非常感谢
测试私有的方法有点闻起来,你应该只是测试公共API.如果你觉得这个方法真的很重要,并且需要被隔离测试,那么它应该在自己的类中,然后可以自己测试呢?
如果您的心脏设置在测试上面的保护方法,您可以在您的测试组件中滚动您自己的Mock:
public class CustomerServiceMock : CustomerService { public voID DoSomethingTester() { // Set up state or whatever you need DoSomething(); }}[TestMethod]public voID DoSomething_WhenCalled_DoesSomething() { CustomerServiceMock serviceMock = new CustomerServiceMock(...); serviceMock.DoSomethingTester(); } 如果是私人的话,你可能会做一些反思的事情,但去路线是测试地狱的方式.
更新
虽然你在你的问题中提供了示例代码,但我并没有真正看到你想如何“测试”受保护的方法,所以我会想出一些有创意的东西…
让我们说你的客户服务如下:
public CustomerService : ICustomerService { private Readonly ICustomerRepository _repository; public CustomerService(ICustomerRepository repository) { _repository = repository; } public voID MakeCustomerPreferred(Customer preferred) { MakePreferred(customer); _repository.Save(customer); } protected virtual voID MakePreferred(Customer customer) { // Or more than likely some grungy logic customer.IsPreferred = true; } } 如果您想测试受保护的方法,您可以执行以下 *** 作:
[TestClass]public class CustomerServiceTests { CustomerServiceTester customerService; Mock<ICustomerRepository> customerRepositoryMock; [Testinitialize] public voID Setup() { customerRepoMock = new Mock<ICustomerRepository>(); customerService = new CustomerServiceTester(customerRepoMock.Object); } public class CustomerServiceTester : CustomerService { public voID MakePreferredTest(Customer customer) { MakePreferred(customer); } // You Could also add in test specific instrumentation // by overrIDing MakePreferred here like so... protected overrIDe voID MakePreferred(Customer customer) { CustomerArgument = customer; WasCalled = true; base.MakePreferred(customer); } public Customer CustomerArgument { get; set; } public bool WasCalled { get; set; } } [TestMethod] public voID MakePreferred_WithValIDCustomer_MakesCustomerPreferred() { Customer customer = new Customer(); customerService.MakePreferredTest(customer); Assert.AreEqual(true,customer.IsPreferred); } // Rest of your tests} 这个“模式”的名称是测试特定的子类(基于xUnit测试模式术语),以获取更多信息,您可能希望看到:
http://xunitpatterns.com/Test-Specific%20Subclass.html
根据您的意见和以前的问题,您似乎已经完成了对某些旧代码执行单元测试的任务(或者自己做出决定).在这种情况下,所有遗产代码的圣经是Michael Feathers的书.它涵盖了这样的技术,以及重构和技术来处理将“不可测试”的类和方法分解成更易于管理的东西,我强烈推荐它.
总结以上是内存溢出为你收集整理的c# – 测试和嘲弄私人/受保护的方法.许多帖子,但仍然无法做一个例子全部内容,希望文章能够帮你解决c# – 测试和嘲弄私人/受保护的方法.许多帖子,但仍然无法做一个例子所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)