'(也许你打算在 gmock 测试中使用'->'?)'
'(maybe you meant to use ‘->’ ?)' in gmock test
我使用 gtest 和 gmock 进行了单元测试。
这些都提供了,轮到我让他们通过了。
我有一个 RentalAdministration 对象,它采用(在某些方法中)一个 Car 对象指针。其中一个函数如下所示:
bool RentalAdministration::Add(Car *car){
if(!car){
throw invalid_argument("Car parameter can't be null!");
}
if(FindCar(car->GetLicencePlate()) != NULL){
return false;
}
cars.push_back(car);
return true;
}
其中一个测试看起来像他的:
TEST(RentalAdministrationAdd, test_add_car_to_empty_administration)
{
RentalAdministration admin;
Car *car;
EXPECT_CALL(car, GetLicencePlate()).WillOnce(Return("fh-01-ict"));
EXPECT_TRUE(admin.Add(&car));
}
当我尝试进行这些测试时,我遇到了很多错误,所有这些都是相似的:
g++ -Wall -Werror -pedantic -ggdb -O0 -std=c++98 -Iproduct -Itest test/RentalAdministrationTest.cpp product/RentalAdministration.cpp -lgtest -lgmock -lgmock_main -lpthread -o RentalAdministrationTest
In file included from /usr/include/gmock/gmock-generated-function-mockers.h:43:0,
from /usr/include/gmock/gmock.h:61,
from test/RentalAdministrationTest.cpp:2:
test/RentalAdministrationTest.cpp: In member function ‘virtual void RentalAdministrationAdd_test_add_car_to_empty_administration_Test::TestBody()’:
test/RentalAdministrationTest.cpp:13:5: error: request for member ‘gmock_GetLicencePlate’ in ‘car’, which is of pointer type ‘Car*’ (maybe you meant to use ‘->’ ?)
EXPECT_CALL(car, GetLicencePlate()).WillOnce(Return("fh-01-ict"));
^
In file included from /usr/include/gtest/gtest.h:58:0,
from /usr/include/gmock/internal/gmock-internal-utils.h:47,
from /usr/include/gmock/gmock-actions.h:46,
from /usr/include/gmock/gmock.h:58,
from test/RentalAdministrationTest.cpp:2:
test/RentalAdministrationTest.cpp:14:31: error: no matching function for call to ‘RentalAdministration::Add(Car**)’
EXPECT_TRUE(admin.Add(&car));
^
我想知道我在这里做错了什么。我刚开始使用 C++。
顺便说一句:我正在用 g++ 编译并且有 98 版。
谢谢。
编辑:请原谅我没有发布这个,但我有一个 Car.h 的模拟文件,它与测试本身位于同一文件夹中。
#ifndef __CAR_H
#define __CAR_H
#include "gmock/gmock.h"
#include <string>
using namespace std;
class Car
{
public:
MOCK_CONST_METHOD0(GetLicencePlate, string());
MOCK_METHOD0(Rent, bool());
MOCK_METHOD1(Return, double(int kilometers));
MOCK_METHOD0(Clean, void());
};
#endif
Edit1:按照建议,我尝试使用 Car* 的引用 (&)。
这消除了我上面提到的错误,但给我留下了一些其他错误:
error: cannot declare field ‘AdminTest::car’ to be of abstract type ‘Car’
Car car;
error: ‘class Car’ has no member named ‘gmock_GetLicencePlate’
car
是指向 Car
的指针。它的类型是:Car*
。为了从 Car*
调用 Car
成员,您必须取消引用指针。这是在使用 car->x
语法时自动完成的,相当于 (*car).x
.
我假设 EXPECT_CALL
需要一个非指针参数。因此,您可以获得对 car
的引用并将其传递给宏:
Car& car_ref = *car;
EXPECT_CALL(car_ref, GetLicencePlate()).WillOnce(Return("fh-01-ict"));
首先是指针问题,Vittorio 已经说过,但是,您还需要模拟 Car 对象才能使用 EXCEPT_CALL:
class MockCar : public Car{
// Here I assume that original method is const
MOCK_CONST_METHOD0(GetLicencePlate);
}
TEST(RentalAdministrationAdd, test_add_car_to_empty_administration)
{
RentalAdministration admin;
MockCar car;
EXPECT_CALL(car, GetLicencePlate()).WillOnce(Return("fh-01-ict"));
EXPECT_TRUE(admin.Add(&car));
}
你可以在我的例子中看到你没有使用真正的汽车对象,而是一个模拟汽车对象,你可以在其中控制访问和强制 return 值
我找到了解决方案。
对于任何想知道的人:在一个 class (RentalAdministration) 中,我包含了 cars
文件夹中的 Car.h
文件。 (喜欢#include "cars/Car.h"
)
但是,对于测试,应该使用不同的 Car.h
。因此,更改为 #include "Car.h"
使其工作。
我使用 gtest 和 gmock 进行了单元测试。
这些都提供了,轮到我让他们通过了。
我有一个 RentalAdministration 对象,它采用(在某些方法中)一个 Car 对象指针。其中一个函数如下所示:
bool RentalAdministration::Add(Car *car){
if(!car){
throw invalid_argument("Car parameter can't be null!");
}
if(FindCar(car->GetLicencePlate()) != NULL){
return false;
}
cars.push_back(car);
return true;
}
其中一个测试看起来像他的:
TEST(RentalAdministrationAdd, test_add_car_to_empty_administration)
{
RentalAdministration admin;
Car *car;
EXPECT_CALL(car, GetLicencePlate()).WillOnce(Return("fh-01-ict"));
EXPECT_TRUE(admin.Add(&car));
}
当我尝试进行这些测试时,我遇到了很多错误,所有这些都是相似的:
g++ -Wall -Werror -pedantic -ggdb -O0 -std=c++98 -Iproduct -Itest test/RentalAdministrationTest.cpp product/RentalAdministration.cpp -lgtest -lgmock -lgmock_main -lpthread -o RentalAdministrationTest
In file included from /usr/include/gmock/gmock-generated-function-mockers.h:43:0,
from /usr/include/gmock/gmock.h:61,
from test/RentalAdministrationTest.cpp:2:
test/RentalAdministrationTest.cpp: In member function ‘virtual void RentalAdministrationAdd_test_add_car_to_empty_administration_Test::TestBody()’:
test/RentalAdministrationTest.cpp:13:5: error: request for member ‘gmock_GetLicencePlate’ in ‘car’, which is of pointer type ‘Car*’ (maybe you meant to use ‘->’ ?)
EXPECT_CALL(car, GetLicencePlate()).WillOnce(Return("fh-01-ict"));
^
In file included from /usr/include/gtest/gtest.h:58:0,
from /usr/include/gmock/internal/gmock-internal-utils.h:47,
from /usr/include/gmock/gmock-actions.h:46,
from /usr/include/gmock/gmock.h:58,
from test/RentalAdministrationTest.cpp:2:
test/RentalAdministrationTest.cpp:14:31: error: no matching function for call to ‘RentalAdministration::Add(Car**)’
EXPECT_TRUE(admin.Add(&car));
^
我想知道我在这里做错了什么。我刚开始使用 C++。
顺便说一句:我正在用 g++ 编译并且有 98 版。
谢谢。
编辑:请原谅我没有发布这个,但我有一个 Car.h 的模拟文件,它与测试本身位于同一文件夹中。
#ifndef __CAR_H
#define __CAR_H
#include "gmock/gmock.h"
#include <string>
using namespace std;
class Car
{
public:
MOCK_CONST_METHOD0(GetLicencePlate, string());
MOCK_METHOD0(Rent, bool());
MOCK_METHOD1(Return, double(int kilometers));
MOCK_METHOD0(Clean, void());
};
#endif
Edit1:按照建议,我尝试使用 Car* 的引用 (&)。 这消除了我上面提到的错误,但给我留下了一些其他错误:
error: cannot declare field ‘AdminTest::car’ to be of abstract type ‘Car’
Car car;
error: ‘class Car’ has no member named ‘gmock_GetLicencePlate’
car
是指向 Car
的指针。它的类型是:Car*
。为了从 Car*
调用 Car
成员,您必须取消引用指针。这是在使用 car->x
语法时自动完成的,相当于 (*car).x
.
我假设 EXPECT_CALL
需要一个非指针参数。因此,您可以获得对 car
的引用并将其传递给宏:
Car& car_ref = *car;
EXPECT_CALL(car_ref, GetLicencePlate()).WillOnce(Return("fh-01-ict"));
首先是指针问题,Vittorio 已经说过,但是,您还需要模拟 Car 对象才能使用 EXCEPT_CALL:
class MockCar : public Car{
// Here I assume that original method is const
MOCK_CONST_METHOD0(GetLicencePlate);
}
TEST(RentalAdministrationAdd, test_add_car_to_empty_administration)
{
RentalAdministration admin;
MockCar car;
EXPECT_CALL(car, GetLicencePlate()).WillOnce(Return("fh-01-ict"));
EXPECT_TRUE(admin.Add(&car));
}
你可以在我的例子中看到你没有使用真正的汽车对象,而是一个模拟汽车对象,你可以在其中控制访问和强制 return 值
我找到了解决方案。
对于任何想知道的人:在一个 class (RentalAdministration) 中,我包含了 cars
文件夹中的 Car.h
文件。 (喜欢#include "cars/Car.h"
)
但是,对于测试,应该使用不同的 Car.h
。因此,更改为 #include "Car.h"
使其工作。