Google测试C++,调用错误的构造函数的破碎行为
我有一个构造函数,可以打开一个文件并抛出std :: runtime_error如果失败,则构造函数只需一个参数,即带有路径的文件名。我想这样测试。
TEST(TestTextParser, LoadFileThatDoesntExist) {
ASSERT_THROW(TextParser(brokenFilePath),std::runtime_error);
}
但是,相反,我必须像默认值这样测试,而不是抛出单个参数构造函数。
TEST(TestTextParser, LoadFileThatDoesntExist) {
try {
auto c = TextParser(brokenFilePath);
EXPECT_TRUE(false);
}
catch(std::runtime_error e)
{
std::cout << e.what() << std::endl;
ASSERT_TRUE(e.what() == ("Unable to open file " + brokenFilePath));
return;
}
EXPECT_TRUE(false);
}
看似需要的是将构造函数分配给某些东西,这迫使使用适当的构造函数。这是预期的行为吗?
I have a constructor that opens a file and throws a std::runtime_error if it fails, the constructor just takes one argument, the filename with path.I'd like to test it like this;
TEST(TestTextParser, LoadFileThatDoesntExist) {
ASSERT_THROW(TextParser(brokenFilePath),std::runtime_error);
}
but instead, I have to test it like this as the default, not the single parameter constructor is thrown;
TEST(TestTextParser, LoadFileThatDoesntExist) {
try {
auto c = TextParser(brokenFilePath);
EXPECT_TRUE(false);
}
catch(std::runtime_error e)
{
std::cout << e.what() << std::endl;
ASSERT_TRUE(e.what() == ("Unable to open file " + brokenFilePath));
return;
}
EXPECT_TRUE(false);
}
What's seemingly required is to assign the constructor to something, which forces the use of the proper constructor. Is this expected behavior?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我发现
assert_throw()
一般而言的宏(通常不会像我期望的那样解析)。我倾向于将测试包裹在lambda中,然后将lambda放在宏中:I find the
ASSERT_THROW()
macro bothersome in general (it often does not parse the way I expect). I tend to wrap the test in a lambda then place the lambda in the macro: