Szukałem już długo na rozwiązanie pozornie starszych c-funkcji z googleMock bez zmiany istniejącego kodu i ostatnie dni znalazłem następujący naprawdę świetny artykuł: https://www.codeproject.com/articles/1040972/using-googletest-and-googlemock-frameworks-for-emb
Dzisiaj pisałam testu pierwszej jednostki do c-funkcje za pomocą gmock i wziął jako przykład dwie funkcje z biblioteki bcm2835.c (http://www.airspayce.com/mikem/bcm2835/) dla programowania raspberry Pi: Oto moje rozwiązanie: Używam gcc 4.8.3. w Eclipse i Windows. Bądź świadomy ustawienia opcji kompilatora -std = gnu ++ 11.
Oto moje funkcje mają być testowane
int inits(void);
void pinMode(uint8_t pin, uint8_t mode);
int inits(){
return bcm2835_init();
}
void pinMode(uint8_t pin, uint8_t mode){
bcm2835_gpio_fsel(pin, mode);
}
Zawiera oraz definiuje dla testów jednostkowych z funkcjami googleTest/googleMock
// MOCKING C-Functions with GMOCK :)
#include <memory>
#include "gtest/gtest.h"
#include "gmock/gmock.h"
using namespace ::testing;
using ::testing::Return;
Mock BCM2835Lib
class BCM2835Lib_MOCK{
public:
virtual ~BCM2835Lib_MOCK(){}
// mock methods
MOCK_METHOD0(bcm2835_init,int());
MOCK_METHOD2(bcm2835_gpio_fsel,void(uint8_t,uint8_t));
};
Tworzenie TestFixture
class TestFixture: public ::testing::Test{
public:
TestFixture(){
_bcm2835libMock.reset(new ::testing::NiceMock<BCM2835Lib_MOCK>());
}
~TestFixture(){
_bcm2835libMock.reset();
}
virtual void SetUp(){}
virtual void TearDown(){}
// pointer for accessing mocked library
static std::unique_ptr<BCM2835Lib_MOCK> _bcm2835libMock;
};
Instantiate szydzili funkcje lib
// instantiate mocked lib
std::unique_ptr<BCM2835Lib_MOCK> TestFixture::_bcm2835libMock;
Sztuczne funkcje lib połączyć Mocks z C-funkcje
// fake lib functions
int bcm2835_init(){return TestFixture::_bcm2835libMock->bcm2835_init();}
void bcm2835_gpio_fsel(uint8_t pin, uint8_t mode){TestFixture::_bcm2835libMock->bcm2835_gpio_fsel(pin,mode);}
Tworzenie klasy testów jednostkowych dla BCM2835 z TestFixture
// create unit testing class for BCM2835 from TestFixture
class BCM2835LibUnitTest : public TestFixture{
public:
BCM2835LibUnitTest(){
// here you can put some initializations
}
};
Napisz do badania przy użyciu googleTest i googleMock
TEST_F(BCM2835LibUnitTest,inits){
EXPECT_CALL(*_bcm2835libMock,bcm2835_init()).Times(1).WillOnce(Return(1));
EXPECT_EQ(1,inits()) << "init must return 1";
}
TEST_F(BCM2835LibUnitTest,pinModeTest){
EXPECT_CALL(*_bcm2835libMock,bcm2835_gpio_fsel((uint8_t)RPI_V2_GPIO_P1_18
,(uint8_t)BCM2835_GPIO_FSEL_OUTP
)
)
.Times(1)
;
pinMode((uint8_t)RPI_V2_GPIO_P1_18,(uint8_t)BCM2835_GPIO_FSEL_OUTP);
}
rezultaty :)
[----------] 2 tests from BCM2835LibUnitTest
[ RUN ] BCM2835LibUnitTest.inits
[ OK ] BCM2835LibUnitTest.inits (0 ms)
[ RUN ] BCM2835LibUnitTest.pinModeTest
[ OK ] BCM2835LibUnitTest.pinModeTest (0 ms)
[----------] 2 tests from BCM2835LibUnitTest (0 ms total)
nadzieję, że pomoże:) - dla mnie to naprawdę działające rozwiązanie.
Czy funkcja "func_1()" również jest funkcją "C"? –
@OldFox Tak, jest to funkcja C. – user3159610
Czy 'func_1()' zawiera złożony scenariusz lub używa niezrównanej zależności? (Na przykład sprzęt) –