gcontini
2020-01-01 9d7cd404cc2d09c82b65be4828be0ac74eca20a7
test/functional/volid_test.cpp
@@ -27,8 +27,7 @@
   const IDENTIFICATION_STRATEGY strategy = 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;
@@ -39,25 +38,22 @@
   const string licLocation = generate_license("volid_license", extraArgs);
   LicenseInfo license;
   LicenseLocation licenseLocation;
   licenseLocation.licenseFileLocation = licLocation.c_str();
   licenseLocation.licenseData = "";
   const EVENT_TYPE result = acquire_license(nullptr, &licenseLocation, &license);
   LicenseLocation location = {LICENSE_PATH};
   std::copy(licLocation.begin(), licLocation.end(), location.licenseData);
   const 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, 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]);
      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
@@ -91,49 +87,41 @@
   }
   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);
         strncpy(pcsig, reference_signatures[i].c_str(), sizeof(PcSignature) - 1);
         EVENT_TYPE val_result = validate_pc_signature(pcsig);
         BOOST_TEST_CHECKPOINT("Verifying signature: ");
         BOOST_CHECK_EQUAL(val_result, LICENSE_OK);