/**************************************************************************** ** gmio ** Copyright Fougue (2 Mar. 2015) ** contact@fougue.pro ** ** This software is a reusable library whose purpose is to provide complete ** I/O support for various CAD file formats (eg. STL) ** ** This software is governed by the CeCILL-B license under French law and ** abiding by the rules of distribution of free software. You can use, ** modify and/ or redistribute the software under the terms of the CeCILL-B ** license as circulated by CEA, CNRS and INRIA at the following URL ** "http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html". ****************************************************************************/ #include "utest_assert.h" #include "../src/gmio_core/memblock.h" #include "../src/gmio_core/endian.h" #include "../src/gmio_core/error.h" #include "../src/gmio_core/stream.h" #include #include static struct gmio_memblock buffer_ctor() { return gmio_memblock_calloc(4, 256); } const char* test_core__buffer() { /* gmio_memblock_calloc() */ { const size_t obj_count = 4; const size_t obj_size = 256; const size_t buff_size = obj_count * obj_size; const uint8_t zero_buff[4 * 256] = {0}; struct gmio_memblock buff = gmio_memblock_calloc(obj_count, obj_size); UTEST_ASSERT(buff.ptr != NULL); UTEST_ASSERT(buff.size == buff_size); UTEST_ASSERT(memcmp(buff.ptr, &zero_buff[0], buff_size) == 0); /* TODO: make assert succeed with mingw and GMIO_BUILD_SHARED_LIBS=ON * In this case free() has not the same address in libgmio.dll and * test_core.exe */ UTEST_ASSERT(buff.func_deallocate == &free); gmio_memblock_deallocate(&buff); } /* gmio_memblock_malloc() */ { const size_t buff_size = 2 * 1024; /* 2KB */ struct gmio_memblock buff = gmio_memblock_malloc(buff_size); UTEST_ASSERT(buff.ptr != NULL); UTEST_ASSERT(buff.size == buff_size); UTEST_ASSERT(buff.func_deallocate == &free); gmio_memblock_deallocate(&buff); } /* gmio_memblock_realloc() */ { const size_t buff_size = 1024; /* 1KB */ struct gmio_memblock buff = gmio_memblock_malloc(buff_size); buff = gmio_memblock_realloc(buff.ptr, 2 * buff_size); UTEST_ASSERT(buff.ptr != NULL); UTEST_ASSERT(buff.size == (2 * buff_size)); UTEST_ASSERT(buff.func_deallocate == &free); gmio_memblock_deallocate(&buff); } /* default ctor */ { UTEST_ASSERT(gmio_memblock_default_constructor() != NULL); gmio_memblock_set_default_constructor(&buffer_ctor); UTEST_ASSERT(gmio_memblock_default_constructor() == &buffer_ctor); } return NULL; } const char* test_core__endian() { UTEST_ASSERT(gmio_host_endianness() == GMIO_ENDIANNESS_HOST); GMIO_PRAGMA_MSVC_WARNING_PUSH_AND_DISABLE(4127) UTEST_ASSERT(GMIO_ENDIANNESS_LITTLE != GMIO_ENDIANNESS_BIG); UTEST_ASSERT(GMIO_ENDIANNESS_HOST == GMIO_ENDIANNESS_LITTLE || GMIO_ENDIANNESS_HOST == GMIO_ENDIANNESS_BIG); GMIO_PRAGMA_MSVC_WARNING_POP() return NULL; } const char* test_core__error() { UTEST_ASSERT(gmio_no_error(GMIO_ERROR_OK)); UTEST_ASSERT(!gmio_error(GMIO_ERROR_OK)); UTEST_ASSERT(!gmio_no_error(GMIO_ERROR_UNKNOWN)); UTEST_ASSERT(gmio_error(GMIO_ERROR_UNKNOWN)); return NULL; } const char* test_core__stream() { { const struct gmio_stream null_stream = gmio_stream_null(); const uint8_t null_bytes[sizeof(struct gmio_stream)] = {0}; UTEST_ASSERT(memcmp(&null_stream, &null_bytes, sizeof(struct gmio_stream)) == 0); } return NULL; }