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
#!/bin/bash -ex

inputfile=$(edmFileInPath CondTools/Hcal/data/hcalpfcuts.txt)
cat << \EOF > temp_pfcuts_to_db.py

import FWCore.ParameterSet.Config as cms
from Configuration.StandardSequences.Eras import eras

process = cms.Process("TODB",eras.Run3)
process.load("CondCore.CondDB.CondDB_cfi")

process.load("Configuration.StandardSequences.GeometryDB_cff")
process.load("Configuration.StandardSequences.FrontierConditions_GlobalTag_cff")
from Configuration.AlCa.autoCond import autoCond
process.GlobalTag.globaltag = autoCond["phase1_2022_realistic"] 

process.load('Configuration.StandardSequences.Services_cff')
process.load("CondCore.CondDB.CondDB_cfi")
process.CondDB.connect = "sqlite_file:HcalPFCuts_V00_test.db"

process.maxEvents = cms.untracked.PSet(
    input = cms.untracked.int32(1)
)

process.source = cms.Source("EmptySource",
    numberEventsInRun = cms.untracked.uint32(1),
    firstRun = cms.untracked.uint32(1)
)

process.es_ascii = cms.ESSource("HcalTextCalibrations",
   input = cms.VPSet(
       cms.PSet(
           object = cms.string("PFCuts"),
           file = cms.FileInPath("CondTools/Hcal/data/hcalpfcuts.txt")
      )
   )
)
process.es_prefer = cms.ESPrefer('HcalTextCalibrations','es_ascii')

process.PoolDBOutputService = cms.Service(
    "PoolDBOutputService",
    process.CondDB,
    timetype = cms.untracked.string('runnumber'),
    toPut = cms.VPSet(cms.PSet(
        record = cms.string("HcalPFCutsRcd"),
        tag = cms.string("HcalPFCuts_test_tag")
    ))
)

process.mytest = cms.EDAnalyzer("HcalPFCutsPopConAnalyzer",
    record = cms.string('HcalPFCutsRcd'),
    loggingOn = cms.untracked.bool(True),
    SinceAppendMode = cms.bool(True),
    Source = cms.PSet(
        IOVRun = cms.untracked.uint32(1)
    )
)
process.p = cms.Path(process.mytest)
EOF

cmsRun temp_pfcuts_to_db.py
rm temp_pfcuts_to_db.py

cat << \EOF > temp_pfcuts_from_db.py

import FWCore.ParameterSet.Config as cms
from Configuration.StandardSequences.Eras import eras

process = cms.Process("FROMDB",eras.Run3)
process.load("CondCore.CondDB.CondDB_cfi")

process.load("Configuration.StandardSequences.GeometryDB_cff")
process.load("Configuration.StandardSequences.FrontierConditions_GlobalTag_cff")
from Configuration.AlCa.autoCond import autoCond
process.GlobalTag.globaltag = autoCond["phase1_2022_realistic"] 

process.load('Configuration.StandardSequences.Services_cff')
process.load("CondCore.CondDB.CondDB_cfi")
process.CondDB.connect = "sqlite_file:HcalPFCuts_V00_test.db"

process.maxEvents = cms.untracked.PSet(
    input = cms.untracked.int32(1)
)

process.source = cms.Source("EmptySource",
    numberEventsInRun = cms.untracked.uint32(1),
    firstRun = cms.untracked.uint32(1)
)

process.PoolDBESSource = cms.ESSource("PoolDBESSource",
    process.CondDB,
    toGet = cms.VPSet(cms.PSet(
        record = cms.string("HcalPFCutsRcd"),
        tag = cms.string("HcalPFCuts_test_tag")
    ))
)

process.es_prefer = cms.ESPrefer("PoolDBESSource","")

process.dumpcond = cms.EDAnalyzer("HcalDumpConditions",
    dump = cms.untracked.vstring("PFCuts")
)
process.p = cms.Path(process.dumpcond)
EOF

cmsRun temp_pfcuts_from_db.py
rm temp_pfcuts_from_db.py

# Ingnore raw channel ids in the comparison
rm -f db_reference.txt db_dump.txt
awk '{print $1, $2, $3, $4, $5, $6}' $inputfile > db_reference.txt
awk '{print $1, $2, $3, $4, $5, $6}' DumpPFCuts_Run1.txt > db_dump.txt
diff db_dump.txt db_reference.txt