From 9119e2b9bbb11b4ae21618fbaacfe6edaeb2a62b Mon Sep 17 00:00:00 2001 From: Gabriele Contini <contini.mailing@gmail.com> Date: 周六, 15 2月 2020 23:49:50 +0800 Subject: [PATCH] pc identifiers work --- test/functional/standard-license_test.cpp | 112 ++++++++++++++++++++++++++++++++++++++----------------- 1 files changed, 77 insertions(+), 35 deletions(-) diff --git a/test/functional/standard-license_test.cpp b/test/functional/standard-license_test.cpp index dc24a98..8bb45b1 100644 --- a/test/functional/standard-license_test.cpp +++ b/test/functional/standard-license_test.cpp @@ -1,49 +1,91 @@ -#define BOOST_TEST_MODULE standard_license_test -//#define BOOST_TEST_MAIN -#define BOOST_TEST_DYN_LINK +#define BOOST_TEST_MODULE test_standard_license + #include <boost/test/unit_test.hpp> -#include "../../../src/license-generator/license-generator.h" -#include "../../../src/library/api/license++.h" -#include <build_properties.h> #include <boost/filesystem.hpp> -#include "../../src/library/reader/SimpleIni.h" +#include <licensecc/licensecc.h> +#include <licensecc_properties_test.h> +#include <licensecc_properties.h> -namespace fs = boost::filesystem; -using namespace license; +#include "../../src/library/ini/SimpleIni.h" +#include "generate-license.h" +#include "../../src/library/base/FileUtils.hpp" + using namespace std; +namespace fs = boost::filesystem; -void generate_license(const string& prod_name, const string& fname) { - int argc = 4; - const char** argv = new const char*[argc + 1]; - argv[0] = "lic-generator"; - argv[1] = "-o"; - argv[2] = fname.c_str(); - argv[3] = "test"; - int retCode = LicenseGenerator::generateLicense(argc, argv); - delete (argv); - BOOST_CHECK_EQUAL(retCode, 0); - BOOST_ASSERT(fs::exists(fname)); - CSimpleIniA ini; - SI_Error rc = ini.LoadFile(fname.c_str()); - BOOST_CHECK_GE(rc,0); - int sectionSize = ini.GetSectionSize(prod_name.c_str()); - BOOST_CHECK_GT(sectionSize,0); -} +namespace license { +namespace test { -BOOST_AUTO_TEST_CASE( standard_lic_file ) { - const string licLocation(PROJECT_TEST_TEMP_DIR "/standard_license.lic"); - generate_license(string("TEST"), licLocation); +/** + * Test a generic license with no expiry neither client id. The license is read from file + */ +BOOST_AUTO_TEST_CASE(test_generic_license_read_file) { + const vector<string> extraArgs; + const string licLocation = generate_license("standard_license", extraArgs); /* */ LicenseInfo license; - LicenseLocation licenseLocation; - licenseLocation.openFileNearModule=false; - licenseLocation.licenseFileLocation = licLocation.c_str(); - licenseLocation.environmentVariableName = ""; - 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, false); } +/** + * Test a generic license with no expiry neither client id. The license is passed in trhough the licenseData structure. + */ +BOOST_AUTO_TEST_CASE(test_read_license_data) { + const vector<string> extraArgs; + const fs::path licLocation = fs::path(generate_license("standard_license1", extraArgs)); + string license_data; + // load the license string + fs::load_string_file(licLocation, license_data); + LicenseInfo license; + LicenseLocation location = {LICENSE_PLAIN_DATA}; + std::copy(license_data.begin(), license_data.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, false); +} + +/** + * Pass the license data to the application. + */ + +// BOOST_AUTO_TEST_CASE( b64_environment_variable ) { +// const string licLocation(PROJECT_TEST_TEMP_DIR "/standard_env_license.lic"); +// const vector<string> extraArgs; +// generate_license(licLocation, extraArgs); +// const string licensestr(license::get_file_contents(licLocation.c_str(), MAX_LICENSE_LENGTH)); +// /* */ +// LicenseInfo license; +// LicenseLocation licenseLocation; +// licenseLocation.licenseFileLocation = nullptr; +// licenseLocation.licenseData = licensestr.c_str(); +// const EVENT_TYPE result = acquire_license("TEST", &licenseLocation, +// &license); +// BOOST_CHECK_EQUAL(result, LICENSE_OK); +// BOOST_CHECK_EQUAL(license.has_expiry, false); +// BOOST_CHECK_EQUAL(license.linked_to_pc, false); +//} +// +// BOOST_AUTO_TEST_CASE( hw_identifier ) { +// const string licLocation(PROJECT_TEST_TEMP_DIR "/hw_identifier.lic"); +// const vector<string> extraArgs = { "-s", "Jaaa-aaaa-MG9F-ZhB1" }; +// generate_license(licLocation, extraArgs); +// +// LicenseInfo license; +// LicenseLocation licenseLocation; +// licenseLocation.licenseFileLocation = licLocation.c_str(); +// licenseLocation.licenseData = ""; +// const EVENT_TYPE result = acquire_license("TEST", &licenseLocation, +// &license); +// BOOST_CHECK_EQUAL(result, IDENTIFIERS_MISMATCH); +// BOOST_CHECK_EQUAL(license.has_expiry, false); +// BOOST_CHECK_EQUAL(license.linked_to_pc, true); +//} +} +} // namespace license -- Gitblit v1.9.1