2

我已经实现了类型参数化测试(Sample #6)以将相同的测试用例应用于多个类。碰巧将字符串分配给 a signed char[]、或时unsigned char[],我得到:const signed char[]const unsigned char[]

../stackoverflow.cpp: In member function ‘void IosTest_DummyTest_Test<gtest_TypeParam_>::TestBody() [with gtest_TypeParam_ = std::basic_istream<char, std::char_traits<char> >]’:                           
../stackoverflow.cpp:34:   instantiated from here
../stackoverflow.cpp:32: error: char-array initialized from wide string

更有趣的是,当将测试用例应用于一种类型时,一切都很好,但是当我添加第二种类型时,它就崩溃了。我可以在以下代码中重现错误:

#include "gtest/gtest.h"
#include <iostream>

// Factory methods
template<class T> std::ios* CreateStream();

template<>
std::ios* CreateStream<std::istream>() {
  return &std::cin;
}

template<>
std::ios* CreateStream<std::ostream>() {
  return &std::cout;
}

// Fixture class
template<class T>
class IosTest: public ::testing::Test {
 protected:
  IosTest() : ios_(CreateStream<T>()) {}
  virtual ~IosTest() {}
  std::ios* const ios_;
};

using testing::Types;
typedef Types<std::istream, std::ostream> Implementations;
TYPED_TEST_CASE(IosTest, Implementations);

TYPED_TEST(IosTest, DummyTest) {
  signed char c[] = ".";
  this->ios_->fill(c[0]);
};

在该行typedef Types<std::istream, std::ostream> Implementations;中创建了一个称为类型的列表,Implementations在下一行中TYPED_TEST_CASE(IosTest, Implementations);,定义了测试用例IosTest将应用于Implementations列表中定义的类型。

正如我已经说过的,如果我从列表中删除其中一个std::istreamstd::ostreamImplementations列表中删除,我可以编译并运行测试而不会发出任何警告(我正在使用-Wall标志)。谁能解释这种现象?

4

2 回答 2

0

是否有可能您的 gtest 库是使用您正在编译应用程序 (stackoverflow.cpp) 的不同版本编译器构建的?我记得看到此错误消息与我使用较新版本的 gcc 构建的库相关,并尝试将其与较旧版本的 gcc 链接。

您可以尝试从源代码构建 gtest。它带有一个脚本,可以将所有内容提取并融合到一个头文件和一个 cpp 文件中。

在您的 gtest 安装中查找此 python 脚本:

gtest/scripts/fuse_gtest_files.py

脚本中有关于如何运行它的说明。你最终得到两个文件:

  • gtest-all.cc
  • gtest.h

您只需要这样做一次并将其添加到您的 makefile 中。我这样做是为了向客户分发基于 Linux 的应用程序。

于 2011-09-23T17:54:35.277 回答
0

它看起来像这里描述的 GCC 错误。

如果你改变signed char c[] = ".";一切char c[] = ".";似乎工作得很好。

于 2011-11-28T21:30:28.443 回答