我想为下面的代码编写单元测试用例
HomeController.cs
[HttpPost]
[ActionName("CreateDemo")]
public async Task<IHttpActionResult> CreateDemo([FromBody] MyRequest request)
{
if (request == null)
{
return BadRequest("request can not be null");
}
if (request.MyID == Guid.Empty)
{
return BadRequest("MyID must be provided");
}
}
我尝试过以下哪种方法不正确我猜是这样
[TestMethod]
public async Task NullCheck()
{
try
{
var controller = new HomeController();
var resposne = await controller.CreateDemo(null);
Assert.AreEqual(); // not sure what to put here
}
catch (HttpResponseException ex) //catch is not hit
{
Assert.IsTrue(
ex.Message.Contains("request can not be null"));
}
}
答案 0 :(得分:6)
每个单元测试应测试一个要求或关注点。您的方法实现了两个要求:
1)如果请求是null
,请返回带有预定义错误消息的BadRequestErrorMessageResult
对象。
2)如果请求的MyID
属性为空GUID
,则返回BadRequestErrorMessageResult
个对象,并返回另一个预定义的错误消息。
这意味着我们应该进行两次单元测试:
[Test]
public async Task CreateDemo_returns_BadRequestErrorMessageResult_when_request_is_null()
{
// Arrange
var controller = new HomeController();
// Act
var response = await controller.CreateDemo(null);
// Assert
Assert.IsInstanceOf<BadRequestErrorMessageResult>(response);
Assert.AreEqual("request can not be null", response.Message);
}
[Test]
public async Task CreateDemo_returns_BadRequestErrorMessageResult_when_request_ID_is_empty_GUID()
{
// Arrange
var controller = new HomeController();
var request = new MyRequest(Guid.Empty);
// Act
var response = await controller.CreateDemo(request);
// Assert
Assert.IsInstanceOf<BadRequestErrorMessageResult>(response);
Assert.AreEqual("MyID must be provided", response.Message);
}
你可以更进一步,将每个测试分成两个,其中一个测试返回对象是预期类型,另一个验证返回的对象状态是否符合预期(例如Message
字符串是预期的)。这样,每次测试都会有一个断言。
附注:
您使用nunit
标记标记了此问题,因此我提供了使用该框架的代码。但是,在您的示例中,您使用来自Microsoft单元测试框架的[TestMethod]
属性。如果您想使用该框架,则必须进行一些更改,例如:将Assert.IsInstanceOf
替换为Assert.IsInstanceOfType
。
我假设GUID
通过其构造函数传递给MyRequest
,构造函数将其分配给MyID
。
我不是来自网络世界,但我发现BadRequest
方法有一个重载,如果BadRequestErrorMessageResult
作为参数传递,则返回string
。