Gabriele Contini
2019-09-07 fcd903b7461ed8021b420b9581e989756d21c2b6
test/functional/volid_test.cpp
@@ -25,11 +25,13 @@
   BOOST_TEST_CHECKPOINT("Before generate");
   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;
   vector<string> extraArgs;
    extraArgs.push_back("-s");
    extraArgs.push_back(identifier_out);
   BOOST_TEST_CHECKPOINT("Before generate license");
   generate_license(licLocation, extraArgs);
   LicenseInfo license;
@@ -52,10 +54,10 @@
            strategies[i]);
        BOOST_ASSERT(generate_ok == 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);
            idfile << "0000-0000-0000-0000" << endl;
      }
        else
      } else
            idfile << identifier_out << endl;
   }
   idfile.close();
@@ -63,41 +65,46 @@
BOOST_AUTO_TEST_CASE(generated_identifiers_stability) {
   const string idfileLocation(PROJECT_TEST_TEMP_DIR "/identifiers_file");
   IDENTIFICATION_STRATEGY strategies[] =
         { DEFAULT,
               DISK_LABEL,
               DISK_NUM,
               ETHERNET };
   const int num_strategies = sizeof(strategies) / sizeof(strategies[0]);
   std::vector<IDENTIFICATION_STRATEGY> strategies;
   if (getVirtualization() != CONTAINER) {
      strategies = { DEFAULT, DISK_LABEL, DISK_NUM, ETHERNET };
   } else {
      strategies = { DEFAULT, ETHERNET };
   }
   int num_strategies = strategies.size();
   std::ifstream test_idfile_exist(idfileLocation);
    if (!test_idfile_exist.good()){
        generate_reference_file(idfileLocation, strategies, num_strategies);
    }
    else{
      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())
            generate_reference_file(idfileLocation, strategies, num_strategies);
      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]);
      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: ["
               + to_string(static_cast<long long>(strategies[i]))
               + " generated: [" + generated_identifier + "] reference: ["
               + reference_signatures[i] + "]";
         BOOST_ERROR(message);
      }