xlnt/tests/cell/cell_test_suite.cpp

839 lines
27 KiB
C++
Raw Normal View History

// Copyright (c) 2014-2021 Thomas Fussell
2017-04-14 07:01:30 +08:00
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
2017-04-14 07:01:30 +08:00
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE
//
// @license: http://www.opensource.org/licenses/mit-license.php
// @author: see AUTHORS file
2016-06-20 02:43:41 +08:00
#include <sstream>
2017-04-14 02:51:35 +08:00
#include <helpers/assertions.hpp>
#include <helpers/test_suite.hpp>
2014-05-09 03:32:12 +08:00
2018-07-05 17:26:29 +08:00
#include <xlnt/cell/cell.hpp>
#include <xlnt/cell/comment.hpp>
#include <xlnt/cell/hyperlink.hpp>
#include <xlnt/styles/alignment.hpp>
#include <xlnt/styles/border.hpp>
#include <xlnt/styles/fill.hpp>
#include <xlnt/styles/format.hpp>
#include <xlnt/styles/number_format.hpp>
2018-07-05 17:26:29 +08:00
#include <xlnt/styles/protection.hpp>
#include <xlnt/styles/style.hpp>
#include <xlnt/utils/date.hpp>
#include <xlnt/utils/datetime.hpp>
#include <xlnt/utils/time.hpp>
#include <xlnt/utils/timedelta.hpp>
#include <xlnt/workbook/workbook.hpp>
#include <xlnt/worksheet/range.hpp>
#include <xlnt/worksheet/worksheet.hpp>
2017-04-14 02:51:35 +08:00
class cell_test_suite : public test_suite
2014-05-09 03:32:12 +08:00
{
public:
2017-04-14 02:51:35 +08:00
cell_test_suite()
{
2017-04-14 07:01:30 +08:00
register_test(test_infer_numeric);
register_test(test_constructor);
register_test(test_null);
register_test(test_string);
register_test(test_formula1);
register_test(test_formula2);
register_test(test_formula3);
register_test(test_not_formula);
register_test(test_boolean);
register_test(test_error_codes);
register_test(test_insert_datetime);
register_test(test_insert_date);
register_test(test_insert_time);
register_test(test_cell_formatted_as_date1);
register_test(test_cell_formatted_as_date2);
register_test(test_cell_formatted_as_date3);
register_test(test_illegal_characters);
register_test(test_timedelta);
register_test(test_cell_offset);
register_test(test_font);
register_test(test_fill);
register_test(test_border);
register_test(test_number_format);
register_test(test_alignment);
register_test(test_protection);
register_test(test_style);
register_test(test_print);
register_test(test_values);
register_test(test_reference);
register_test(test_anchor);
register_test(test_hyperlink);
register_test(test_comment);
register_test(test_copy_and_compare);
register_test(test_cell_phonetic_properties);
2017-04-14 02:51:35 +08:00
}
private:
void test_infer_numeric()
{
xlnt::workbook wb;
2017-04-14 07:01:30 +08:00
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2017-04-14 07:01:30 +08:00
cell.value("4.2", true);
xlnt_assert_delta(cell.value<double>(), 4.2, 1E-9);
2017-04-14 07:01:30 +08:00
cell.value("-42.000", true);
xlnt_assert(cell.value<int>() == -42);
2017-04-14 07:01:30 +08:00
cell.value("0", true);
xlnt_assert(cell.value<int>() == 0);
2017-04-14 07:01:30 +08:00
cell.value("0.9999", true);
xlnt_assert(cell.value<double>() == 0.9999);
2017-04-14 07:01:30 +08:00
cell.value("99E-02", true);
xlnt_assert(cell.value<double>() == 0.99);
2017-04-14 07:01:30 +08:00
cell.value("4", true);
xlnt_assert(cell.value<int>() == 4);
2017-04-14 07:01:30 +08:00
cell.value("-1E3", true);
xlnt_assert(cell.value<int>() == -1000);
2017-04-14 07:01:30 +08:00
cell.value("2e+2", true);
xlnt_assert(cell.value<int>() == 200);
2017-04-14 07:01:30 +08:00
cell.value("3.1%", true);
xlnt_assert_delta(cell.value<double>(), 0.031, 1E-9);
2017-04-14 07:01:30 +08:00
cell.value("03:40:16", true);
xlnt_assert(cell.value<xlnt::time>() == xlnt::time(3, 40, 16));
2017-04-14 07:01:30 +08:00
cell.value("03:", true);
xlnt_assert_equals(cell.value<std::string>(), "03:");
2017-04-14 07:01:30 +08:00
cell.value("03:40", true);
xlnt_assert(cell.value<xlnt::time>() == xlnt::time(3, 40));
2017-04-14 07:01:30 +08:00
cell.value("30:33.865633336", true);
xlnt_assert(cell.value<xlnt::time>() == xlnt::time(0, 30, 33, 865633));
2017-04-14 02:51:35 +08:00
}
void test_constructor()
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference("A", 1));
2017-04-14 07:01:30 +08:00
xlnt_assert(cell.data_type() == xlnt::cell::type::empty);
xlnt_assert(cell.column() == "A");
2018-07-03 09:16:33 +08:00
xlnt_assert(cell.column_index() == 1);
xlnt_assert(cell.row() == 1);
xlnt_assert(cell.reference() == "A1");
xlnt_assert(!cell.has_value());
}
void test_null()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
2016-03-14 11:46:01 +08:00
const auto datatypes =
{
xlnt::cell::type::empty,
xlnt::cell::type::boolean,
xlnt::cell::type::error,
xlnt::cell::type::formula_string,
xlnt::cell::type::number,
xlnt::cell::type::shared_string};
2017-04-14 07:01:30 +08:00
for (const auto &datatype : datatypes)
{
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.data_type(datatype);
xlnt_assert(cell.data_type() == datatype);
cell.clear_value();
xlnt_assert(cell.data_type() == xlnt::cell::type::empty);
}
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_string()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value("hello");
xlnt_assert(cell.data_type() == xlnt::cell::type::shared_string);
2017-04-14 07:01:30 +08:00
cell.value(".");
xlnt_assert(cell.data_type() == xlnt::cell::type::shared_string);
2017-04-14 07:01:30 +08:00
cell.value("0800");
xlnt_assert(cell.data_type() == xlnt::cell::type::shared_string);
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_formula1()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2016-07-24 07:15:17 +08:00
cell.value("=42", true);
//xlnt_assert(cell.data_type() == xlnt::cell::type::number);
xlnt_assert(cell.has_formula());
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_formula2()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value("=if(A1<4;-1;1)", true);
//xlnt_assert(cell.data_type() == xlnt::cell::type::number);
xlnt_assert(cell.has_formula());
2014-05-09 03:32:12 +08:00
}
2016-07-24 07:15:17 +08:00
void test_formula3()
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2016-07-24 07:15:17 +08:00
xlnt_assert(!cell.has_formula());
xlnt_assert_throws_nothing(cell.formula(""));
xlnt_assert(!cell.has_formula());
cell.formula("=42");
xlnt_assert(cell.has_formula());
xlnt_assert_equals(cell.formula(), "42");
2016-07-24 07:15:17 +08:00
cell.clear_formula();
xlnt_assert(!cell.has_formula());
2016-07-24 07:15:17 +08:00
}
void test_not_formula()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value("=", true);
xlnt_assert(cell.data_type() == xlnt::cell::type::shared_string);
xlnt_assert(cell.value<std::string>() == "=");
xlnt_assert(!cell.has_formula());
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_boolean()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
for (auto value : {true, false})
{
cell.value(value);
xlnt_assert(cell.data_type() == xlnt::cell::type::boolean);
}
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_error_codes()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
// error string can't be empty
xlnt_assert_throws(cell.error(""), xlnt::exception);
// error string has to have a leading '#'
xlnt_assert_throws(cell.error("not an error"), xlnt::exception);
2017-04-14 07:01:30 +08:00
for (auto error_code : xlnt::cell::error_codes())
2014-05-09 03:32:12 +08:00
{
// error type from the string format
cell.value(error_code.first, true);
xlnt_assert(cell.data_type() == xlnt::cell::type::error);
std::string error;
xlnt_assert_throws_nothing(error = cell.error());
xlnt_assert_equals(error, error_code.first);
// clearing the value clears the error state
cell.clear_value();
xlnt_assert_throws(cell.error(), xlnt::exception);
// can explicitly set the error
xlnt_assert_throws_nothing(cell.error(error_code.first));
std::string error2;
xlnt_assert_throws_nothing(error2 = cell.error());
xlnt_assert_equals(error2, error_code.first);
2014-05-09 03:32:12 +08:00
}
}
void test_insert_datetime()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value(xlnt::datetime(2010, 7, 13, 6, 37, 41));
xlnt_assert(cell.data_type() == xlnt::cell::type::number);
xlnt_assert_delta(cell.value<double>(), 40372.27616898148, 1E-9);
xlnt_assert(cell.is_date());
xlnt_assert(cell.number_format().format_string() == "yyyy-mm-dd h:mm:ss");
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_insert_date()
2014-06-11 06:36:31 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value(xlnt::date(2010, 7, 13));
xlnt_assert(cell.data_type() == xlnt::cell::type::number);
xlnt_assert(cell.value<double>() == 40372.0);
xlnt_assert(cell.is_date());
xlnt_assert(cell.number_format().format_string() == "yyyy-mm-dd");
2014-06-11 06:36:31 +08:00
}
2017-04-14 07:01:30 +08:00
void test_insert_time()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value(xlnt::time(1, 3));
xlnt_assert(cell.data_type() == xlnt::cell::type::number);
xlnt_assert_delta(cell.value<double>(), 0.04375, 1E-9);
xlnt_assert(cell.is_date());
xlnt_assert(cell.number_format().format_string() == "h:mm:ss");
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_cell_formatted_as_date1()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value(xlnt::datetime::today());
cell.clear_value();
xlnt_assert(!cell.is_date()); // disagree with openpyxl
xlnt_assert(!cell.has_value());
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_cell_formatted_as_date2()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value(xlnt::datetime::today());
cell.value("testme");
xlnt_assert(!cell.is_date());
xlnt_assert(cell.value<std::string>() == "testme");
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
void test_cell_formatted_as_date3()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value(xlnt::datetime::today());
cell.value(true);
xlnt_assert(!cell.is_date());
xlnt_assert(cell.value<bool>() == true);
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
2016-03-14 11:46:01 +08:00
void test_illegal_characters()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
// The bytes 0x00 through 0x1F inclusive must be manually escaped in values.
auto illegal_chrs = {0, 1, 2, 3, 4, 5, 6, 7, 8, 11, 12, 14, 15, 16, 17, 18,
19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31};
2017-04-14 07:01:30 +08:00
for (auto i : illegal_chrs)
2014-05-13 01:42:28 +08:00
{
std::string str(1, i);
xlnt_assert_throws(cell.value(str), xlnt::illegal_character);
2014-05-13 01:42:28 +08:00
}
2017-04-14 07:01:30 +08:00
cell.value(std::string(1, 33));
cell.value(std::string(1, 9)); // Tab
cell.value(std::string(1, 10)); // Newline
cell.value(std::string(1, 13)); // Carriage return
cell.value(" Leading and trailing spaces are legal ");
}
2017-04-14 07:01:30 +08:00
2016-03-14 11:46:01 +08:00
// void test_time_regex() {}
2017-04-14 07:01:30 +08:00
void test_timedelta()
2014-06-11 06:36:31 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
2017-04-14 07:01:30 +08:00
cell.value(xlnt::timedelta(1, 3, 0, 0, 0));
2015-11-23 01:41:27 +08:00
xlnt_assert(cell.value<double>() == 1.125);
xlnt_assert(cell.data_type() == xlnt::cell::type::number);
xlnt_assert(!cell.is_date());
xlnt_assert(cell.number_format().format_string() == "[hh]:mm:ss");
2014-06-11 06:36:31 +08:00
}
void test_cell_offset()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell(xlnt::cell_reference(1, 1));
xlnt_assert(cell.offset(1, 2).reference() == "B3");
2015-11-23 01:41:27 +08:00
}
2017-04-14 07:01:30 +08:00
2015-11-23 01:41:27 +08:00
void test_font()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
2017-04-14 07:01:30 +08:00
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2017-04-14 07:01:30 +08:00
auto font = xlnt::font().bold(true);
cell.font(font);
2017-04-14 07:01:30 +08:00
xlnt_assert(cell.has_format());
xlnt_assert(cell.format().font_applied());
xlnt_assert_equals(cell.font(), font);
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
2016-03-14 11:46:01 +08:00
void test_fill()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2017-04-14 07:01:30 +08:00
xlnt::fill fill(xlnt::pattern_fill()
.type(xlnt::pattern_fill_type::solid)
.foreground(xlnt::color::red()));
cell.fill(fill);
2017-04-14 07:01:30 +08:00
xlnt_assert(cell.has_format());
xlnt_assert(cell.format().fill_applied());
xlnt_assert_equals(cell.fill(), fill);
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
2016-03-14 11:46:01 +08:00
void test_border()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2017-04-14 07:01:30 +08:00
xlnt::border border;
cell.border(border);
2017-04-14 07:01:30 +08:00
xlnt_assert(cell.has_format());
xlnt_assert(cell.format().border_applied());
xlnt_assert_equals(cell.border(), border);
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
2016-03-14 11:46:01 +08:00
void test_number_format()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2017-04-14 07:01:30 +08:00
xlnt::number_format format("dd--hh--mm");
cell.number_format(format);
2017-04-14 07:01:30 +08:00
xlnt_assert(cell.has_format());
xlnt_assert(cell.format().number_format_applied());
xlnt_assert_equals(cell.number_format().format_string(), "dd--hh--mm");
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
2016-03-14 11:46:01 +08:00
void test_alignment()
2014-05-09 03:32:12 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2017-04-14 07:01:30 +08:00
xlnt::alignment align;
2016-08-18 19:34:18 +08:00
align.wrap(true);
2017-04-14 07:01:30 +08:00
cell.alignment(align);
2017-04-14 07:01:30 +08:00
xlnt_assert(cell.has_format());
xlnt_assert(cell.format().alignment_applied());
xlnt_assert_equals(cell.alignment(), align);
2014-05-09 03:32:12 +08:00
}
2017-04-14 07:01:30 +08:00
2016-03-14 11:46:01 +08:00
void test_protection()
2014-07-20 02:43:48 +08:00
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2016-06-20 02:43:41 +08:00
xlnt_assert(!cell.has_format());
2016-06-20 02:43:41 +08:00
2017-04-14 07:01:30 +08:00
auto protection = xlnt::protection().locked(false).hidden(true);
cell.protection(protection);
2017-04-14 07:01:30 +08:00
xlnt_assert(cell.has_format());
xlnt_assert(cell.format().protection_applied());
xlnt_assert_equals(cell.protection(), protection);
2017-04-14 07:01:30 +08:00
xlnt_assert(cell.has_format());
2016-06-20 02:43:41 +08:00
cell.clear_format();
xlnt_assert(!cell.has_format());
2016-06-20 02:43:41 +08:00
}
2017-04-14 07:01:30 +08:00
2016-06-20 02:43:41 +08:00
void test_style()
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2017-04-14 07:01:30 +08:00
xlnt_assert(!cell.has_style());
2017-04-14 07:01:30 +08:00
auto test_style = wb.create_style("test_style");
2016-08-18 19:34:18 +08:00
test_style.number_format(xlnt::number_format::date_ddmmyyyy(), true);
2017-04-14 07:01:30 +08:00
cell.style(test_style);
xlnt_assert(cell.has_style());
xlnt_assert_equals(cell.style().number_format(), xlnt::number_format::date_ddmmyyyy());
xlnt_assert_equals(cell.style(), test_style);
2016-06-20 02:43:41 +08:00
auto other_style = wb.create_style("other_style");
2016-08-18 19:34:18 +08:00
other_style.number_format(xlnt::number_format::date_time2(), true);
2017-04-14 07:01:30 +08:00
cell.style("other_style");
xlnt_assert_equals(cell.style().number_format(), xlnt::number_format::date_time2());
xlnt_assert_equals(cell.style(), other_style);
2017-04-14 07:01:30 +08:00
auto last_style = wb.create_style("last_style");
2016-08-18 19:34:18 +08:00
last_style.number_format(xlnt::number_format::percentage(), true);
2017-04-14 07:01:30 +08:00
cell.style(last_style);
xlnt_assert_equals(cell.style().number_format(), xlnt::number_format::percentage());
xlnt_assert_equals(cell.style(), last_style);
2017-04-14 07:01:30 +08:00
xlnt_assert_throws(cell.style("doesn't exist"), xlnt::key_not_found);
2017-04-14 07:01:30 +08:00
2016-06-20 02:43:41 +08:00
cell.clear_style();
2017-04-14 07:01:30 +08:00
xlnt_assert(!cell.has_style());
xlnt_assert_throws(cell.style(), xlnt::invalid_attribute);
2016-06-20 02:43:41 +08:00
}
2017-04-14 07:01:30 +08:00
2016-06-20 02:43:41 +08:00
void test_print()
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
2016-06-20 02:43:41 +08:00
{
auto cell = ws.cell("A1");
2016-06-20 02:43:41 +08:00
std::stringstream ss;
ss << cell;
auto stream_string = ss.str();
xlnt_assert_equals(cell.to_string(), stream_string);
xlnt_assert_equals(stream_string, "");
2016-06-20 02:43:41 +08:00
}
{
auto cell = ws.cell("A2");
2016-06-20 02:43:41 +08:00
cell.value(false);
2016-06-20 02:43:41 +08:00
std::stringstream ss;
ss << cell;
auto stream_string = ss.str();
xlnt_assert_equals(cell.to_string(), stream_string);
xlnt_assert_equals(stream_string, "FALSE");
2016-06-20 02:43:41 +08:00
}
2017-04-14 07:01:30 +08:00
2016-06-20 02:43:41 +08:00
{
auto cell = ws.cell("A3");
2016-06-20 02:43:41 +08:00
cell.value(true);
2016-06-20 02:43:41 +08:00
std::stringstream ss;
ss << cell;
auto stream_string = ss.str();
xlnt_assert_equals(cell.to_string(), stream_string);
xlnt_assert_equals(stream_string, "TRUE");
2016-06-20 02:43:41 +08:00
}
2017-04-14 07:01:30 +08:00
2016-06-20 02:43:41 +08:00
{
auto cell = ws.cell("A4");
2016-06-20 02:43:41 +08:00
cell.value(1.234);
2016-06-20 02:43:41 +08:00
std::stringstream ss;
ss << cell;
auto stream_string = ss.str();
xlnt_assert_equals(cell.to_string(), stream_string);
xlnt_assert_equals(stream_string, "1.234");
2016-06-20 02:43:41 +08:00
}
2017-04-14 07:01:30 +08:00
2016-06-20 02:43:41 +08:00
{
auto cell = ws.cell("A5");
2016-06-20 02:43:41 +08:00
cell.error("#REF");
2016-06-20 02:43:41 +08:00
std::stringstream ss;
ss << cell;
auto stream_string = ss.str();
xlnt_assert_equals(cell.to_string(), stream_string);
xlnt_assert_equals(stream_string, "#REF");
2016-06-20 02:43:41 +08:00
}
2017-04-14 07:01:30 +08:00
2016-06-20 02:43:41 +08:00
{
auto cell = ws.cell("A6");
2016-06-20 02:43:41 +08:00
cell.value("test");
2016-06-20 02:43:41 +08:00
std::stringstream ss;
ss << cell;
auto stream_string = ss.str();
xlnt_assert_equals(cell.to_string(), stream_string);
xlnt_assert_equals(stream_string, "test");
2016-06-20 02:43:41 +08:00
}
}
void test_values()
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
2016-06-20 02:43:41 +08:00
cell.value(static_cast<int>(4));
xlnt_assert_equals(cell.value<int>(), 4);
2016-06-20 02:43:41 +08:00
cell.value(static_cast<unsigned int>(3));
xlnt_assert_equals(cell.value<unsigned>(), 3);
2016-06-20 02:43:41 +08:00
cell.value(static_cast<unsigned long long>(4));
xlnt_assert_equals(cell.value<unsigned long long>(), 4);
2016-06-20 02:43:41 +08:00
cell.value(static_cast<long long int>(3));
xlnt_assert_equals(cell.value<long long int>(), 3);
2016-06-20 02:43:41 +08:00
cell.value(static_cast<float>(3.14));
xlnt_assert_delta(cell.value<float>(), 3.14, 0.001);
2016-06-20 02:43:41 +08:00
cell.value(static_cast<double>(3.141592));
xlnt_assert_equals(cell.value<double>(), 3.141592);
2016-06-20 02:43:41 +08:00
auto cell2 = ws.cell("A2");
2017-07-03 10:15:42 +08:00
cell2.value(std::string(100000, 'a'));
cell.value(cell2);
2017-07-03 10:15:42 +08:00
xlnt_assert_equals(cell.value<std::string>(), std::string(32767, 'a'));
2014-07-20 02:43:48 +08:00
}
2016-07-19 09:38:16 +08:00
void test_reference()
{
xlnt::cell_reference_hash hash;
xlnt_assert_differs(hash(xlnt::cell_reference("A2")), hash(xlnt::cell_reference(1, 1)));
xlnt_assert_equals(hash(xlnt::cell_reference("A2")), hash(xlnt::cell_reference(1, 2)));
2016-07-19 09:38:16 +08:00
xlnt_assert_equals((xlnt::cell_reference("A1"), xlnt::cell_reference("B2")), xlnt::range_reference("A1:B2"));
2016-07-19 09:38:16 +08:00
xlnt_assert_throws(xlnt::cell_reference("A1&"), xlnt::invalid_cell_reference);
xlnt_assert_throws(xlnt::cell_reference("A"), xlnt::invalid_cell_reference);
2016-07-19 09:38:16 +08:00
auto ref = xlnt::cell_reference("$B$7");
xlnt_assert_equals(ref.row_absolute(), true);
xlnt_assert_equals(ref.column_absolute(), true);
ref = xlnt::cell_reference("$B7");
xlnt_assert_equals(ref.row_absolute(), false);
xlnt_assert_equals(ref.column_absolute(), true);
ref = xlnt::cell_reference("B$7");
xlnt_assert_equals(ref.row_absolute(), true);
xlnt_assert_equals(ref.column_absolute(), false);
2016-07-19 09:38:16 +08:00
xlnt_assert(xlnt::cell_reference("A1") == "A1");
xlnt_assert(xlnt::cell_reference("A1") != "A2");
2016-07-19 09:38:16 +08:00
}
2016-07-21 08:10:19 +08:00
void test_anchor()
{
xlnt::workbook wb;
2017-04-14 07:01:30 +08:00
auto cell = wb.active_sheet().cell("A1");
auto anchor = cell.anchor();
xlnt_assert_equals(anchor.first, 0);
xlnt_assert_equals(anchor.second, 0);
2016-07-21 08:10:19 +08:00
}
2016-07-24 07:15:17 +08:00
void test_hyperlink()
{
xlnt::workbook wb;
2017-04-14 07:01:30 +08:00
auto cell = wb.active_sheet().cell("A1");
xlnt_assert(!cell.has_hyperlink());
xlnt_assert_throws(cell.hyperlink(), xlnt::invalid_attribute);
xlnt_assert_throws(cell.hyperlink(""), xlnt::invalid_parameter);
// link without optional display
const std::string link1("http://example.com");
cell.hyperlink(link1);
xlnt_assert(cell.has_hyperlink());
xlnt_assert(cell.hyperlink().external());
xlnt_assert_equals(cell.hyperlink().url(), link1);
xlnt_assert_equals(cell.hyperlink().relationship().target().to_string(), link1);
xlnt_assert_equals(cell.hyperlink().display(), link1);
cell.clear_value();
// link with display
const std::string link2("http://example2.com");
const std::string display_txt("notaurl");
cell.hyperlink(link2, display_txt);
xlnt_assert(cell.has_hyperlink());
xlnt_assert(cell.hyperlink().external());
xlnt_assert_equals(cell.hyperlink().url(), link2);
xlnt_assert_equals(cell.hyperlink().relationship().target().to_string(), link2);
xlnt_assert_equals(cell.hyperlink().display(), display_txt);
// relative (local) url
const std::string local("../test_local");
cell.hyperlink(local);
xlnt_assert(cell.has_hyperlink());
xlnt_assert(cell.hyperlink().external());
xlnt_assert_equals(cell.hyperlink().url(), local);
xlnt_assert_equals(cell.hyperlink().relationship().target().to_string(), local);
// value
int cell_test_val = 123;
cell.value(cell_test_val);
std::string cell_value_str = std::to_string(cell_test_val);
cell.hyperlink(link2, display_txt);
xlnt_assert_equals(cell.value<int>(), 123);
xlnt_assert_equals(cell.hyperlink().display(), cell_value_str); // display text ignored
cell.clear_value();
// cell overload without display
const std::string cell_target_str("A2");
auto cell_target = wb.active_sheet().cell(cell_target_str);
std::string link3 = wb.active_sheet().title() + '!' + cell_target_str; // Sheet1!A2
cell.hyperlink(cell_target);
xlnt_assert(cell.has_hyperlink());
xlnt_assert(!cell.hyperlink().external());
xlnt_assert_equals(cell.hyperlink().target_range(), link3);
xlnt_assert_equals(cell.hyperlink().display(), link3);
cell.clear_value();
// cell overload with display
cell.hyperlink(cell_target, display_txt);
xlnt_assert(cell.has_hyperlink());
xlnt_assert(!cell.hyperlink().external());
xlnt_assert_equals(cell.hyperlink().target_range(), link3);
xlnt_assert_equals(cell.hyperlink().display(), display_txt);
// value
cell.value(cell_test_val);
cell.hyperlink(cell_target, display_txt);
xlnt_assert_equals(cell.value<int>(), 123);
xlnt_assert_equals(cell.hyperlink().display(), cell_value_str); // display text ignored
cell.clear_value();
// range overload without display
const std::string range_target_str("A2:A5");
xlnt::range range_target(wb.active_sheet(), xlnt::range_reference(range_target_str));
std::string link4 = wb.active_sheet().title() + '!' + range_target_str; // Sheet1!A2:A5
cell.hyperlink(range_target);
xlnt_assert(cell.has_hyperlink());
xlnt_assert(!cell.hyperlink().external());
xlnt_assert_equals(cell.hyperlink().target_range(), link4);
xlnt_assert_equals(cell.hyperlink().display(), link4);
cell.clear_value();
// range overload with display
cell.hyperlink(range_target, display_txt);
xlnt_assert(cell.has_hyperlink());
xlnt_assert(!cell.hyperlink().external());
xlnt_assert_equals(cell.hyperlink().target_range(), link4);
xlnt_assert_equals(cell.hyperlink().display(), display_txt);
// value
cell.value(cell_test_val);
cell.hyperlink(range_target, display_txt);
xlnt_assert_equals(cell.value<int>(), 123);
xlnt_assert_equals(cell.hyperlink().display(), cell_value_str); // display text ignored
cell.clear_value();
2016-07-24 07:15:17 +08:00
}
2016-10-29 22:23:04 +08:00
void test_comment()
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell = ws.cell("A1");
xlnt_assert(!cell.has_comment());
xlnt_assert_throws(cell.comment(), xlnt::exception);
cell.comment(xlnt::comment("comment", "author"));
xlnt_assert(cell.has_comment());
xlnt_assert_equals(cell.comment(), xlnt::comment("comment", "author"));
cell.clear_comment();
xlnt_assert(!cell.has_comment());
xlnt_assert_throws(cell.comment(), xlnt::exception);
xlnt::comment comment_with_size("test comment", "author");
comment_with_size.size(1000, 30);
cell.comment(comment_with_size);
xlnt_assert_equals(cell.comment(), comment_with_size);
2016-10-29 22:23:04 +08:00
}
void test_copy_and_compare()
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell1 = ws.cell("A1");
auto cell2 = ws.cell("A2");
xlnt_assert_equals(cell1, cell1);
xlnt_assert_equals(cell2, cell2);
xlnt_assert_differs(cell1, cell2);
xlnt_assert_differs(cell2, cell1);
// nullptr equality
xlnt_assert(nullptr == cell1);
xlnt_assert(cell1 == nullptr);
cell1.value("test");
xlnt_assert(!(nullptr == cell1));
xlnt_assert(!(cell1 == nullptr));
// copy
xlnt::cell cell3(cell1);
xlnt_assert_equals(cell1, cell3);
// assign
cell3 = cell2;
xlnt_assert_equals(cell2, cell3);
}
void test_cell_phonetic_properties()
{
xlnt::workbook wb;
auto ws = wb.active_sheet();
auto cell1 = ws.cell("A1");
xlnt_assert_equals(cell1.phonetics_visible(), false);
cell1.show_phonetics(true);
xlnt_assert_equals(cell1.phonetics_visible(), true);
cell1.show_phonetics(false);
xlnt_assert_equals(cell1.phonetics_visible(), false);
}
2014-05-09 03:32:12 +08:00
};
2020-02-09 01:12:59 +08:00
static cell_test_suite x{};