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;
}
|