Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
#include "FWCore/PluginManager/interface/PluginManager.h"
#include "FWCore/PluginManager/interface/standard.h"
#include "FWCore/PluginManager/interface/SharedLibrary.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/ServiceRegistry/interface/ServiceRegistry.h"
//
#include "CondCore/CondDB/interface/ConnectionPool.h"
#include "CondCore/CondDB/interface/PayloadProxy.h"
//
#include "MyTestData.h"
//
#include <fstream>
#include <iomanip>
#include <cstdlib>
#include <iostream>

using namespace cond::persistency;

int run(const std::string& connectionString) {
  try {
    //*************
    std::cout << "> Connecting with db in " << connectionString << std::endl;
    ConnectionPool connPool;
    connPool.setMessageVerbosity(coral::Debug);
    Session session = connPool.createSession(connectionString, true);
    session.transaction().start(false);
    MyTestData d0(17);
    MyTestData d1(999);
    std::cout << "> Storing payload ptr=" << &d0 << std::endl;
    cond::Hash p0 = session.storePayload(d0, boost::posix_time::microsec_clock::universal_time());
    cond::Hash p1 = session.storePayload(d1, boost::posix_time::microsec_clock::universal_time());

    IOVEditor editor;
    if (!session.existsIov("MyNewIOV")) {
      editor = session.createIov<MyTestData>("MyNewIOV", cond::lumiid, cond::SYNCH_HLT);
      editor.setDescription("Test with MyTestData class");
      editor.insert(1, p0);
      editor.insert(cond::time::lumiTime(100, 11), p1);
      editor.insert(cond::time::lumiTime(100, 21), p0);
      editor.insert(cond::time::lumiTime(100, 31), p1);
      editor.insert(cond::time::lumiTime(200, 11), p1);
      editor.insert(cond::time::lumiTime(200, 21), p0);
      editor.insert(cond::time::lumiTime(200, 31), p1);
      editor.insert(cond::time::lumiTime(300, 11), p1);
      editor.insert(cond::time::lumiTime(300, 21), p0);
      editor.insert(cond::time::lumiTime(300, 31), p1);
      editor.insert(cond::time::lumiTime(400, 11), p0);
      editor.insert(cond::time::lumiTime(400, 12), p1);
      editor.insert(cond::time::lumiTime(400, 13), p0);
      std::cout << "> inserted iovs..." << std::endl;
      editor.flush();
      std::cout << "> iov changes flushed..." << std::endl;
    }

    session.transaction().commit();
    std::cout << "> iov changes committed!..." << std::endl;

    ::sleep(2);
    session.transaction().start();

    auto arr0 = session.readIov("MyNewIOV").selectAll();
    std::cout << "# Selecting all iovs..." << std::endl;
    for (auto iiov : arr0) {
      std::cout << "# since=" << iiov.since << " till:" << iiov.till << std::endl;
    }
    auto arr1 = session.readIov("MyNewIOV").selectRange(cond::time::lumiTime(100, 15), cond::time::lumiTime(300, 15));
    std::cout << "# Selecting range (" << cond::time::lumiTime(100, 15) << "," << cond::time::lumiTime(300, 15) << ")"
              << std::endl;
    for (auto iiov : arr1) {
      std::cout << "# since=" << iiov.since << " till:" << iiov.till << std::endl;
    }
    auto pxn = session.readIov("MyNewIOV");
    std::vector<cond::Time_t> inputTimes{10,
                                         cond::time::lumiTime(100, 15),
                                         cond::time::lumiTime(100, 25),
                                         cond::time::lumiTime(100, 35),
                                         cond::time::lumiTime(200, 15),
                                         cond::time::lumiTime(200, 25),
                                         cond::time::lumiTime(200, 35),
                                         cond::time::lumiTime(300, 15),
                                         cond::time::lumiTime(300, 25),
                                         cond::time::lumiTime(300, 35),
                                         cond::time::lumiTime(400, 11),
                                         cond::time::lumiTime(400, 12),
                                         cond::time::lumiTime(400, 13)};
    for (auto t : inputTimes) {
      cond::Iov_t iiov = pxn.getInterval(t);
      std::cout << "#Target=" << t << " since=" << iiov.since << " till:" << iiov.till << std::endl;
    }

    std::cout << "#Nqueries:" << pxn.numberOfQueries() << std::endl;

    session.transaction().commit();

    cond::Iov_t iov;
    auto requests = std::make_shared<std::vector<cond::Iov_t>>();
    PayloadProxy<MyTestData> ppn(&iov, &session, &requests);
    session.transaction().start(true);
    auto iovP = session.readIov("MyNewIOV");
    for (auto t : inputTimes) {
      iov = iovP.getInterval(t);
      ppn.initializeForNewIOV();
      ppn.make();
      std::cout << "PP: target=" << t << " since=" << iov.since << " till:" << iov.till << std::endl;
    }
    session.transaction().commit();

    std::cout << "#PP: nqueries:" << iovP.numberOfQueries() << std::endl;

  } catch (const std::exception& e) {
    std::cout << "ERROR: " << e.what() << std::endl;
    return -1;
  } catch (...) {
    std::cout << "UNEXPECTED FAILURE." << std::endl;
    return -1;
  }
  std::cout << "## Run successfully completed." << std::endl;
  return 0;
}

int main(int argc, char** argv) {
  int ret = 0;
  edmplugin::PluginManager::Config config;
  edmplugin::PluginManager::configure(edmplugin::standard::config());
  std::string connectionString0("sqlite_file:cms_conditions_3.db");
  ret = run(connectionString0);
  return ret;
}