Files
date_time/test/posix_time/testtime_input_facet.cpp
2005-04-23 05:41:08 +00:00

243 lines
8.5 KiB
C++

/* Copyright (c) 2005 CrystalClear Software, Inc.
* Use, modification and distribution is subject to the
* Boost Software License, Version 1.0. (See accompanying
* file LICENSE-1.0 or http://www.boost.org/LICENSE-1.0)
* Author: Jeff Garland, Bart Garst
* $Date$
*/
#include "boost/date_time/gregorian/gregorian.hpp"
#include "boost/date_time/posix_time/posix_time.hpp"
#include "boost/date_time/testfrmwk.hpp"
#include <iostream>
#include <sstream>
#include <string>
#include <vector>
// for tests that are expected to fail
template<class temporal_type, class exception_type>
bool failure_test(temporal_type component,
const std::string& input,
exception_type /*except*/,
boost::posix_time::ptime_input_facet* facet)
{
using namespace boost::posix_time;
bool result = false;
std::istringstream iss(input);
iss.imbue(std::locale(std::locale::classic(), facet));
try {
iss >> component;
}
catch(exception_type e) {
result = true;
}
catch(...) {
result = false;
}
return result;
}
int main(){
#if defined(USE_DATE_TIME_PRE_1_33_FACET_IO) // skip this file
check("No tests run for this compiler. Incompatible IO", true);
#else
using namespace boost::gregorian;
using namespace boost::posix_time;
// set up initial objects
time_duration td = hours(0);
ptime pt(not_a_date_time);
time_period tp(pt, td);
// exceptions for failure_tests
std::ios_base::failure e_failure("default");
/* test ptime, time_duration, time_period.
* test all formats.
* test for bad input.
* test special values.
* do not test custom names (done in gregorian).
*
* format flags to test H,M,S,s,F,f,j
*/
// default format tests: time_duration, ptime
std::istringstream iss("09:59:01.321987654321 2005-Jan-15 10:15:03.123456789123");
iss >> td;
iss >> pt;
#if defined(BOOST_DATE_TIME_POSIX_TIME_STD_CONFIG)
check("Default format time_duration", td == time_duration(9,59,1,321987654));
check("Default format ptime", pt == ptime(date(2005,01,15),time_duration(10,15,3,123456789)));
#else
check("Default format time_duration", td == time_duration(9,59,1,321987));
check("Default format ptime", pt == ptime(date(2005,01,15),time_duration(10,15,3,123456)));
#endif
// test all flags that appear in ptime_input_facet
iss.str("12:34:56 2005-Jan-15 12:34:56");
iss >> td;
iss >> pt;
check("Default format time_duration no frac_sec", td == time_duration(12,34,56));
// the following test insures %F parsing stops at the appropriate point
check("Default format ptime", pt == ptime(date(2005,01,15),time_duration(12,34,56)));
iss.str("14:13:12 extra stuff"); // using default %H:%M:%S%F format
iss >> td;
check("Default frac_sec format time_duration", td == time_duration(14,13,12));
ptime_input_facet* facet = new ptime_input_facet();
std::locale loc(std::locale::classic(), facet);
facet->time_duration_format("%H:%M:%S%f");
iss.imbue(loc);
iss.str("14:13:12.0 extra stuff");
iss >> td;
check("Required-frac_sec format time_duration", td == time_duration(14,13,12));
iss.str("12");
facet->time_duration_format("%H");
iss >> td;
check("Hours format", td == hours(12));
iss.str("05");
facet->time_duration_format("%M");
iss >> td;
check("Minutes format", td == minutes(5));
iss.str("45");
facet->time_duration_format("%S");
iss >> td;
check("Seconds w/o frac_sec format", td == seconds(45));
iss.str("10.01");
facet->time_duration_format("%s");
iss >> td;
#if defined(BOOST_DATE_TIME_POSIX_TIME_STD_CONFIG)
check("Seconds w/ frac_sec format", td == time_duration(0,0,10,10000000));
#else
check("Seconds w/ frac_sec format", td == time_duration(0,0,10,10000));
#endif
iss.str("2005-105T23:59");
facet->format("%Y-%jT%H:%M"); // extended ordinal format
iss >> pt;
check("Extended Ordinal format", pt == ptime(date(2005,4,15),time_duration(23,59,0)));
// special_values tests. prove the individual flags catch special_values
// NOTE: these flags all by themselves will not parse a complete ptime,
// these are *specific* special_values tests
iss.str("+infinity -infinity");
facet->format("%H");
facet->time_duration_format("%H");
iss >> pt;
iss >> td;
check("Special value: ptime %H flag", pt == ptime(pos_infin));
check("Special value: time_duration %H flag", td == time_duration(neg_infin));
iss.str("not-a-date-time +infinity");
facet->format("%M");
facet->time_duration_format("%M");
iss >> pt;
iss >> td;
check("Special value: ptime %M flag", pt == ptime(not_a_date_time));
check("Special value: time_duration %M flag", td == time_duration(pos_infin));
iss.str("-infinity not-a-date-time ");
facet->format("%S");
facet->time_duration_format("%S");
iss >> pt;
iss >> td;
check("Special value: ptime %S flag", pt == ptime(neg_infin));
check("Special value: time_duration %S flag", td == time_duration(not_a_date_time));
iss.str("+infinity -infinity");
facet->format("%s");
facet->time_duration_format("%s");
iss >> pt;
iss >> td;
check("Special value: ptime %s flag", pt == ptime(pos_infin));
check("Special value: time_duration %s flag", td == time_duration(neg_infin));
iss.str("not-a-date-time +infinity");
facet->format("%j");
facet->time_duration_format("%f");
iss >> pt;
iss >> td;
check("Special value: ptime %j flag", pt == ptime(not_a_date_time));
check("Special value: time_duration %f flag", td == time_duration(pos_infin));
// time_period tests - the time_period_parser is thoroughly tested in gregorian tests
// default period format is closed range so last ptime is included in peiod
iss.str("[2005-Jan-01 00:00:00/2005-Dec-31 23:59:59]");
facet->format(ptime_input_facet::default_time_input_format); // reset format
iss >> tp;
check("Time period, default formats",
(tp.begin() == ptime(date(2005,1,1),hours(0))) &&
(tp.last() == ptime(date(2005,12,31),time_duration(23,59,59))) &&
(tp.end() == ptime(date(2005,12,31),time_duration(23,59,59,1))) );
// Failure tests
// faliure tests for date elements tested in gregorian tests
ptime_input_facet* facet2 = new ptime_input_facet();
facet2->time_duration_format("%H:%M:%S%f");
check("Failure test: Missing frac_sec with %f flag",
failure_test(td, "14:13:12 extra stuff", e_failure, facet2));
// Reversable format tests
time_duration td_io(10,11,12,1234567);
ptime pt_io(date(2004,03,15), td_io);
ptime_facet* otp_facet = new ptime_facet();
ptime_input_facet* inp_facet = new ptime_input_facet();
std::stringstream ss;
std::locale loc2(std::locale::classic(), otp_facet);
ss.imbue(std::locale(loc2, inp_facet)); // imbue locale containing both facets
ss.str("");
ss << pt_io; // stream out pt_io
ss >> pt;
check("Stream out one ptime then into another: default format", pt_io == pt);
ss.str("");
ss << td_io; // stream out td_io
ss >> td;
check("Stream out one time_duration then into another: default format", td_io == td);
td_io = time_duration(1,29,59); // no frac_sec, default format has %F
pt_io = ptime(date(2004,2,29), td_io); // leap year
ss.str("");
ss << pt_io; // stream out pt_io
ss >> pt;
check("Stream out one ptime then into another: default format", pt_io == pt);
ss.str("");
ss << td_io; // stream out td_io
ss >> td;
check("Stream out one time_duration then into another: default format", td_io == td);
td_io = time_duration(13,05,0); // no seconds as the next formats won't use them
pt_io = ptime(date(2004,2,29), td_io); // leap year
otp_facet->format("%Y-%jT%H:%M"); // extended ordinal
inp_facet->format("%Y-%jT%H:%M");
ss.str("");
ss << pt_io; // stream out pt_io
ss >> pt;
check("Stream out one ptime then into another: extended ordinal format", pt_io == pt);
otp_facet->format("Time: %H:%M, Date: %B %d, %Y"); // custom format with extra words
inp_facet->format("Time: %H:%M, Date: %B %d, %Y");
ss.str("");
ss << pt_io; // stream out pt_io
ss >> pt;
check("Stream out one ptime then into another: custom format (" + ss.str() + ")", pt_io == pt);
{
// fully parameterized constructor - compile only test, all other features tested in gregorian
boost::date_time::format_date_parser<date, char> fdp("%Y-%b-%d", std::locale::classic());
special_values_parser svp; // default constructor
period_parser pp; // default constructor
boost::date_time::date_generator_parser<date, char> dgp; // default constructor
ptime_input_facet tif("%Y-%m-%d %H:%M:%s", fdp, svp, pp, dgp);
}
#endif // USE_DATE_TIME_PRE_1_33_FACET_IO
return printTestStats();
}