【问题标题】:Segmentation fault while running Google test运行 Google 测试时出现分段错误
【发布时间】:2014-08-08 10:05:44
【问题描述】:

当我尝试通过模拟一个接受指向对象的指针作为参数的方法来运行 gtest 时,我遇到了分段错误。我确定了造成问题的模拟方法。

class NvmControllerMockApp : NvmController_API
{ 

 public:

   MOCK_METHOD1(registerAccessor, bool(NVM_Accessor *accessor));
   MOCK_METHOD0(update, void());

}

这是gtest产生的o/p:

Running main() from gmock_main.cc
[==========] Running 1 test from 1 test case.
[----------] Global test environment set-up.
[----------] 1 test from MeterTamperAppTest
[ RUN      ] MeterTamperAppTest.NeutralDisturbanceCheck
Segmentation fault (core dumped)

MOCK_METHOD1 是造成分段错误的原因。如果从要测试的文件中排除该方法,那么事情似乎工作正常。需要注意的是,NVM_Accessor 类处理一些指针。我尝试使用 GDB 调试错误,以下是分段错误时的回溯消息:

Program received signal SIGSEGV, Segmentation fault.
0x00000000004168d3 in testing::internal::UntypedFunctionMockerBase::UntypedInvokeWith (this=0x67f188, untyped_args=0x7fffffffdca0)
    at ../src/gmock-spec-builders.cc:363
363     this->UntypedDescribeUninterestingCall(untyped_args, &ss);
(gdb) backtrace
#0  0x00000000004168d3 in testing::internal::UntypedFunctionMockerBase::UntypedInvokeWith (this=0x67f188, untyped_args=0x7fffffffdca0)
    at ../src/gmock-spec-builders.cc:363
#1  0x0000000000410fc9 in testing::internal::FunctionMockerBase<bool (NVM_Accessor*)>::InvokeWith(std::tr1::tuple<NVM_Accessor*> const&) (
    this=0x67f188, args=...) at /home/sudeep/GramPower/gmock-1.7.0/include/gmock/gmock-spec-builders.h:1530
#2  0x0000000000410c56 in testing::internal::FunctionMocker<bool (NVM_Accessor*)>::Invoke(NVM_Accessor*) (this=0x67f188, a1=0x67f148)
    at /home/sudeep/GramPower/gmock-1.7.0/include/gmock/gmock-generated-function-mockers.h:97
#3  0x000000000041076f in NvmControllerMockApp::registerAccessor (this=0x67f180, gmock_a1=0x67f148)
    at /home/sudeep/GramPower/gpos_fw/gpos/apps/nvm_controller/mocks/nvm_controller_mock_app.h:26
#4  0x0000000000413470 in MeterTamperApp::MeterTamperApp (this=0x67f128, env_=0x67ee90) at apps/meter_tamper/meter_tamper_app.cpp:31
#5  0x0000000000410989 in MeterTamperAppMockEnvironment::MeterTamperAppMockEnvironment (this=0x67ee90)
    at apps/meter_tamper/tests/../mocks/meter_tamper_app_mock_environment.h:23
#6  0x0000000000410a3e in MeterTamperAppTest::MeterTamperAppTest (this=0x67ee80) at apps/meter_tamper/tests/meter_tamper_app_dtest.cpp:30
#7  0x0000000000410b10 in MeterTamperAppTest_NeutralDisturbanceCheck_Test::MeterTamperAppTest_NeutralDisturbanceCheck_Test (this=0x67ee80)
    at apps/meter_tamper/tests/meter_tamper_app_dtest.cpp:36

【问题讨论】:

  • 你能分享一个最小版本的gmock_main.cc,它会出现分段错误吗?
  • 可能解决不了问题,但是继承应该是公开的
  • 如果您包含MeterTamperAppTest.NeutralDisturbanceCheck 的测试用例代码以及测试夹具代码会有所帮助,因为在回溯中可以看到涉及夹具构造函数,这很奇怪。这意味着在运行测试用例中的任何指令之前发生分段错误。
  • 请@user3921737找到这个问题的答案了吗?

标签: c++ unit-testing googletest


【解决方案1】:

我有一个类似的问题 - 模拟类实例化的分段错误。我将 gmock 和 gtest 构建为静态库。 通过将-Dgtest_disable_pthreads=OFF 选项传递给cmake,问题已得到解决。 希望这对其他人有帮助。

【讨论】:

    【解决方案2】:

    解决方法很简单:使用当前的 git 版本。

    相关的cmets和gmock 1.7.0版本出了什么问题可以在这里找到:

    gcc 6.1.0 segmentation fault - gcc bug?

    谷歌测试的错误报告可以在这里找到: https://github.com/google/googletest/issues/705

    最后一个链接还提供了一个修复,可以合并到 1.7.0 中,而无需检查当前的 git repo。

    【讨论】:

      【解决方案3】:

      可能您的目标文件生成错误。删除所有目标文件并从头开始编译。

      【讨论】:

        【解决方案4】:

        我遇到了同样的问题。 就我而言,这是因为“EXPECT_EQ”没有中断测试执行:

            std::vector<int> ret = some_call(); //here the empty vector intializing "ret"
            EXPECT_EQ(ret.size(), 1); //here is failure
            EXPECT_EQ(ret[0], expectedResult); //here is segmentation. Author expected test termination one line above
        

        .. 我将深入研究 gtest 文档..

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2015-08-27
          • 1970-01-01
          • 2021-07-03
          • 2017-02-22
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多