From 95d1452eefadffaf1ec75dd0a8336bc2c387eb17 Mon Sep 17 00:00:00 2001 From: gcontini <1121667+gcontini@users.noreply.github.com> Date: 周六, 01 2月 2020 02:48:51 +0800 Subject: [PATCH] rename enums and further developments --- test/functional/volid_test.cpp | 109 +++++++++++++++++++++++++++++------------------------- 1 files changed, 58 insertions(+), 51 deletions(-) diff --git a/test/functional/volid_test.cpp b/test/functional/volid_test.cpp index f63d2b3..14144df 100644 --- a/test/functional/volid_test.cpp +++ b/test/functional/volid_test.cpp @@ -1,30 +1,33 @@ -#define BOOST_TEST_MODULE standard_license_test -//#define BOOST_TEST_MAIN -//#undef BOOST_TEST_DYN_LINK +#define BOOST_TEST_MODULE test_volid + #include <boost/test/unit_test.hpp> #include <fstream> +#include <iostream> #include <stdio.h> #include <cstring> -#include "../../src/tools/license-generator/license-generator.h" -#include "../../src/library/api/license++.h" -#include <build_properties.h> #include <boost/filesystem.hpp> +#include <licensecc_properties.h> +#include <licensecc_properties_test.h> + +#include <licensecc/licensecc.h> #include "../../src/library/ini/SimpleIni.h" -#include "generate-license.h" #include "../../src/library/pc-identifiers.h" +#include "../../src/library/os/os.h" +#include "generate-license.h" namespace fs = boost::filesystem; using namespace license; using namespace std; -BOOST_AUTO_TEST_CASE( default_volid_lic_file ) { - const string licLocation(PROJECT_TEST_TEMP_DIR "/volid_license.lic"); +namespace license { +namespace test { + +BOOST_AUTO_TEST_CASE(default_volid_lic_file) { PcSignature identifier_out; - const IDENTIFICATION_STRATEGY strategy = IDENTIFICATION_STRATEGY::ETHERNET; + const LCC_API_IDENTIFICATION_STRATEGY strategy = LCC_API_IDENTIFICATION_STRATEGY::STRATEGY_ETHERNET; BOOST_TEST_CHECKPOINT("Before generate"); - const FUNCTION_RETURN generate_ok = generate_user_pc_signature(identifier_out, - strategy); + const FUNCTION_RETURN generate_ok = generate_user_pc_signature(identifier_out, strategy); BOOST_TEST_CHECKPOINT("After generate signature"); BOOST_ASSERT(generate_ok == FUNCTION_RETURN::FUNC_RET_OK); cout << "Identifier:" << identifier_out << endl; @@ -32,31 +35,27 @@ extraArgs.push_back("-s"); extraArgs.push_back(identifier_out); BOOST_TEST_CHECKPOINT("Before generate license"); - generate_license(licLocation, extraArgs); + const string licLocation = generate_license("volid_license", extraArgs); LicenseInfo license; - LicenseLocation licenseLocation; - licenseLocation.openFileNearModule = false; - licenseLocation.licenseFileLocation = licLocation.c_str(); - licenseLocation.environmentVariableName = ""; - const EVENT_TYPE result = acquire_license("TEST", licenseLocation, &license); + LicenseLocation location = {LICENSE_PATH}; + std::copy(licLocation.begin(), licLocation.end(), location.licenseData); + const LCC_EVENT_TYPE result = acquire_license(nullptr, &location, &license); BOOST_CHECK_EQUAL(result, LICENSE_OK); BOOST_CHECK_EQUAL(license.has_expiry, false); BOOST_CHECK_EQUAL(license.linked_to_pc, true); } -static void generate_reference_file(const string &idfileLocation, - IDENTIFICATION_STRATEGY strategies[], int num_strategies) { +static void generate_reference_file(const string &idfileLocation, LCC_API_IDENTIFICATION_STRATEGY strategies[], + int num_strategies) { ofstream idfile(idfileLocation); PcSignature identifier_out; for (int i = 0; i < num_strategies; i++) { - FUNCTION_RETURN generate_ok = generate_user_pc_signature(identifier_out, - strategies[i]); - BOOST_ASSERT(generate_ok == FUNC_RET_OK); + FUNCTION_RETURN generate_ok = generate_user_pc_signature(identifier_out, strategies[i]); if (generate_ok != FUNC_RET_OK) { - BOOST_ERROR( - "Generating identifier for strategy " << strategies[i] << " failed with: " << generate_ok); + BOOST_ERROR("Generating identifier for strategy " << strategies[i] << " failed with: " << generate_ok); idfile << "0000-0000-0000-0000" << endl; + BOOST_ASSERT(generate_ok == FUNC_RET_OK); } else idfile << identifier_out << endl; } @@ -65,62 +64,70 @@ BOOST_AUTO_TEST_CASE(generated_identifiers_stability) { const string idfileLocation(PROJECT_TEST_TEMP_DIR "/identifiers_file"); - std::vector<IDENTIFICATION_STRATEGY> strategies; - if (getVirtualization() != CONTAINER) { - strategies = { DEFAULT, DISK_LABEL, DISK_NUM, ETHERNET }; + std::vector<LCC_API_IDENTIFICATION_STRATEGY> strategies; + size_t disk_num; + getDiskInfos(NULL, &disk_num); + if (disk_num > 0) { + strategies = {STRATEGY_DEFAULT, STRATEGY_DISK_NUM, STRATEGY_DISK_LABEL}; } else { - strategies = { DEFAULT, ETHERNET }; + BOOST_TEST_CHECKPOINT("if no disk default strategy fails see #49"); + // strategies = { DEFAULT }; + strategies = {}; } - int num_strategies = strategies.size(); + size_t adapters; + getAdapterInfos(nullptr, &adapters); + if (adapters > 0) { + strategies.push_back(STRATEGY_ETHERNET); + } + + size_t num_strategies = strategies.size(); + if (num_strategies == 0) { + // see issue #49 can't use default + return; + } std::ifstream test_idfile_exist(idfileLocation); if (!test_idfile_exist.good()) { - generate_reference_file(idfileLocation, strategies.data(), - strategies.size()); + generate_reference_file(idfileLocation, strategies.data(), strategies.size()); } else { std::istream_iterator<string> start(test_idfile_exist), end; std::vector<string> reference_signatures(start, end); test_idfile_exist.close(); - if (reference_signatures.size() != num_strategies - || std::find(reference_signatures.begin(), - reference_signatures.end(), "0000-0000-0000-0000") - != reference_signatures.end()) + if (reference_signatures.size() != num_strategies || + std::find(reference_signatures.begin(), reference_signatures.end(), "0000-0000-0000-0000") != + reference_signatures.end()) generate_reference_file(idfileLocation, strategies.data(), num_strategies); } std::ifstream is(idfileLocation); std::istream_iterator<string> start(is), end; std::vector<string> reference_signatures(start, end); - BOOST_TEST_CHECKPOINT( - "Generating current signatures and comparing with past"); + BOOST_TEST_CHECKPOINT("Generating current signatures and comparing with past"); for (int i = 0; i < num_strategies; i++) { PcSignature generated_identifier; - FUNCTION_RETURN generate_ok = generate_user_pc_signature( - generated_identifier, strategies[i]); + FUNCTION_RETURN generate_ok = generate_user_pc_signature(generated_identifier, strategies[i]); BOOST_ASSERT(generate_ok == FUNCTION_RETURN::FUNC_RET_OK); if (generate_ok != FUNC_RET_OK) { - BOOST_ERROR( - "Generating identifier for strategy " << strategies[i] << " failed with: " << generate_ok); + BOOST_ERROR("Generating identifier for strategy " << strategies[i] << " failed with: " << generate_ok); continue; } if (reference_signatures[i] != generated_identifier) { - string message = string("pc signature compare fail: strategy: ") - + to_string(static_cast<long long>(strategies[i])) - + " generated: [" + generated_identifier + "] reference: [" - + reference_signatures[i] + "]"; + string message = string("pc signature compare fail: strategy: ") + + to_string(static_cast<long long>(strategies[i])) + " generated: [" + generated_identifier + + "] reference: [" + reference_signatures[i] + "]"; BOOST_ERROR(message); } } BOOST_TEST_CHECKPOINT("Verifying signatures"); for (int j = 0; j < 100; j++) { for (unsigned int i = 0; i < reference_signatures.size(); i++) { - if (reference_signatures[i] == "0000-0000-0000-0000") - continue; + if (reference_signatures[i] == "0000-0000-0000-0000") continue; PcSignature pcsig; - strncpy(pcsig, reference_signatures[i].c_str(), - sizeof(PcSignature) - 1); - EVENT_TYPE val_result = validate_pc_signature(pcsig); + strncpy(pcsig, reference_signatures[i].c_str(), sizeof(PcSignature) - 1); + LCC_EVENT_TYPE val_result = validate_pc_signature(pcsig); BOOST_TEST_CHECKPOINT("Verifying signature: "); BOOST_CHECK_EQUAL(val_result, LICENSE_OK); } } } +} // namespace test +} // namespace license -- Gitblit v1.9.1