- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有没有办法打印使用fixtures的erlang测试生成器的测试描述?使用生成器很难判断哪个测试实际上失败了,打印描述会有所帮助。
例子:
-module(math_test).
-include_lib("eunit/include/eunit.hrl").
-define(test(Desc, F), {Desc, {setup, fun setup/0, fun cleanup/1, F}}).
setup() ->
ok.
cleanup(_) ->
ok.
math_test_ () ->
[
?test("adds two numbers", fun add_two_numbers/0),
?test("subtract two numbers", fun subtract_two_numbers/0),
?test("undefined method called", fun undefined_error/0)
].
add_two_numbers () ->
?assertEqual(2, 1 + 3).
subtract_two_numbers () ->
?assertEqual(1, 2 - 2).
undefined_error () ->
undefined_module:uh_oh().
然后运行它
[root@a7c901c022bb src]# rebar3 eunit --module=math_test
===> Verifying dependencies...
===> Compiling math
===> Performing EUnit tests...
FFF
Failures:
1) math_test:math_test_/0
Failure/Error: ?assertEqual(2, 1 + 3)
expected: 2
got: 4
%% /src/_build/test/lib/math/src/math_test.erl:20:in `math_test:-add_two_numbers/0-fun-0-/1`
Output:
Output:
2) math_test:math_test_/0
Failure/Error: ?assertEqual(1, 2 - 2)
expected: 1
got: 0
%% /src/_build/test/lib/math/src/math_test.erl:23:in `math_test:-subtract_two_numbers/0-fun-0-/1`
Output:
Output:
3) math_test:math_test_/0
Failure/Error: {error,undef,[{undefined_module,uh_oh,[],[]}]}
Output:
前 2 个错误没问题,但不是很好——您至少可以在断言中看到实际出错的地方。
然而,第三个错误(调用未定义的模块/方法)是非常错误的地方——没有真正的方法来判断它来自哪里!
有没有办法改进,比如打印测试描述和失败日志?
最佳答案
您可以做的一件事是将测试描述放在测试本身上,而不是整个 setup
元组。即,更改此行:
-define(test(Desc, F), {Desc, {setup, fun setup/0, fun cleanup/1, F}}).
到:
-define(test(Desc, F), {setup, fun setup/0, fun cleanup/1, {Desc, F}}).
随着这个改变,测试描述被打印出来:
Failures:
1) math_test:math_test_/0: adds two numbers
Failure/Error: ?assertEqual(2, 1 + 3)
expected: 2
got: 4
%% /tmp/math_test/mylib/_build/test/lib/mylib/test/math_test.erl:20:in `math_test:-add_two_numbers/0-fun-0-/0`
Output:
Output:
2) math_test:math_test_/0: subtract two numbers
Failure/Error: ?assertEqual(1, 2 - 2)
expected: 1
got: 0
%% /tmp/math_test/mylib/_build/test/lib/mylib/test/math_test.erl:23:in `math_test:-subtract_two_numbers/0-fun-0-/0`
Output:
Output:
3) math_test:math_test_/0: undefined method called
Failure/Error: {error,undef,[{undefined_module,uh_oh,[],[]}]}
Output:
要尝试的另一件事是使用 ?_test
宏而不是普通的 fun
术语指定测试函数:
math_test_ () ->
[
?test("adds two numbers", ?_test(add_two_numbers())),
?test("subtract two numbers", ?_test(subtract_two_numbers())),
?test("undefined method called", ?_test(undefined_error()))
].
?_test
宏会记住它出现的行号,并在测试失败时将其包含在输出中:
1) math_test:math_test_/0:14: adds two numbers
[...]
2) math_test:math_test_/0:15: subtract two numbers
[...]
3) math_test:math_test_/0:16: undefined method called
[...]
现在您可以知道从哪一行调用了这些测试。
另一种方法是让各个函数返回 eunit“测试对象”,而不是仅仅运行测试。这将涉及使用 ?_assertEqual
而不是 ?assertEqual
,或者将整个内容包装在 ?_test
中:
math_test_ () ->
[
?test("adds two numbers", add_two_numbers()),
?test("subtract two numbers", subtract_two_numbers()),
?test("undefined method called", undefined_error())
].
add_two_numbers () ->
?_assertEqual(2, 1 + 3).
subtract_two_numbers () ->
?_assertEqual(1, 2 - 2).
undefined_error () ->
?_test(undefined_module:uh_oh())
然后输出包含行号和各个测试函数的名称:
Failures:
1) math_test:add_two_numbers/0:20: adds two numbers
Failure/Error: ?assertEqual(2, 1 + 3)
expected: 2
got: 4
%% /tmp/math_test/mylib/_build/test/lib/mylib/test/math_test.erl:20:in `math_test:-add_two_numbers/0-fun-0-/0`
Output:
Output:
2) math_test:subtract_two_numbers/0:23: subtract two numbers
Failure/Error: ?assertEqual(1, 2 - 2)
expected: 1
got: 0
%% /tmp/math_test/mylib/_build/test/lib/mylib/test/math_test.erl:23:in `math_test:-subtract_two_numbers/0-fun-0-/0`
Output:
Output:
3) math_test:undefined_error/0:26: undefined method called
Failure/Error: {error,undef,[{undefined_module,uh_oh,[],[]}]}
Output:
关于erlang - 在 erlang eunit failure 中打印测试夹具描述,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50765610/
免责声明:此问题的作者主要具有 Erlang/OTP 的理论知识。 我有一个小型 OTP 应用程序,它通过 open_port() 调用 myapp/ebin 目录中的一些非 Erlang 可执行文件
免责声明:此问题的作者主要具有 Erlang/OTP 的理论知识。 我有一个小型 OTP 应用程序,它通过 open_port() 调用 myapp/ebin 目录中的一些非 Erlang 可执行文件
我是 Erlang 的新手。它有 2 个测试框架:EUnit 和 Common Test。我很困惑何时使用一个而不是另一个。有人可以向我解释 EUnit 相对于 Common Test 的优势是什么,
我目前正在为一个模块编写测试,该模块在以 spawn_link(?MODULE, init, [self()]) 开始的简单进程中运行。 在我的 eunit 测试中,我定义了一个设置和拆卸函数以及一组
我正在尝试检查我在 MongoDB 中定义的所有索引是否正在被我的应用程序使用,并且没有额外的索引。我有一个实用程序可以为单个 Eunit 执行此操作测试套件。但是,我的一些组件有不止一个 Eunit
我有一个带有少量应用程序的中型版本。我最近在发行版中将一些常见功能重构为库应用程序。这使我的 EUnit 测试失败了 undef测试任何需要库应用程序的东西时的消息。 设置是这样的: % In app
假设我有一个名为 example.erl 的模块 在此模块中,我使用以下构造进行调试: %%% Switch debugging output on/off: %-define(DBG(Str, Ar
我正在使用 EUnit 编写一个测试,但控制台中没有输出任何异常详细信息。 exp_test() -> ?assertEqual(0, 1/0). 在 Erlang Shell 输出中运行此模块:
我想知道如何在 eunit 中标记特定测试,以强制它在下一次测试运行时被忽略(即编译,但不执行)。我在 TDD 上下文中问这个问题,即我想以绿色方式进行重构,但仍然有一些测试用例,稍后我会讨论。 我不
我想在执行任何 eunit 测试之前启动 lager 以便我可以在实际运行测试时看到日志(我使用日志进行调试) . 但是我有数百个测试(分布在多个应用程序和模块中),我不想遍历每个测试并将 lager
我有以下目录结构: myapp ├── apps │ ├── myapp │ ├── myotherapp │ └── myapp_common ├── deps │ ├── cowb
我想使用 EUnit 测试一些第三方 Erlang 代码。 代码函数的输出使用 io:format/2 显示到标准输出。 .我想捕获该输出并执行 ?assert测试将被打印出来的字符串。我无法修改第三
我想编写测试,其中设置和清理功能不会针对每个测试执行,而是在测试开始和测试结束时执行一次。 所以我尝试了这种方式: generator_test_() -> {setup, fun setup/0,
在我的启动脚本中,我使用以下命令启动 erlang: erl -args_file vm.args 目前,在尝试使用 rebar eunit 运行单元测试时,有没有办法将自定义运行时参数(例如 -ar
我正在使用 Erlang 和 EUnit 进行单元测试,我想编写一个测试运行器来自动运行我的单元测试。问题是 eunit:test/1 似乎只返回“错误”或“确定”,而不是测试列表以及它们根据通过或失
我正在为 Erlang 代码编写 EUnit 测试。 我有一个源模块: -module(prob_list). -export([intersection/2,union/2]). probabili
我使用 rebar3 (beta-4) 创建了一个 release 应用程序。添加了一些 eunit 测试并编写了一些代码。 现在我必须调试一个测试用例,看看我必须添加什么才能使实现正常工作。 我找到
调用回调函数后是否可以检查 gen_server 的内部状态?我不想在这里更改我的服务器的 API。 最佳答案 您可以使用sys:get_state/1适合所有一代。 关于erlang - 如何使用
有没有办法打印使用fixtures的erlang测试生成器的测试描述?使用生成器很难判断哪个测试实际上失败了,打印描述会有所帮助。 例子: -module(math_test). -include_l
我想从控制台运行以下 eunit 测试命令 eunit:test([test_module, [verbose]). 我试过这个,但似乎不起作用 erl -noshell -pa ./ebin -s
我是一名优秀的程序员,十分优秀!