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
|
#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 "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);
std::string d0("abcd1234");
std::string d1("abcdefghil");
cond::Hash p0 = session.storePayload(d0, boost::posix_time::microsec_clock::universal_time());
cond::Hash p1 = session.storePayload(d0, boost::posix_time::microsec_clock::universal_time());
IOVEditor editor;
if (!session.existsIov("StringData")) {
editor = session.createIov<std::string>("StringData", cond::timestamp);
editor.setDescription("Test with std::string class");
editor.insert(1000000, p0);
editor.insert(2000000, p1);
editor.flush();
}
session.transaction().commit();
std::cout << "> iov changes committed!..." << std::endl;
session.transaction().start();
IOVProxy proxy = session.readIov("StringData");
auto iovs = proxy.selectAll();
session.transaction().commit();
std::cout << "(0) Found " << iovs.size() << " iovs." << std::endl;
for (auto iov : iovs) {
std::cout << "Iov since " << iov.since << " hash " << iov.payloadId << std::endl;
}
session.transaction().start(false);
cond::Hash p3 = session.storePayload(std::string("013456789"), boost::posix_time::microsec_clock::universal_time());
editor = session.editIov("StringData");
editor.insert(3000000, p3);
editor.erase(2000000, p1);
editor.flush();
std::cout << "2nd iovs changes completed." << std::endl;
session.transaction().commit();
::sleep(2);
session.transaction().start();
proxy = session.readIov("StringData");
iovs = proxy.selectAll();
session.transaction().commit();
std::cout << "(1) Found " << iovs.size() << " iovs." << std::endl;
for (auto iov : iovs) {
std::cout << "Iov since " << iov.since << " hash " << iov.payloadId << 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_4.db");
ret = run(connectionString0);
return ret;
}
|