T

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
#include "DataFormats/Common/interface/DetSetVectorNew.h"
#include "FWCore/Utilities/interface/Exception.h"
#include <iostream>
#include <functional>
#include "catch.hpp"

namespace {
  struct T {
    float v;
  };
}  // namespace

typedef edmNew::DetSetVector<T> DSTV;
typedef edmNew::DetSet<T> DST;
typedef DSTV::FastFiller FF;

TEST_CASE("test edmNew::DetSetVector", "[edmNew::DetSetVector]") {
  DSTV dstv;

  {
    FF ff(dstv, 1);
    ff.push_back(T());
    ff[0].v = 2.1;
  }
  {
    FF ff(dstv, 2);
    ff.push_back(T());
    ff.push_back(T());
  }
  REQUIRE(dstv.size() == 2);
  REQUIRE(dstv.dataSize() == 3);
  REQUIRE(dstv.detsetSize(0) == 1);

  DST d1 = *dstv.find(2);
  d1[0].v = 3.14;
  DST d2 = dstv.insert(4, 3);
  d2[0].v = 4.15;

  SECTION("iterator") {
    int i = 0;
    std::vector<float> values = {2.1, 3.14, 4.15};
    std::for_each(dstv.begin(), dstv.end(), [&i, &values](auto const& value) { REQUIRE(value[0].v == values[i++]); });
  }
}