TestWriteESAlignments

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
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/ServiceRegistry/interface/Service.h"
#include "FWCore/Framework/interface/ConsumesCollector.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"

#include "Geometry/EcalAlgo/interface/EcalPreshowerGeometry.h"
#include "Geometry/EcalAlgo/interface/WriteESAlignments.h"

typedef WriteESAlignments WEA;

class TestWriteESAlignments : public edm::one::EDAnalyzer<> {
public:
  explicit TestWriteESAlignments(const edm::ParameterSet& /*iConfig*/)
      : writer_{consumesCollector()}, nEventCalls_{0} {}
  ~TestWriteESAlignments() override {}

  void beginJob() override {}
  void analyze(edm::Event const& iEvent, edm::EventSetup const&) override;
  void endJob() override {}

private:
  WriteESAlignments writer_;
  unsigned int nEventCalls_;
};

void TestWriteESAlignments::analyze(const edm::Event& /*evt*/, const edm::EventSetup& evtSetup) {
  if (nEventCalls_ > 0) {
    edm::LogInfo("TestWriteESAlignments") << "Writing to DB to be done only once, "
                                          << "set 'untracked PSet maxEvents = {untracked int32 input = 1}'."
                                          << "(Your writing should be fine.)";
    return;
  }

  static const unsigned int nA(EcalPreshowerGeometry::numberOfAlignments());

  typedef std::vector<double> DVec;

  DVec alphaVec(nA, 0);
  DVec betaVec(nA, 0);
  DVec gammaVec(nA, 0);
  DVec xtranslVec(nA, 0);
  DVec ytranslVec(nA, 0);
  DVec ztranslVec(nA, 0);

  writer_.writeAlignments(evtSetup, alphaVec, betaVec, gammaVec, xtranslVec, ytranslVec, ztranslVec);

  edm::LogInfo("TestWriteESAlignments") << "Done!";
  nEventCalls_++;
}

DEFINE_FWK_MODULE(TestWriteESAlignments);