0

我想测试一个方法是否将一个对象添加到基类的列表中。

我的问题是该列表受到保护,因此我无法在我的测试安排中填充它。因此列表为空,我的方法无法在特定索引处添加对象。

如何制作存根列表并使用它而不是真正的基类列表而不将其公开?

我正在使用 NUnit 和起订量。

这是一些模仿我的问题的代码:

public class Person
{
    public string Name { get; set; }
    readonly List<PhoneNumber> _numbers = new List<PhoneNumber>();

    public void AddNumber(PhoneNumber phoneNumber)
    {
        _numbers.Add(phoneNumber);
    }
}

public class PhoneNumber
{
    public int Number { get; set; }
}

public class BaseClass
{
    protected List<Person> Persons = new List<Person>();
}

public class DerivedClass : BaseClass
{
    public void AddNumberToPersons(int index, PhoneNumber phoneNumber)
    {
        Persons[index].AddNumber(phoneNumber); // <-- Need to test if 
                                               // this gets called without errors
    }
}

[Test]
public void AddNumberToPersons_WhenAddingNumberToPersons_NumberGetsAddedToList()
{
    // I think I need to use a stub list or else the list is empty 
    // and index is out of range.

    // Assert that number is added to the list.
}
4

1 回答 1

0

评论中有一些很好的讨论,关于为什么你可能想考虑你正在尝试测试的是什么。也就是说,在某些情况下,您确实希望设置您的类以使用其基类进行测试。在这种情况下,我不会使用 Moq,而是倾向于使用该类的手卷可测试版本。因此,在您的测试项目中,如果您可以创建这样的可测试版本DerivedClass

public class TestableDerived : DerivedClass {
    public TestableDerived(List<Person> people) {
        this.Persons = people;
    }
    public List<Person> AccessablePersons { get { return this.Persons; } }
}

该类TestableDerived可以访问protected层次结构的成员,因此您可以在测试的排列部分填充它。通常,您可以验证相应的状态Person是否已更新以添加数字。这可能会给你一个类似这样的测试:

var sut = new TestableDerived(new List<Person>(){new Person(), new Person()});

sut.AddNumberToPersons(1, new PhoneNumber { Number = 1234 });

Assert.AreEqual(1, sut.AccessablePersons[1].Numbers.Where(x=>x.Number == 1234).Count());

在您的特定示例中,这是行不通的,因为Person一旦添加了电话号码,您的班级就无法访问它们。您可以通过多种方式解决此问题,但这似乎不是您问题的重点,因此我选择相信这是您的示例代码中的一个遗漏并添加了一个Numbers访问器。

于 2015-05-19T21:08:44.657 回答