/
#include <cassert>
#include <limits>
#include <sstream>
#include <fstream>
#include <string>
#define BOOST_TEST_DYN_LINK
#define BOOST_TEST_MAIN
#define BOOST_TEST_MODULE OptimiseTestSuite
#include <boost/test/unit_test.hpp>
#include <stdair/basic/BasLogParams.hpp>
#include <stdair/basic/BasDBParams.hpp>
#include <stdair/service/Logger.hpp>
#include <rmol/config/rmol-paths.hpp>
namespace boost_utf = boost::unit_test;
std::ofstream utfReportStream ("bomsforforecaster_utfresults.xml");
UnitTestConfig() {
boost_utf::unit_test_log.set_stream (utfReportStream);
#if defined(BOOST_VERSION) && BOOST_VERSION >= 105900
boost_utf::unit_test_log.set_format (boost_utf::OF_XML);
#else
boost_utf::unit_test_log.set_format (boost_utf::XML);
#endif
boost_utf::unit_test_log.set_threshold_level (boost_utf::log_test_units);
}
~UnitTestConfig() {
}
};
struct BookingClassData {
double _bookingCount;
double _fare;
double _sellupFactor;
bool _censorshipFlag;
BookingClassData (const double iBookingCount, const double iFare,
const double iSellupFactor, const bool iCensorshipFlag)
: _bookingCount(iBookingCount), _fare(iFare),
_sellupFactor(iSellupFactor), _censorshipFlag(iCensorshipFlag) {
}
double getFare () const {
return _fare;
}
bool getCensorshipFlag () const {
return _censorshipFlag;
}
std::string toString() const {
std::ostringstream oStr;
oStr << std::endl
<< "[Booking class data information]" << std::endl
<< "Booking counter: " << _bookingCount << std::endl
<< "Fare: " << _fare << std::endl
<< "Sell-up Factor: " << _sellupFactor << std::endl
<< "censorshipFlag: " << _censorshipFlag << std::endl;
return oStr.str();
}
};
struct BookingClassDataSet {
typedef std::vector<BookingClassData*> BookingClassDataList_T;
int _numberOfClass;
double _minimumFare;
bool _censorshipFlag;
BookingClassDataList_T _bookingClassDataList;
BookingClassDataSet ()
: _numberOfClass(0), _minimumFare(0),
_censorshipFlag(false) {
}
void addBookingClassData (BookingClassData& ioBookingClassData) {
_bookingClassDataList.push_back (&ioBookingClassData);
}
stdair::NbOfClasses_T getNumberOfClass () const {
return _bookingClassDataList.size();
}
double getMinimumFare () const {
return _minimumFare;
}
bool getCensorshipFlag () const {
return _censorshipFlag;
}
void setMinimumFare (const double iMinFare) {
_minimumFare = iMinFare;
}
void setCensorshipFlag (const bool iCensorshipFlag) {
_censorshipFlag = iCensorshipFlag;
}
void updateMinimumFare() {
double minFare = std::numeric_limits<double>::max();
BookingClassDataList_T::iterator itBookingClassDataList;
for (itBookingClassDataList = _bookingClassDataList.begin();
itBookingClassDataList != _bookingClassDataList.end();
++itBookingClassDataList) {
BookingClassData* lBookingClassData = *itBookingClassDataList;
assert (lBookingClassData != NULL);
const double lFare = lBookingClassData->getFare();
if (lFare < minFare) {
minFare = lFare;
}
}
setMinimumFare(minFare);
}
void updateCensorshipFlag () {
bool censorshipFlag = false;
BookingClassDataList_T::iterator itBookingClassDataList;
for (itBookingClassDataList = _bookingClassDataList.begin();
itBookingClassDataList != _bookingClassDataList.end();
++itBookingClassDataList) {
BookingClassData* lBookingClassData = *itBookingClassDataList;
assert (lBookingClassData != NULL);
const bool lCensorshipFlagOfAClass =
lBookingClassData->getCensorshipFlag();
if (lCensorshipFlagOfAClass) {
censorshipFlag = true;
break;
}
}
setCensorshipFlag(censorshipFlag);
}
std::string toString() const {
std::ostringstream oStr;
oStr << std::endl
<< "[Booking class data set information]" << std::endl
<< "Number of classes: " << _numberOfClass << std::endl
<< "Minimum fare: " << _minimumFare << std::endl
<< "The data of the class set are sensored: " << _censorshipFlag
<< std::endl;
return oStr.str();
}
};
}
BOOST_GLOBAL_FIXTURE (UnitTestConfig);