Я испытываю странное поведение в Moq - несмотря на то, что я настраиваю фиктивный объект, чтобы он действовал определенным образом, а затем вызываю метод точно таким же образом в тестируемом объекте, он реагирует так метод никогда не вызывался.
У меня есть следующее действие контроллера, которое я пытаюсь проверить:
public ActionResult Search(string query, bool includeAll)
{
if (query != null)
{
var keywords = query.Split(' ');
return View(repo.SearchForContacts(keywords, includeAll));
}
else
{
return View();
}
}
Код моего юнит-теста:
public void SearchTestMethod() // Arrange
var teststring = "Anders Beata";
var keywords = teststring.Split(' ');
var includeAll = false;
var expectedModel = dummyContacts.Where(c => c.Id == 1 || c.Id == 2);
repository
.Expect(r => r.SearchForContacts(keywords, includeAll))
.Returns(expectedModel)
.Verifiable();
// Act
var result = controller.Search(teststring, includeAll) as ViewResult;
// Assert
repository.Verify();
Assert.IsNotNull(result);
AssertThat.CollectionsAreEqual<Contact>(
expectedModel,
result.ViewData.Model as IEnumerable<Contact>
);
}
где AssertThat
- это просто мой собственный класс с кучей помощников утверждений (поскольку класс Assert
нельзя расширять с помощью методов расширения ... вздох ...).
Когда я запускаю тест, он завершается неудачно в строке repository.Verify()
, с MoqVerificationException
:
Test method MemberDatabase.Tests.Controllers.ContactsControllerTest.SearchTestMethod()
threw exception: Moq.MockVerificationException: The following expectations were not met:
IRepository r => r.SearchForContacts(value(System.String[]), False)
Если я удаляю repository.Verify()
, утверждение коллекции не сможет сообщить мне, что возвращенная модель - null
. Я отладил и проверил, что query != null
, и что я попал в часть блока if
, где выполняется код. Там нет проблем.
Почему это не работает?