如何使用jdb调试JUnit测试用例?

时间:2012-12-14 11:55:36

标签: java unit-testing debugging junit jdb

我在调试JUnit测试用例时遇到问题。我正在使用Java v6和JUnit Framework v3.8.2。

我像这样调用jdb:

jdb junit.textui.TestRunner MyTest

问题是我不知道TestRunner从TestCase类创建的对象的名称。例如,我想打印方法的返回值,但是当我不知道对象的名称时,如何调用该方法?

编辑:异常发生在第45行,这是我在jdb中执行“where”时得到的调用堆栈:

[1] MyTest.test1 (MyTest.java:44)
[2] sun.reflect.NativeMethodAccessorImpl.invoke0 (native method)
[3] sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java:57)
[4] sun.reflect.DelegatingMethodAccessorImpl.invoke (DelegatingMethodAccessorImpl.java:43)
[5] java.lang.reflect.Method.invoke (Method.java:616)
[6] junit.framework.TestCase.runTest (TestCase.java:164)
[7] junit.framework.TestCase.runBare (TestCase.java:130)
[8] junit.framework.TestResult$1.protect (TestResult.java:106)
[9] junit.framework.TestResult.runProtected (TestResult.java:124)
[10] junit.framework.TestResult.run (TestResult.java:109)
[11] junit.framework.TestCase.run (TestCase.java:120)
[12] junit.framework.TestSuite.runTest (TestSuite.java:230)
[13] junit.framework.TestSuite.run (TestSuite.java:225)
[14] junit.textui.TestRunner.doRun (TestRunner.java:121)
[15] junit.textui.TestRunner.start (TestRunner.java:185)
[16] junit.textui.TestRunner.main (TestRunner.java:143)

Edit2:我搞砸了,我知道要打印方法的对象的名称,但它仍然不起作用。我写了一个小测试用例和类来解释确切的问题。

这是测试用例:

import junit.framework.TestCase;

public class TestJUnit extends TestCase {

    public void test1() {
        try {
            JUnitTestClass mtc = new JUnitTestClass();
            assertTrue(mtc.method1() == 1);
            assertTrue(mtc.method1() == 2);
        } catch (Exception exc) {
            fail(exc.getMessage());
        }
    }
}

这是经过测试的课程:

public class JUnitTestClass {

    private int att1 = 0;

    public int method1() {
        this.att1 += 1;
        return this.att1;
    }
}

然后我像这样运行调试器:

bash-4.2$ jdb -classpath $CLASSPATH junit.textui.TestRunner TestJUnit
Initializing jdb ...
> stop at TestJUnit:8
Deferring breakpoint TestJUnit:8.
It will be set after the class is loaded.
> run
run junit.textui.TestRunner TestJUnit
Set uncaught java.lang.Throwable
Set deferred uncaught java.lang.Throwable
> 
VM Started: Set deferred breakpoint TestJUnit:8
.
Breakpoint hit: "thread=main", TestJUnit.test1(), line=8 bci=8
8                assertTrue(mtc.method1() == 1);

main[1] print mtc.method1()
com.sun.tools.example.debug.expr.ParseException: Name unknown: mtc.method1
mtc.method1() = null
main[1] dump mtc
com.sun.tools.example.debug.expr.ParseException: Name unknown: mtc
mtc = null

当我尝试打印方法或转储对象时,我得到“名称未知”。

Edit3:我在使用javac时忘了使用-g,抱歉。

2 个答案:

答案 0 :(得分:1)

对不起,伙计们,我对这一切都是新手,我犯了一个愚蠢的错误。在调用javac生成我的测试用例类文件时,我忘了使用-g命令。它现在有效。

答案 1 :(得分:0)

你可以在一个实际的测试方法中设置一个断点,然后在它休息时查看调用堆栈,然后升级到实际的JUnit代码吗?

使用可视化调试器这可能是最简单的。它还假设您运行的JUnit实例是使用调试支持构建的。否则你不会得到任何符号信息。