【问题标题】:gtest running error : recipe for target 'test' failedgtest 运行错误:目标“测试”的配方失败
【发布时间】:2017-05-07 12:03:15
【问题描述】:

我正在使用gtest,当一个测试用例在输入后失败时发生了一些错误

$make 测试

Running tests...
Test project /home/wangfrank/GitRootPath/qwer/http_server_client_practice/bin
    Start 1: case-2_nettools_test
1/3 Test #1: case-2_nettools_test .............***Failed    0.00 sec
[==========] Running 1 test from 1 test case.
[----------] Global test environment set-up.
[----------] 1 test from test_case_2
[ RUN      ] test_case_2.test_ipv4addr_constructor
32512
/home/wangfrank/GitRootPath/qwer/http_server_client_practice/test/2_nettools_test.cpp:12: Failure
      Expected: ip_s_0
      Which is: "127.0.0.1"
To be equal to: ip_s_1
      Which is: "32512"
[  FAILED  ] test_case_2.test_ipv4addr_constructor (0 ms)
[----------] 1 test from test_case_2 (0 ms total)

[----------] Global test environment tear-down
[==========] 1 test from 1 test case ran. (0 ms total)
[  PASSED  ] 0 tests.
[  FAILED  ] 1 test, listed below:
[  FAILED  ] test_case_2.test_ipv4addr_constructor

 1 FAILED TEST

    Start 2: case-0_config_test
2/3 Test #2: case-0_config_test ...............   Passed    0.00 sec
    Start 3: case-1_facility_test
3/3 Test #3: case-1_facility_test .............   Passed    0.01 sec

67% tests passed, 1 tests failed out of 3

Total Test time (real) =   0.01 sec

The following tests FAILED:
          1 - case-2_nettools_test (Failed)
Errors while running CTest
Makefile:116: recipe for target 'test' failed
make: *** [test] Error 8

这就是我的 CMakeLists.txt 的样子:

 17 message("==== ENTRY ==== ${unittest_SOURCE_DIR}")                                                                                                                                                               
 18 file(GLOB TESTFILES ./ *.cpp)                                                                                                                                                                                   
 19 foreach(singletestfilename ${TESTFILES})                                                                                                                                                                        
 20     get_filename_component(tn ${singletestfilename} NAME_WE)                                                                                                                                                    
 21     message("==== do with file target : ${tn}")                                                                                                                                                                 
 22     add_executable(${tn} ${singletestfilename})                                                                                                                                                                 
 23     target_link_libraries(${tn} gtest gtest_main)                                                                                                                                                               
 24     target_link_libraries(${tn} ${MY_EXTRA_LIBS})                                                                                                                                                               
 25     add_test(NAME case-${tn}                                                                                                                                                                                    
 26         COMMAND ${tn})                                                                                                                                                                                          
 27 endforeach(singletestfilename)

下面是那个测试文件。

  1 #include "nettools.h"                                                                                                                                                                                           
  2 #include "facility.h"                                                                                                                                                                                           
  3 #include "gtest/gtest.h"                                                                                                                                                                                        
  4                                                                                                                                                                                                                 
  5 TEST(test_case_2, test_ipv4addr_constructor) {                                                                                                                                                                  
  6     using my_http::Ipv4Addr;                                                                                                                                                                                    
  7     Ipv4Addr test_ip = Ipv4Addr("localhost", 1234);                                                                                                                                                             
  8     std::cout << test_ip.get_ip_str() << std::endl;                                                                                                                                                             
  9     std::string ip_s_0 = Ipv4Addr::host2ip_str("localhost");                                                                                                                                                    
 10     std::string ip_s_1 = test_ip.get_ip_str();                                                                                                                                                                  
 11     EXPECT_EQ(ip_s_0, ip_s_1);                                                                                                                                                                                  
 12 }                                                                                                                                                                                                               
 13                                                                                                                                                                                                                 
 14 int main(int argc, char **argv) {                                                                                                                                                                               
 15     ::testing::InitGoogleTest(&argc, argv);                                                                                                                                                                     
 16     return RUN_ALL_TESTS();                                                                                                                                                                                     
 17 }        

它似乎是 gtest 中的 issue。但是我还是不知道怎么解决?谁能帮帮我?

我正在使用 ubuntu16.04、gcc5.4.0、cmake 3.5.1、gtest 1.7.0(我在 gtest 主目录下的 CHANGES 文件中找到的)。

-----第二次编辑--------

如果没有失败的测试,没有错误。

如果我手动运行可执行文件,没有错误。

【问题讨论】:

  • 请使用 --output-on-failure 选项重新运行 ctest 并使用输出更新您的问题。它也可能有助于显示失败的测试用例的源代码。否则,我们这里没有足够的信息来帮助您。
  • @CraigScott 感谢您的建议。
  • 为什么你认为这是 googletest 的问题,而不是被测试的库或测试本身?您有失败的测试代码。您是否尝试过从中创建独立的可执行文件并运行?
  • @Tsyvarev 如果你的意思是在 /bin/test 下运行 ** 2_nettools_test **,我做了,没有发生错误。因为这个问题中指出的错误是makefile的错误,不会影响可执行文件。我已经更新了我的问题,感谢您的申请。

标签: cmake googletest


【解决方案1】:

我在 Ubuntu 18.04 上安装了猫鼬。 我有编译输出:

FAILURE test/unit_test.c:845: ok == 200
Makefile:64: recipe for target 'test' failed
make: *** [test] Error 1

需要执行,这些命令会想办法提取修复:

make --keep-going
make --touch

我可以通过keep-goingtouch 谈论我的步骤。 它们显示了错误配置文件更改的七个阈值。 构建日志:

... #for example
touch vc98
touch vc2017
touch mingw
touch mingw++
touch linux
touch fuzzer
touch fuzz

您需要安装与我的相同的缺失依赖项,以便编译工作。测试软件包并在此处留下您的反馈。

【讨论】:

    猜你喜欢
    • 2021-04-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-03-03
    • 2015-12-02
    • 1970-01-01
    • 2021-12-08
    相关资源
    最近更新 更多