xlnt/source/tests/CellTestSuite.h

321 lines
9.3 KiB
C
Raw Normal View History

2014-05-09 03:32:12 +08:00
#pragma once
#include <ctime>
#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 CellTestSuite : public CxxTest::TestSuite
{
public:
CellTestSuite()
{
}
void test_coordinates()
{
auto coord = xlnt::cell::coordinate_from_string("ZF46");
TS_ASSERT_EQUALS("ZF", coord.column);
TS_ASSERT_EQUALS(46, coord.row);
}
void test_invalid_coordinate()
{
TS_ASSERT_THROWS_ANYTHING(xlnt::cell::coordinate_from_string("AAA"));
}
void test_zero_row()
{
TS_ASSERT_THROWS_ANYTHING(xlnt::cell::coordinate_from_string("AQ0"));
}
void test_absolute()
{
TS_ASSERT_EQUALS("$ZF$51", xlnt::cell::absolute_coordinate("ZF51"));
}
void test_absolute_multiple()
{
TS_ASSERT_EQUALS("$ZF$51:$ZF$53", xlnt::cell::absolute_coordinate("ZF51:ZF$53"));
}
void test_column_index()
{
TS_ASSERT_EQUALS(10, xlnt::cell::column_index_from_string("J"));
TS_ASSERT_EQUALS(270, xlnt::cell::column_index_from_string("jJ"));
TS_ASSERT_EQUALS(7030, xlnt::cell::column_index_from_string("jjj"));
2014-05-11 23:58:53 +08:00
TS_ASSERT_EQUALS(1, xlnt::cell::column_index_from_string("A"));
TS_ASSERT_EQUALS(26, xlnt::cell::column_index_from_string("Z"));
TS_ASSERT_EQUALS(27, xlnt::cell::column_index_from_string("AA"));
TS_ASSERT_EQUALS(52, xlnt::cell::column_index_from_string("AZ"));
TS_ASSERT_EQUALS(53, xlnt::cell::column_index_from_string("BA"));
TS_ASSERT_EQUALS(78, xlnt::cell::column_index_from_string("BZ"));
TS_ASSERT_EQUALS(677, xlnt::cell::column_index_from_string("ZA"));
TS_ASSERT_EQUALS(702, xlnt::cell::column_index_from_string("ZZ"));
TS_ASSERT_EQUALS(703, xlnt::cell::column_index_from_string("AAA"));
TS_ASSERT_EQUALS(728, xlnt::cell::column_index_from_string("AAZ"));
TS_ASSERT_EQUALS(731, xlnt::cell::column_index_from_string("ABC"));
TS_ASSERT_EQUALS(1353, xlnt::cell::column_index_from_string("AZA"));
TS_ASSERT_EQUALS(18253, xlnt::cell::column_index_from_string("ZZA"));
TS_ASSERT_EQUALS(18278, xlnt::cell::column_index_from_string("ZZZ"));
2014-05-09 03:32:12 +08:00
}
void test_bad_column_index()
{
2014-05-11 23:58:53 +08:00
for(auto bad_string : {"JJJJ", "", "$", "1"})
2014-05-09 03:32:12 +08:00
{
2014-05-11 23:58:53 +08:00
TS_ASSERT_THROWS_ANYTHING(xlnt::cell::column_index_from_string(bad_string));
2014-05-09 03:32:12 +08:00
}
}
void test_column_letter_boundries()
{
TS_ASSERT_THROWS_ANYTHING(xlnt::cell::get_column_letter(0));
TS_ASSERT_THROWS_ANYTHING(xlnt::cell::get_column_letter(18279));
}
void test_column_letter()
{
TS_ASSERT_EQUALS("ZZZ", xlnt::cell::get_column_letter(18278));
TS_ASSERT_EQUALS("JJJ", xlnt::cell::get_column_letter(7030));
TS_ASSERT_EQUALS("AB", xlnt::cell::get_column_letter(28));
TS_ASSERT_EQUALS("AA", xlnt::cell::get_column_letter(27));
TS_ASSERT_EQUALS("Z", xlnt::cell::get_column_letter(26));
}
void test_initial_value()
{
xlnt::workbook wb;
2014-05-15 06:31:48 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-11 22:46:43 +08:00
xlnt::cell cell(ws, "A", 1, "17.5");
2014-05-09 03:32:12 +08:00
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
}
void test_null()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
TS_ASSERT_EQUALS(xlnt::cell::type::null, cell.get_data_type());
}
void test_numeric()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1, "17.5");
cell = 42;
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = "4.2";
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = "-42.000";
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = "0";
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = 0;
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = 0.0001;
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = "0.9999";
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = "99E-02";
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = 1e1;
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = "4";
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = "-1E3";
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
cell = 4;
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
}
void test_string()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
2014-05-11 22:46:43 +08:00
2014-05-09 03:32:12 +08:00
cell = "hello";
TS_ASSERT_EQUALS(xlnt::cell::type::string, cell.get_data_type());
}
void test_single_dot()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
cell = ".";
TS_ASSERT_EQUALS(xlnt::cell::type::string, cell.get_data_type());
}
void test_formula()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
cell = "=42";
TS_ASSERT_EQUALS(xlnt::cell::type::formula, cell.get_data_type());
}
void test_boolean()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
cell = true;
TS_ASSERT_EQUALS(xlnt::cell::type::boolean, cell.get_data_type());
cell = false;
TS_ASSERT_EQUALS(xlnt::cell::type::boolean, cell.get_data_type());
}
void test_leading_zero()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
cell = "0800";
TS_ASSERT_EQUALS(xlnt::cell::type::string, cell.get_data_type());
}
2014-05-13 01:42:28 +08:00
void test_error_codes()
2014-05-09 03:32:12 +08:00
{
2014-05-13 01:42:28 +08:00
xlnt::workbook wb;
xlnt::worksheet ws = wb.get_active_sheet();
xlnt::cell cell(ws, "A", 1);
2014-05-09 03:32:12 +08:00
2014-05-13 01:42:28 +08:00
for(auto error : xlnt::cell::ErrorCodes)
{
cell = error.first;
TS_ASSERT_EQUALS(xlnt::cell::type::error, cell.get_data_type());
}
2014-05-09 03:32:12 +08:00
}
void test_data_type_check()
{
2014-05-13 01:42:28 +08:00
xlnt::workbook wb;
xlnt::worksheet ws = wb.get_active_sheet();
xlnt::cell cell(ws, "A", 1);
2014-05-09 03:32:12 +08:00
2014-05-13 01:42:28 +08:00
TS_ASSERT_EQUALS(xlnt::cell::type::null, cell.get_data_type());
2014-05-09 03:32:12 +08:00
2014-05-13 01:42:28 +08:00
cell.bind_value(".0e000");
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
2014-05-09 03:32:12 +08:00
2014-05-13 01:42:28 +08:00
cell.bind_value("-0.e-0");
TS_ASSERT_EQUALS(xlnt::cell::type::numeric, cell.get_data_type());
2014-05-09 03:32:12 +08:00
2014-05-13 01:42:28 +08:00
cell.bind_value("1E");
TS_ASSERT_EQUALS(xlnt::cell::type::string, cell.get_data_type());
2014-05-09 03:32:12 +08:00
}
void test_set_bad_type()
{
2014-05-13 01:42:28 +08:00
xlnt::workbook wb;
xlnt::worksheet ws = wb.get_active_sheet();
xlnt::cell cell(ws, "A", 1);
2014-05-09 03:32:12 +08:00
2014-05-13 01:42:28 +08:00
cell.set_explicit_value("1", xlnt::cell::type::formula);
2014-05-09 03:32:12 +08:00
}
void test_time()
{
2014-05-13 01:42:28 +08:00
xlnt::workbook wb;
xlnt::worksheet ws = wb.get_active_sheet();
xlnt::cell cell(ws, "A", 1);
cell = "03:40:16";
2014-05-15 06:31:48 +08:00
TS_ASSERT_EQUALS(xlnt::cell::type::date, cell.get_data_type());
2014-05-13 01:42:28 +08:00
tm expected1;
expected1.tm_hour = 3;
expected1.tm_min = 40;
expected1.tm_sec = 16;
TS_ASSERT(cell == expected1);
cell = "03:40";
2014-05-15 06:31:48 +08:00
TS_ASSERT_EQUALS(xlnt::cell::type::date, cell.get_data_type());
2014-05-13 01:42:28 +08:00
tm expected2;
expected2.tm_hour = 3;
expected2.tm_min = 40;
TS_ASSERT(cell == expected1);
2014-05-09 03:32:12 +08:00
}
void test_date_format_on_non_date()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
2014-05-11 22:46:43 +08:00
2014-05-09 03:32:12 +08:00
time_t t = time(0);
tm now = *localtime(&t);
cell = now;
cell = "testme";
TS_ASSERT("testme" == cell);
}
void test_set_get_date()
{
tm today = {0};
today.tm_year = 2010;
today.tm_mon = 1;
today.tm_yday = 18;
today.tm_hour = 14;
today.tm_min = 15;
today.tm_sec = 20;
2014-05-11 22:46:43 +08:00
2014-05-09 03:32:12 +08:00
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
2014-05-11 22:46:43 +08:00
2014-05-09 03:32:12 +08:00
cell = today;
TS_ASSERT(today == cell);
}
void test_repr()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
2014-05-11 22:46:43 +08:00
2014-05-09 03:32:12 +08:00
TS_ASSERT_EQUALS(cell.to_string(), "<Cell Sheet1.A1>");
}
void test_is_date()
{
xlnt::workbook wb;
2014-05-13 01:42:28 +08:00
xlnt::worksheet ws = wb.get_active_sheet();
2014-05-09 03:32:12 +08:00
xlnt::cell cell(ws, "A", 1);
time_t t = time(0);
tm now = *localtime(&t);
cell = now;
TS_ASSERT_EQUALS(cell.is_date(), true);
cell = "testme";
2014-05-11 22:46:43 +08:00
TS_ASSERT_EQUALS("testme", cell);
2014-05-09 03:32:12 +08:00
TS_ASSERT_EQUALS(cell.is_date(), false);
}
void test_is_not_date_color_format()
{
2014-05-13 01:42:28 +08:00
xlnt::workbook wb;
xlnt::worksheet ws = wb.get_active_sheet();
xlnt::cell cell(ws, "A", 1);
2014-05-09 03:32:12 +08:00
2014-05-13 01:42:28 +08:00
cell = -13.5;
2014-05-15 10:07:23 +08:00
cell.get_style().get_number_format().set_format_code("0.00_);[Red]\\(0.00\\)");
2014-05-09 03:32:12 +08:00
2014-05-13 01:42:28 +08:00
TS_ASSERT_EQUALS(cell.is_date(), false);
2014-05-09 03:32:12 +08:00
}
};