我有这样的方法:
public bool CheckForRuleName(string ruleName, string studentId)
{
var rules =
_noSqlProvider.GetDocumentsByQuery<StudentRule>(string.Format(GET_Student_BASED_ON_RULENAME, ruleName, studentId));
if (rules.Count() != 0)
{
return true;
}
return false;
}
写了一个单元测试:
[TestMethod]
public void when_calling_CheckForRuleName_Should_Return_FALSE_WHEN_RULE_DOES_NOT_EXIST()
{
var noSqlProv = new Mock<INoSqlProvider<Document, DocumentCollection>>();
noSqlProv.Setup(x => x.GetDocumentsByQuery<StudentRule>(It.IsAny<string>()));
var rulesRepository = new RulesRepository(noSqlProv.Object);
bool rules = rulesRepository.CheckForRuleName("test123","testrule");
Assert.AreEqual(false, rules);
}
测试失败,但有以下异常:
ArgumentNullException: Value cannot be null.
Parameter name: source
现在GetDocumentsByQuery方法需要一个像这样的SQL字符串:
"select j from json j where j.name='{0}' and j.studentid='{1}'"
它查询DocumentDb,只是为了完成这个问题。 因为查询我使用的实际Db不是一个好习惯:
It.IsAny<string>()
我是单元测试的新手,所以有人可以就如何对这类代码进行单元测试提供指导。
提前致谢。
问候。
答案 0 :(得分:4)
您的存根方法不会返回任何值,因此默认返回null
。将一个存根规则列表添加到return子句中。如果你想让它返回false,那么它必须是一个空集合。
var stubbedRules = new StudentRule[0];
noSqlProv.Setup(x => x.GetDocumentsByQuery<StudentRule>(It.IsAny<string>())).Returns(stubbedRules);