TestSiStripDelay

Macros

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 114 115 116 117
#include <cppunit/CompilerOutputter.h>
#include <cppunit/TestFixture.h>
#include <cppunit/TestResult.h>
#include <cppunit/TestResultCollector.h>
#include <cppunit/TestRunner.h>
#include <cppunit/TextTestProgressListener.h>
#include <cppunit/extensions/HelperMacros.h>
#include <cppunit/ui/text/TestRunner.h>

#include <algorithm>
#include <boost/foreach.hpp>
#include <cassert>
#include <iterator>

#include "CalibFormats/SiStripObjects/interface/SiStripDelay.h"

#ifndef TestSiStripDelay_cc
#define TestSiStripDelay_cc

class TestSiStripDelay : public CppUnit::TestFixture {
public:
  TestSiStripDelay() {}
  void setUp() {
    baseDelay1 = new SiStripBaseDelay;
    baseDelaySign1 = 1;
    baseDelay2 = new SiStripBaseDelay;
    baseDelaySign2 = -1;
    totalDelays = 15000;
    // totalDelays = 1;
    for (uint32_t i = 0; i < totalDelays; ++i) {
      detIds.push_back(i);
      coarseDelay.push_back(i / 1000);
      fineDelay.push_back(i / 2000);
      baseDelay1->put(i, i / 1000, i / 2000);
      baseDelay2->put(i, i / 2000, i / 1000);
      // coarseDelay.push_back(1);
      // fineDelay.push_back(2);
      // baseDelay1->put(i, 1, 2);
      // baseDelay2->put(i, 2, 1);
    }
  }

  void tearDown() {
    delete baseDelay1;
    delete baseDelay2;
  }

  void testConstructor() {
    SiStripDelay delay(*baseDelay1, baseDelaySign1, std::make_pair("baseDelay1", "delay1"));
    CPPUNIT_ASSERT(delay.getNumberOfTags() == 1);
    CPPUNIT_ASSERT(delay.getBaseDelay(0) == baseDelay1);
    CPPUNIT_ASSERT(delay.getTagSign(0) == 1);
    CPPUNIT_ASSERT(delay.getRcdName(0) == "baseDelay1");
    CPPUNIT_ASSERT(delay.getLabelName(0) == "delay1");
  }

  void testFillNewDelay() {
    SiStripDelay delay(*baseDelay1, baseDelaySign1, std::make_pair("baseDelay1", "delay1"));
    delay.fillNewDelay(*baseDelay2, baseDelaySign2, std::make_pair("baseDelay2", "delay2"));
    CPPUNIT_ASSERT(delay.getNumberOfTags() == 2);
    CPPUNIT_ASSERT(delay.getBaseDelay(0) == baseDelay1);
    CPPUNIT_ASSERT(delay.getTagSign(0) == baseDelaySign1);
    CPPUNIT_ASSERT(delay.getRcdName(0) == "baseDelay1");
    CPPUNIT_ASSERT(delay.getLabelName(0) == "delay1");
    CPPUNIT_ASSERT(delay.getBaseDelay(1) == baseDelay2);
    CPPUNIT_ASSERT(delay.getTagSign(1) == baseDelaySign2);
    CPPUNIT_ASSERT(delay.getRcdName(1) == "baseDelay2");
    CPPUNIT_ASSERT(delay.getLabelName(1) == "delay2");
  }

  void testMakeDelay() {
    SiStripDelay delay(*baseDelay1, baseDelaySign1, std::make_pair("baseDelay1", "delay1"));
    CPPUNIT_ASSERT(delay.makeDelay());
    for (uint32_t i = 0; i < totalDelays; ++i) {
      CPPUNIT_ASSERT(float(delay.getDelay(detIds[i])) == float(baseDelay1->delay(detIds[i]) * baseDelaySign1));
    }
    delay.fillNewDelay(*baseDelay2, baseDelaySign2, std::make_pair("baseDelay2", "delay2"));
    CPPUNIT_ASSERT(delay.makeDelay());
    for (uint32_t i = 0; i < totalDelays; ++i) {
      //       std::cout << "float(delay.getDelay("<<detIds[i]<<")) = " <<
      //       float(delay.getDelay(detIds[i])) << std::endl; std::cout <<
      //       "float(baseDelay1->delay("<<detIds[i]<<") = " <<
      //       float(baseDelay1->delay(detIds[i])) << std::endl; std::cout <<
      //       "float(baseDelay2->delay("<<detIds[i]<<") = " <<
      //       float(baseDelay2->delay(detIds[i])) << std::endl; std::cout <<
      //       "float(baseDelay1->delay("<<detIds[i]<<")*"<<baseDelaySign1<<" -
      //       baseDelay2->delay("<<detIds[i]<<"))*"<<baseDelaySign2<<" = " <<
      //       float(baseDelay1->delay(detIds[i])*baseDelaySign1 +
      //       baseDelay2->delay(detIds[i])*baseDelaySign2) << std::endl;
      CPPUNIT_ASSERT(float(delay.getDelay(detIds[i])) == float(baseDelay1->delay(detIds[i]) * baseDelaySign1 +
                                                               baseDelay2->delay(detIds[i]) * baseDelaySign2));
    }
  }

  SiStripBaseDelay *baseDelay1;
  int baseDelaySign1;
  SiStripBaseDelay *baseDelay2;
  int baseDelaySign2;
  std::vector<uint32_t> detIds;
  std::vector<uint16_t> coarseDelay;
  std::vector<uint16_t> fineDelay;
  uint32_t totalDelays;

  // Declare and build the test suite
  CPPUNIT_TEST_SUITE(TestSiStripDelay);
  CPPUNIT_TEST(testConstructor);
  CPPUNIT_TEST(testFillNewDelay);
  CPPUNIT_TEST(testMakeDelay);
  CPPUNIT_TEST_SUITE_END();
};

// Register the test suite in the registry.
// This way we will have to only pass the registry to the runner
// and it will contain all the registered test suites.
CPPUNIT_TEST_SUITE_REGISTRATION(TestSiStripDelay);

#endif