xlnt/source/tests/NumberFormatTestSuite.h

166 lines
4.4 KiB
C
Raw Normal View History

2014-05-09 03:32:12 +08:00
#pragma once
#include <iostream>
#include <cxxtest/TestSuite.h>
2014-05-10 03:54:06 +08:00
#include "../xlnt.h"
2014-05-09 03:32:12 +08:00
class NumberFormatTestSuite : public CxxTest::TestSuite
{
public:
NumberFormatTestSuite()
{
}
void setup_class(int cls)
2014-05-13 01:42:28 +08:00
{
//cls.workbook = Workbook()
// cls.worksheet = Worksheet(cls.workbook, "Test")
// cls.sd = SharedDate()
2014-05-13 01:42:28 +08:00
}
2014-05-09 03:32:12 +08:00
void test_convert_date_to_julian()
{
//TS_ASSERT_EQUALS(40167, sd.to_julian(2009, 12, 20))
2014-05-09 03:32:12 +08:00
}
void test_convert_date_from_julian()
{
}
void test_date_equal(int julian, int datetime)
2014-05-13 01:42:28 +08:00
{
//TS_ASSERT_EQUALS(sd.from_julian(julian), datetime);
2014-05-09 03:32:12 +08:00
//date_pairs = (
// (40167, datetime(2009, 12, 20)),
// (21980, datetime(1960, 3, 5)),
// );
2014-05-09 03:32:12 +08:00
//for count, dt in date_pairs
//{
// yield test_date_equal, count, dt;
//}
2014-05-13 01:42:28 +08:00
}
2014-05-09 03:32:12 +08:00
void test_convert_datetime_to_julian()
{
//TS_ASSERT_EQUALS(40167, sd.datetime_to_julian(datetime(2009, 12, 20)))
// TS_ASSERT_EQUALS(40196.5939815, sd.datetime_to_julian(datetime(2010, 1, 18, 14, 15, 20, 1600)))
2014-05-09 03:32:12 +08:00
}
void test_insert_float()
{
//worksheet.cell("A1").value = 3.14
// TS_ASSERT_EQUALS(Cell.TYPE_NUMERIC, worksheet.cell("A1")._data_type)
2014-05-09 03:32:12 +08:00
}
void test_insert_percentage()
{
//worksheet.cell("A1").value = "3.14%"
// TS_ASSERT_EQUALS(Cell.TYPE_NUMERIC, worksheet.cell("A1")._data_type)
// assert_almost_equal(0.0314, worksheet.cell("A1").value)
2014-05-09 03:32:12 +08:00
}
void test_insert_datetime()
{
//worksheet.cell("A1").value = date.today()
// TS_ASSERT_EQUALS(Cell.TYPE_NUMERIC, worksheet.cell("A1")._data_type)
2014-05-09 03:32:12 +08:00
}
void test_insert_date()
{
//worksheet.cell("A1").value = datetime.now()
// TS_ASSERT_EQUALS(Cell.TYPE_NUMERIC, worksheet.cell("A1")._data_type)
2014-05-09 03:32:12 +08:00
}
void test_internal_date()
{
//dt = datetime(2010, 7, 13, 6, 37, 41)
// worksheet.cell("A3").value = dt
// TS_ASSERT_EQUALS(40372.27616898148, worksheet.cell("A3")._value)
2014-05-09 03:32:12 +08:00
}
void test_datetime_interpretation()
{
//dt = datetime(2010, 7, 13, 6, 37, 41)
// worksheet.cell("A3").value = dt
// TS_ASSERT_EQUALS(dt, worksheet.cell("A3").value)
2014-05-09 03:32:12 +08:00
}
void test_date_interpretation()
{
//dt = date(2010, 7, 13)
// worksheet.cell("A3").value = dt
// TS_ASSERT_EQUALS(datetime(2010, 7, 13, 0, 0), worksheet.cell("A3").value)
2014-05-09 03:32:12 +08:00
}
void test_number_format_style()
{
//worksheet.cell("A1").value = "12.6%"
// TS_ASSERT_EQUALS(NumberFormat.FORMAT_PERCENTAGE, \
// worksheet.cell("A1").style.number_format.format_code)
2014-05-09 03:32:12 +08:00
}
void test_date_format_on_non_date()
{
//cell = worksheet.cell("A1");
2014-05-09 03:32:12 +08:00
}
void check_date_pair(int count, const std::string &date_string)
2014-05-13 01:42:28 +08:00
{
//cell.value = strptime(date_string, "%Y-%m-%d");
//TS_ASSERT_EQUALS(count, cell._value);
2014-05-09 03:32:12 +08:00
//date_pairs = (
// (15, "1900-01-15"),
// (59, "1900-02-28"),
// (61, "1900-03-01"),
// (367, "1901-01-01"),
// (2958465, "9999-12-31"), );
//for count, date_string in date_pairs
//{
// yield check_date_pair, count, date_string;
//}
2014-05-13 01:42:28 +08:00
}
2014-05-09 03:32:12 +08:00
void test_1900_leap_year()
{
//assert_raises(ValueError, sd.from_julian, 60)
// assert_raises(ValueError, sd.to_julian, 1900, 2, 29)
2014-05-09 03:32:12 +08:00
}
void test_bad_date()
{
//void check_bad_date(year, month, day)
//{
// assert_raises(ValueError, sd.to_julian, year, month, day)
//}
2014-05-09 03:32:12 +08:00
//bad_dates = ((1776, 7, 4), (1899, 12, 31), )
// for year, month, day in bad_dates
// {
// yield check_bad_date, year, month, day
// }
2014-05-09 03:32:12 +08:00
}
void test_bad_julian_date()
{
//assert_raises(ValueError, sd.from_julian, -1)
2014-05-09 03:32:12 +08:00
}
void test_mac_date()
{
// sd.excel_base_date = CALENDAR_MAC_1904
2014-05-09 03:32:12 +08:00
// datetuple = (2011, 10, 31)
2014-05-09 03:32:12 +08:00
// dt = date(datetuple[0], datetuple[1], datetuple[2])
// julian = sd.to_julian(datetuple[0], datetuple[1], datetuple[2])
// reverse = sd.from_julian(julian).date()
// TS_ASSERT_EQUALS(dt, reverse)
// sd.excel_base_date = CALENDAR_WINDOWS_1900
2014-05-09 03:32:12 +08:00
}
};