From 8e1bdfdca2ad2157fd74cedc1a6768a1b1c0849d Mon Sep 17 00:00:00 2001 From: gcontini <1121667+gcontini@users.noreply.github.com> Date: 周日, 09 2月 2020 04:48:55 +0800 Subject: [PATCH] identifiers next work --- test/library/Os_Linux_test.cpp | 91 +++++++++++++++++++++++++-------------------- 1 files changed, 51 insertions(+), 40 deletions(-) diff --git a/test/library/Os_Linux_test.cpp b/test/library/Os_Linux_test.cpp index 01b25ff..21e94e0 100644 --- a/test/library/Os_Linux_test.cpp +++ b/test/library/Os_Linux_test.cpp @@ -1,50 +1,61 @@ #define BOOST_TEST_MODULE os_linux_test -//#define BOOST_TEST_MAIN -//#define BOOST_TEST_DYN_LINK -#include <boost/test/unit_test.hpp> -#include "../../src/library/os/os.h" -#include <build_properties.h> - #include <string> #include <iostream> -using namespace std; +#include <boost/test/unit_test.hpp> -BOOST_AUTO_TEST_CASE( read_disk_id ) { - DiskInfo * diskInfos = NULL; - size_t disk_info_size = 0; - FUNCTION_RETURN result = getDiskInfos(NULL, &disk_info_size); - BOOST_CHECK_EQUAL(result, FUNC_RET_OK); - BOOST_CHECK_GT(disk_info_size, 0); - diskInfos = (DiskInfo*) malloc(sizeof(DiskInfo) * disk_info_size); - result = getDiskInfos(diskInfos, &disk_info_size); - BOOST_CHECK_EQUAL(result, FUNC_RET_OK); - BOOST_CHECK_GT(strlen(diskInfos[0].device), 0); - BOOST_CHECK_GT(strlen(diskInfos[0].label), 0); - BOOST_CHECK_GT(diskInfos[0].disk_sn[0], 0); - free(diskInfos); +#include <licensecc_properties.h> +#include <licensecc_properties_test.h> +#include "../../src/library/base/StringUtils.h" +#include "../../src/library/os/os.h" +#include "../../src/library/os/execution_environment.hpp" + +namespace license { +using namespace std; +namespace test { + +BOOST_AUTO_TEST_CASE(read_disk_id) { + ExecutionEnvironment exec_env; + VIRTUALIZATION virt = exec_env.getVirtualization(); + if (virt == NONE || virt == VM) { + DiskInfo *diskInfos = NULL; + size_t disk_info_size = 0; + FUNCTION_RETURN result = getDiskInfos(NULL, &disk_info_size); + BOOST_CHECK_EQUAL(result, FUNC_RET_OK); + BOOST_CHECK_GT(disk_info_size, 0); + diskInfos = (DiskInfo *)malloc(sizeof(DiskInfo) * disk_info_size); + result = getDiskInfos(diskInfos, &disk_info_size); + BOOST_CHECK_EQUAL(result, FUNC_RET_OK); + BOOST_CHECK_GT(mstrnlen_s(diskInfos[0].device, sizeof(diskInfos[0].device)), 0); + BOOST_CHECK_GT(mstrnlen_s(diskInfos[0].label, sizeof diskInfos[0].label), 0); + BOOST_CHECK_GT(diskInfos[0].disk_sn[0], 0); + free(diskInfos); + } else if (virt == CONTAINER) { + // docker or lxc diskInfo is not meaningful + DiskInfo *diskInfos = NULL; + size_t disk_info_size = 0; + FUNCTION_RETURN result = getDiskInfos(NULL, &disk_info_size); + BOOST_CHECK_EQUAL(result, FUNC_RET_NOT_AVAIL); + } } -BOOST_AUTO_TEST_CASE( read_network_adapters ) { - AdapterInfo * adapter_info = NULL; - size_t adapter_info_size = 0; - FUNCTION_RETURN result = getAdapterInfos(NULL, &adapter_info_size); - BOOST_CHECK_EQUAL(result, FUNC_RET_OK); - BOOST_CHECK_GT(adapter_info_size, 0); - adapter_info = (AdapterInfo*) malloc( - sizeof(AdapterInfo) * adapter_info_size); - result = getAdapterInfos(adapter_info, &adapter_info_size); - BOOST_CHECK_EQUAL(result, FUNC_RET_OK); - for (size_t i = 0; i < adapter_info_size; i++) { - cout << "Interface found: " << string(adapter_info[i].description) - << endl; - BOOST_CHECK_GT(strlen(adapter_info[i].description), 0); - //lo mac address is always 0 but it has ip - //other interfaces may not be connected - if (string(adapter_info[i].description) == "lo") { - BOOST_CHECK_NE(adapter_info[i].ipv4_address[0], 0); +// To test if virtualization is detected correctly define an env variable VIRT_ENV +// otherwise the test is skipped +BOOST_AUTO_TEST_CASE(test_virtualization) { + const char *env = getenv("VIRT_ENV"); + ExecutionEnvironment exec_env; + if (env != NULL) { + if (strcmp(env, "CONTAINER") == 0) { + VIRTUALIZATION virt = exec_env.getVirtualization(); + BOOST_CHECK_MESSAGE(virt == CONTAINER, "container detected"); + } else if (strcmp(env, "VM") == 0) { + BOOST_FAIL("check for vm not implemented"); + } else if (strcmp(env, "NONE") == 0) { + VIRTUALIZATION virt = exec_env.getVirtualization(); + BOOST_CHECK_EQUAL(virt, NONE); } else { - BOOST_CHECK_NE(adapter_info[i].mac_address[0], 0); + BOOST_FAIL(string("value ") + env + " not supported: VM,CONTAINER,NONE"); } } - free(adapter_info); } +} // namespace test +} // namespace license -- Gitblit v1.9.1