5

release用 rebar3 (beta-4) 创建了一个应用程序。添加了一些 eunit 测试并编写了一些代码。

现在我必须调试一个测试用例,看看我必须添加什么才能使实现正常工作。

我从 Erlang 控制台找到了一些关于使用的文章dbg,并找到了如何从 Eunit 编写调试信息。但我需要从我必须测试的代码中获取信息(实际实现(逻辑))。

rebar3当与参数一起使用时,有没有办法调试 Erlang 代码(实际源代码,而不是测试代码)eunit

我在终端中使用跟踪:https ://aloiroberto.wordpress.com/2009/02/23/tracing-erlang-functions/

4

1 回答 1

8

一种方法是使用rebar3在测试配置文件下运行 shell,然后启动调试器并设置断点等:

$ rebar3 as test shell
...
1> debugger:start().
{ok, <0.67.0>}

这将弹出调试器 GUI。调试器设置好并准备就绪后,在以下位置运行测试eunit

2> eunit:test(your_test_module,[verbose]).
======================== EUnit ========================
your_test_module: xyz_test_ (module 'your_test_module')...

假设您在调试器中设置了一个合适的断点,这会命中它,但您可能会遇到这种方法的问题:默认情况下,eunit测试会在 5 秒后超时,这不会给您太多的调试时间。您需要为您的测试指定更长的超时时间,这就是为什么上面的示例显示正在运行的是一个名为的测试夹具xyz_test_,它用较长的超时时间包装实际测试。这样的夹具非常简单:

-include_lib("eunit/include/eunit.hrl").

xyz_test_() ->
    {timeout,3600,
     [fun() -> ?assertMatch(expected_value, my_module:my_fun()), ok end]}.

在这里,实际的测试是匿名函数,它与 from 的返回值匹配my_module:my_fun/0,在这个例子中,它代表了被测业务逻辑。这个示例夹具将测试超时设置为一小时;您当然可以根据应用程序的需要进行设置。

于 2016-01-08T01:05:29.160 回答