16

每当由于StackOverflowException单元测试过程立即退出而导致单元测试失败 - 找出发生了什么(我知道)的唯一方法是调试通过按照此处找到的步骤获得的单元测试过程的故障转储

StackOverflowException获取抛出时正在运行的单元测试的名称的最简单方法是什么?即使在调试单元测试时,我也很难找到当前单元测试的名称,因为它位于堆栈的底部,并且 Visual Studio 不会在调试窗口中显示整个堆栈,因为它太大了。

有没有办法在不收集和调试故障转储的情况下找出哪个单元测试失败?

4

2 回答 2

1

正如在另一个问题中提到的,除非您自己抛出它,否则您无法真正捕获堆栈溢出异常。

因此,作为您的问题的解决方法(不是真正的解决方案),您可以在代码中插入方法调用以检测堆栈溢出,然后手动抛出异常并稍后捕获它。

[TestClass]
public class TestStackOverflowDetection
{
    [TestMethod]
    public void TestDetectStackOverflow()
    {
        try
        {
            InfiniteRecursion();
        }
        catch (StackOverflowException e)
        {
            Debug.WriteLine(e);
        }
    }

    private static int InfiniteRecursion(int i = 0)
    {
        // Insert the following call in all methods that
        // we suspect could be part of an infinite recursion 
        CheckForStackOverflow(); 

        // Force an infinite recursion
        var j = InfiniteRecursion(i) + 1;
        return j;
    }

    private static void CheckForStackOverflow()
    {
        var stack = new System.Diagnostics.StackTrace(true);
        if (stack.FrameCount > 1000) // Set stack limit to 1,000 calls
        {
            // Output last 10 frames in the stack
            foreach (var f in stack.GetFrames().Reverse().Take(30).Reverse())
                Debug.Write("\tat " + f);

            // Throw a stack overflow exception
            throw new StackOverflowException();
        }
    }
于 2013-03-12T17:41:42.073 回答
1

看看RuntimeHelpers.EnsureSufficientExecutionStack方法(http://msdn.microsoft.com/en-us/library/system.runtime.compilerservices.runtimehelpers.ensuresufficientexecutionstack.aspx)。您可能希望在递归方法中调用它以InsufficientExecutionStackException提前获取。

于 2013-03-12T19:29:06.177 回答