Как MOq в ISingleResult? Нужно ли мне? или есть лучший способ?

голоса
6

У меня есть метод действий, как это в моем контроллере

public ActionResult Index()
{
    using (NorthwindDataContext db = new NorthwindDatacontext())
    {
        var results = db.GetRecordSets(arg1, ....).ToList();
        // use results as list
    }

    return View();
}

и я хотел бы начать делать тесты для него (да, после того, как он был построен, не раньше ... но код был написан, прежде чем я начал использовать TDD так ...)

и я понял, что добавление свойства, такие как этот к контроллеру

public delegate NorthwindDatacontext ContextBuilderDelegate();

public ContextBuilderDelegate ContextBuilder { get; set; }

Я мог бы добавить в конструктор что-то вроде этого ...

ContextBuilder = () => new NorthwindDatacontext();

то я мог бы проверить настройку свойства ContextBuilder с макетом из NorthwindDatacontext ActionMethod

var controller              = new MyController();
var mockDataContext         = new Mock<NorthwindDatacontext>();
controller.ContextBuilder   = () => mockDataContext.Object;

Но ... я не нашел способа использовать это, потому что все методы NorthwindDatacontext использовать ISingleResult в ReturnType и я не могу найти способ, чтобы создать объект с этим интерфейсом. Я попытался это

var theResult                  = new List<GetRecordSetsResult>();
// fill the data structure here with the provided result...

mockDataContext.Setup(c => c. GetRecordSets()).Returns(theResult as
                                            ISingleResult<GetRecordSetsResult>);

но он не работает, потому что theResult равна нулю при преобразовании в ISingleResult.

Есть ли способ, чтобы создать объект ISingleResult, чтобы проверить это так или я делаю неправильный способ делать вещи здесь?

Заранее спасибо

Задан 19/05/2009 в 11:59
источник пользователем
На других языках...                            


2 ответов

голоса
3

ToList()является метод расширения для IEnumerable, который легко издеваться, потому что он имеет только один метод член - GetEnumerator().

Тем не менее вы можете иметь проблемы насмешливой NorthwindDataContext класса, если его методы не виртуальные ...

В любом случае, это, как я решил аналогичную проблему в моей песочнице, надеюсь, что это помогает:

public class MyType
{
    public virtual ISingleResult<int> ReturnSomeResult() { throw new NotImplementedException(); }
}

[TestMethod]
public void TestMethod1()
{
    var mockMyType = new Mock<MyType>();
    var mockSingleResult = new Mock<ISingleResult<int>>();
    IEnumerable<int> someEnumerable = new int[] {1,2,3,4,5};
    mockSingleResult.Setup(result => result.GetEnumerator()).Returns(someEnumerable.GetEnumerator());
    mockMyType.Setup(myType => myType.ReturnSomeResult()).Returns(mockSingleResult.Object);

    Assert.AreEqual(15, mockMyType.Object.ReturnSomeResult().ToList().Sum());
}
Ответил 19/05/2009 в 15:37
источник пользователем

голоса
5

Я создал класс, который реализован ISingleResult и просто положить список в нем. Я довольно новыми для этого типа кодирования, поэтому в то время как это работает для меня, используйте на свой страх и риск (и если вы видите отверстия оставить комментарий).

class SingleResult<T>:ISingleResult<T>
{
    readonly List<T> _list = new List<T>();

    public void Add(T item)
    {
        _list.Add(item);
    }

    #region Interface Items

    public IEnumerator<T> GetEnumerator()
    {
        return _list.GetEnumerator();
    }

    IEnumerator IEnumerable.GetEnumerator()
    {
        return GetEnumerator();
    }

    public object ReturnValue { get { return _list; } }

    public void Dispose() { }

    #endregion
}

Это может быть использовано для возврата в части издеваться. Вот как я в конечном итоге использовать его с Rhino иронизирует:

[TestMethod]
public void TestSomething()
{
    //Arrange
    // Make a data context and DAL
    var _ctx = MockRepository.GenerateMock<IDataClassesDataContext>();
    var someDALClass = new SomeDALClass(_ctx);

    User testUser = UserObjectHelper.TestUser();
    SingleResult<User> userList = new SingleResult<User> { testUser };

    // Indicate that we expect a call the to sproc GetUserByUserID
    _ctx.Expect(x => x.GetUserByUserID(testUser.UserID)).Return(userList);

    //Act
    someDALClass.UpdateUser(testUser);

    //Assert
    Assert.IsTrue(SomeTestCondition());
}
Ответил 07/12/2009 в 19:10
источник пользователем

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more