TestGetPathStatus

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
#include "FWCore/Framework/interface/global/EDAnalyzer.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/Utilities/interface/EDGetToken.h"

#include "DataFormats/Common/interface/EndPathStatus.h"
#include "DataFormats/Common/interface/Handle.h"
#include "DataFormats/Common/interface/PathStatus.h"

#include <iostream>

namespace edm {
  class EventSetup;
  class StreamID;
}  // namespace edm

namespace edmtest {

  class TestGetPathStatus : public edm::global::EDAnalyzer<> {
  public:
    explicit TestGetPathStatus(edm::ParameterSet const& pset);
    virtual ~TestGetPathStatus() {}

    void analyze(edm::StreamID, edm::Event const&, edm::EventSetup const&) const override;

  private:
    std::vector<int> expectedStates_;
    std::vector<unsigned int> expectedIndexes_;

    edm::EDGetTokenT<edm::PathStatus> tokenPathStatus_;
    edm::EDGetTokenT<edm::EndPathStatus> tokenEndPathStatus_;
  };

  TestGetPathStatus::TestGetPathStatus(edm::ParameterSet const& pset)
      : expectedStates_(pset.getParameter<std::vector<int>>("expectedStates")),
        expectedIndexes_(pset.getParameter<std::vector<unsigned int>>("expectedIndexes")),
        tokenPathStatus_(consumes(pset.getParameter<edm::InputTag>("pathStatusTag"))),
        tokenEndPathStatus_(consumes(pset.getParameter<edm::InputTag>("endPathStatusTag"))) {}

  void TestGetPathStatus::analyze(edm::StreamID, edm::Event const& event, edm::EventSetup const&) const {
    auto const& pathStatus = event.get(tokenPathStatus_);

    unsigned int eventID = event.id().event();
    if (eventID < expectedStates_.size() && expectedStates_[eventID] != static_cast<int>(pathStatus.state())) {
      std::cerr << "TestGetPathStatus::analyze unexpected path status state" << std::endl;
      abort();
    }
    if (eventID < expectedIndexes_.size() && expectedIndexes_[eventID] != pathStatus.index()) {
      std::cerr << "TestGetPathStatus::analyze unexpected path status index " << std::endl;
      abort();
    }

    (void)event.get(tokenEndPathStatus_);
  }
}  // namespace edmtest
using edmtest::TestGetPathStatus;
DEFINE_FWK_MODULE(TestGetPathStatus);