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
|
|
|
}
|
|
|
|
};
|