Я пытаюсь протестировать некоторый исходный код с помощью cmocka.В основном (соответствующий) исходный код выглядит аналогично Source.c.
В модульном тесте каждая функция вызывается отдельно.При тестировании функции Add () эта функция в конечном итоге вызовет util_malloc () (эта функция обычно проверяет размер 0 перед malloc), который оборачивается модульным тестом.В завернутой функции __ wrap_util_malloc () в Wrappers.c сначала проверяется ожидаемый размер, после чего malloc используется для выделения памяти.
Далее Удалить() проверяется функция, при которой ранее выделенная память освобождается.
При запуске теста cmocka возвращается со следующими ошибками:
<failure><![CDATA[Blocks allocated... project_path/wrappers.c:46: note: block 00341e58 allocated here ERROR: Add_Test leaked 1 block(s) ]]></failure>
и
<failure><![CDATA[EXCEPTION_ACCESS_VIOLATION occurred at 004060af.
To debug in Visual Studio... [...]
]]></failure>
На данный момент я добавил Удалить() вызов в конце функции Add_Test () (и Add () в начале Remove_Test () ).Кажется, это решает проблему.Исходя из этого, следует освободить всю выделенную память в каждом отдельном модульном тесте.
Теперь мои вопросы:
- Можно ли использовать выделенную память в тестировании нескольких модулей?
- Как лучше всего решить эту проблему?
Source.c:
static ST_SOME_STRUCT GlobStruct;
void Add()
{
GlobStruct = util_malloc(sizeof(ST_SOME_STRUCT));
}
void Remove()
{
util_free(&GlobStruct);
}
void DoStuff()
{
//Do stuff using the global structure GlobStruct
}
Unit_test.c:
int main( int argc, char **argv )
{
const struct CMUnitTest Test[] =
{
cmocka_unit_test(Add_Test),
cmocka_unit_test(Remove_Test),
};
cmocka_set_message_output( CM_OUTPUT_XML );
return cmocka_run_group_tests( Test, NULL, NULL );
}
static void Add_Test (void** state)
{
expect_value(__wrap_util_malloc, size, sizeof(ST_SOME_STRUCT ));
Add();
}
static void Remove_Test (void** state)
{
expect_not_value(__wrap_util_free, memory, cast_ptr_to_largest_integral_type(NULL));
Remove();
}
Wrappers.c:
void *__wrap_util_malloc(int size)
{
check_expected(size);
return malloc(size);
}
void __wrap_util_free(void *memory)
{
check_expected_ptr(memory);
free(memory);
}