testEcalShowerContainmentCorrections

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
/**
   \file
   test file for EcalShowerContainmentCorrections 

   \author Stefano ARGIRO
   \version $Id: FEDRawData_t.cpp,v 1.2 2006/03/27 10:08:21 argiro Exp $
   \date 28 Jun 2005
*/

#include <cppunit/extensions/HelperMacros.h>
#include "CondFormats/EcalCorrections/interface/EcalShowerContainmentCorrections.h"
#include "DataFormats/EcalDetId/interface/EBDetId.h"
class testEcalShowerContainmentCorrections : public CppUnit::TestFixture {
  CPPUNIT_TEST_SUITE(testEcalShowerContainmentCorrections);

  CPPUNIT_TEST(testFillandReadBack1);
  CPPUNIT_TEST(testFillandReadBack2);

  CPPUNIT_TEST_SUITE_END();

public:
  void setUp();
  void tearDown();
  void testFillandReadBack1();
  void testFillandReadBack2();

  double* testdata_;
};

///registration of the test so that the runner can find it
CPPUNIT_TEST_SUITE_REGISTRATION(testEcalShowerContainmentCorrections);

void testEcalShowerContainmentCorrections::setUp() {
  testdata_ = new double[EcalShowerContainmentCorrections::Coefficients::kSize];

  for (unsigned int i = 0; i < EcalShowerContainmentCorrections::Coefficients::kSize; ++i)
    testdata_[i] = i;
}

void testEcalShowerContainmentCorrections::tearDown() { delete[] testdata_; }

void testEcalShowerContainmentCorrections::testFillandReadBack1() {
  EcalShowerContainmentCorrections::Coefficients coeff;
  std::copy(testdata_, testdata_ + EcalShowerContainmentCorrections::Coefficients::kSize, coeff.data);

  // fill a random xtal
  EBDetId xtal(5, 550, EBDetId::SMCRYSTALMODE);

  EcalShowerContainmentCorrections correction;

  correction.fillCorrectionCoefficients(xtal, 3, coeff);

  EcalShowerContainmentCorrections::Coefficients correction_readback = correction.correctionCoefficients(xtal);

  for (unsigned int i = 0; i < EcalShowerContainmentCorrections::Coefficients::kSize; ++i)
    CPPUNIT_ASSERT(testdata_[i] == correction_readback.data[i]);
}

void testEcalShowerContainmentCorrections::testFillandReadBack2() {
  EcalShowerContainmentCorrections::Coefficients coeff;
  std::copy(testdata_, testdata_ + EcalShowerContainmentCorrections::Coefficients::kSize, coeff.data);

  EcalShowerContainmentCorrections correction;

  // use filling by module
  correction.fillCorrectionCoefficients(3, 2, coeff);

  // this is a xtal in SM3 , module 2
  EBDetId xtal(3, 550, EBDetId::SMCRYSTALMODE);

  EcalShowerContainmentCorrections::Coefficients correction_readback = correction.correctionCoefficients(xtal);

  for (unsigned int i = 0; i < EcalShowerContainmentCorrections::Coefficients::kSize; ++i)
    CPPUNIT_ASSERT(testdata_[i] == correction_readback.data[i]);
}

#include <Utilities/Testing/interface/CppUnit_testdriver.icpp>