阻塞线程的单元测试方法

时间:2019-10-17 14:34:49

标签: c# unit-testing mocking xunit.net

在等待某事并阻塞线程的方法上进行UnitTest的最佳方法是什么? 我想测试该方法是否调用另一个方法,但是显然测试永远不会结束,因为线程正在等待另一个事件。我正在使用C#,xUnit和Mock 我想到了在调用该方法以结束块时在模拟中引发异常的想法。另一个想法是使用超时,但这听起来也不对。 在这种情况下,您认为什么是好的做法?

[Fact]
public void Connect_ConnectAsync_MethodCalled()
{
    // Arrange
    var socketMock = new Mock<IHsmsSocket>();
    socketMock.Setup(x => x.ConnectAsync(It.IsAny<SocketAsyncEventArgs>())).Throws(new Exception("Method called"));

    int bufferSize = 5000;
    int port = 5000;
    IPAddress ip = IPAddress.Parse("0.0.0.0");
    SocketClient client = new SocketClient(socketMock.Object, bufferSize);

    IPEndPoint endPoint = new IPEndPoint(ip, port);

    Exception ex = new Exception("Not called");

    // Act
    try
    {
        client.Connect(endPoint);
    }
    catch (Exception e)
    {
        ex = e;
    }

    // Assert
    Assert.Equal("Method called", ex.Message);

    // Clean up
    client.Dispose();
}

1 个答案:

答案 0 :(得分:0)

我个人会像在您的示例中一样抛出一个特定的异常。 这是正确的最简单方法,也是所有测试读者最明显的方法。

虽然超时同样有效,但效果相同,但实际上只是增加了运行测试所需的时间。

测试的读者可能会想知道为什么首先要使用超时。 尚不清楚为什么要使用特定的间隔来等待完成。

我也不想抛出System.Exception,而是抛出一个特定的自定义异常,例如DummyException,以表明它纯粹是为了测试,与方法调用背后的实际行为无关。

我也更喜欢使用try-catch块,但这有点个人喜好。

var ex = Assert.Throws<DummyException>(action);
Assert.Equal(ex.Message, "Method called");
相关问题