Ответ 1
Вы можете изменить класс B в шаблон:
template< typename T >
class B
{
public:
static int Method2(int a, int b){ return T::Method1(a,b);}
};
а затем создайте макет:
struct MockA
{
static MockCalc *mock;
static int Method2(int a, int b){ return mock->Method1(a,b);}
};
class MockCalc {
public:
MOCK_METHOD2(Method1, int(int,int));
};
Перед каждым испытанием инициализируйте статический макет-объект MockA::mock
.
Другой вариант - вместо прямого вызова A::Method1
создать объект-функтор (возможно, std:: function type) в классе B и вызвать его в Method2. Тогда это проще, потому что вам не понадобится MockA, потому что вы создадите обратный вызов MockCalc:: Method1 для этого объекта. Что-то вроде этого:
class B
{
public:
static std::function< int(int,int) > f;
static int Method2(int a, int b){ return f(a,b);}
};
class MockCalc {
public:
MOCK_METHOD2(Method1, int(int,int));
};
и инициализировать его:
MockCalc mock;
B::f = [&mock](int a,int b){return mock.Method1(a,b);};