3

在 Logtalk 代码示例中,每个示例都提供了自己的测试套件,可以在“独立”模式下运行(一次一个测试套件)。

但是,正如标题所说,我对同时测试所有测试套件(在我的应用程序中继承的所有已加载对象lgtunit)的最佳方法感兴趣,并在最后对所有测试执行进行单一摘要(总通过/跳过/失败的)。

例如,在 SWI-Prolog 中,run_tests/0运行所有测试单元。

4

2 回答 2

1

对于自动化,logtalk_testerLogtalk 发行版中包含一个 Bash shell 脚本,可为您提供单一摘要。对于运行所有加载对象的所有测试扩展lgtunit,部分解决方案可能是一个目标,例如:

?- forall(extends_object(TestObject, lgtunit), TestObject::run).

但这不会给你一个单一的总结。一种解决方案是定义一个摘要对象,定义logtalk::message_hook/4钩子谓词来拦截和收集所有相关信息,然后对其进行汇总。您可以检查lgtunit/lgtunit_messages.lgt文件中的消息条款。您要拦截的是tests_results_summary(Total, Skipped, Passed, Failed, Note). 就像是:

:- object(test_summary).

    :- public(report/0).
    report :-
        % compute totals from result_/4 and report them
        ...

    :- private(result_/4).
    :- dynamic(result_/4).

    :- multifile(logtalk::message_hook/4).
    :- dynamic(logtalk::message_hook/4).
    logtalk::message_hook(tests_results_summary(Total,Skipped,Passed,Failed,_), _, lgtunit, _) :-
        assertz(result_(Total,Skipped,Passed,Failed)).

:- end_object.

可能,还run_all/0使用例如上述解决方案向该对象添加谓词。多文件谓词也是动态的。因此,您可以断言和收回其定义,以便它仅在您想要运行所有测试并总结结果时才处于活动状态。

顺便说一句,按照上面的思路,一个完全开发和记录的解决方案将对 Logtalk 做出很好的贡献......

于 2015-11-02T10:52:56.777 回答
1

这是运行所有已注册测试套件的运行器对象的第一个实现:https ://github.com/koryonik/logtalk-experiments/tree/master/test-runner

用法很简单:

只需运行所有加载的 lgtunit 测试套件:

test_runner::autoregister_tests, % register all loaded lgtunit objects
test_runner::run_tests.

或手动注册要运行的测试套件:

test_runner::register_tests(test_suite_obj1),
test_runner::register_tests(test_suite_obj2),
test_runner::run_tests. %run the 2 test suites
于 2016-02-20T19:55:35.337 回答