xlnt/source/workbook/tests/test_workbook.hpp

287 lines
8.7 KiB
C++
Raw Normal View History

2014-05-08 15:32:12 -04:00
#pragma once
2014-05-21 19:17:56 -04:00
#include <algorithm>
2014-05-08 15:32:12 -04:00
#include <iostream>
#include <cxxtest/TestSuite.h>
2014-06-05 16:19:31 -04:00
#include <xlnt/xlnt.hpp>
2014-06-18 15:12:44 -04:00
#include "helpers/temporary_file.hpp"
2014-05-08 15:32:12 -04:00
2016-03-06 10:39:50 +08:00
//checked with 52f25d6
2014-06-05 16:19:31 -04:00
class test_workbook : public CxxTest::TestSuite
2014-05-08 15:32:12 -04:00
{
public:
void test_get_active_sheet()
{
2014-05-18 21:29:19 -04:00
xlnt::workbook wb;
2016-03-06 10:39:50 +08:00
TS_ASSERT_EQUALS(wb.get_active_sheet(), wb[0]);
2014-05-08 15:32:12 -04:00
}
void test_create_sheet()
{
2014-05-18 21:29:19 -04:00
xlnt::workbook wb;
2016-03-06 10:39:50 +08:00
auto new_sheet = wb.create_sheet();
auto last = std::distance(wb.begin(), wb.end()) - 1;
TS_ASSERT_EQUALS(new_sheet, wb[last]);
2014-05-08 15:32:12 -04:00
}
2016-03-06 10:39:50 +08:00
void test_add_correct_sheet()
{
xlnt::workbook wb;
auto new_sheet = wb.create_sheet();
2016-06-23 09:33:10 +01:00
new_sheet.get_cell("A6").set_value(1.498);
2016-07-21 22:14:00 -04:00
wb.copy_sheet(new_sheet);
TS_ASSERT(wb[1].compare(wb[2], false));
2016-06-23 09:33:10 +01:00
wb.create_sheet().get_cell("A6").set_value(1.497);
TS_ASSERT(!wb[1].compare(wb[3], false));
2014-05-08 15:32:12 -04:00
}
2016-03-06 10:39:50 +08:00
void test_add_sheet_from_other_workbook()
{
xlnt::workbook wb1, wb2;
auto new_sheet = wb1.get_active_sheet();
2016-07-29 18:55:49 -04:00
TS_ASSERT_THROWS(wb2.copy_sheet(new_sheet), xlnt::invalid_parameter);
2016-07-17 14:59:11 -04:00
TS_ASSERT_THROWS(wb2.get_index(new_sheet), std::runtime_error);
}
void test_add_sheet_at_index()
{
xlnt::workbook wb;
auto ws = wb.get_active_sheet();
ws.get_cell("B3").set_value(2);
ws.set_title("Active");
2016-07-21 22:14:00 -04:00
wb.copy_sheet(ws, 0);
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS(wb.get_sheet_titles().at(0), "Sheet1");
2016-07-17 14:59:11 -04:00
TS_ASSERT_EQUALS(wb.get_sheet_by_index(0).get_cell("B3").get_value<int>(), 2);
2016-08-01 18:33:43 -04:00
TS_ASSERT_EQUALS(wb.get_sheet_titles().at(1), "Active");
2016-07-17 14:59:11 -04:00
TS_ASSERT_EQUALS(wb.get_sheet_by_index(1).get_cell("B3").get_value<int>(), 2);
2016-03-06 10:39:50 +08:00
}
2014-05-08 15:32:12 -04:00
void test_remove_sheet()
{
2016-07-17 14:59:11 -04:00
xlnt::workbook wb, wb2;
2014-05-18 21:29:19 -04:00
auto new_sheet = wb.create_sheet(0);
2016-07-18 03:20:20 +08:00
new_sheet.set_title("removed");
2014-05-12 13:42:28 -04:00
wb.remove_sheet(new_sheet);
2016-07-21 23:04:36 -04:00
TS_ASSERT(!wb.contains("removed"));
2016-07-17 14:59:11 -04:00
TS_ASSERT_THROWS(wb.remove_sheet(wb2.get_active_sheet()), std::runtime_error);
2014-05-08 15:32:12 -04:00
}
2016-08-05 01:52:05 -04:00
void test_get_sheet_by_title()
2014-05-08 15:32:12 -04:00
{
2014-05-18 21:29:19 -04:00
xlnt::workbook wb;
auto new_sheet = wb.create_sheet();
std::string title = "my sheet";
new_sheet.set_title(title);
2016-08-05 01:52:05 -04:00
auto found_sheet = wb.get_sheet_by_title(title);
2014-05-18 21:29:19 -04:00
TS_ASSERT_EQUALS(new_sheet, found_sheet);
2016-08-05 01:52:05 -04:00
TS_ASSERT_THROWS(wb.get_sheet_by_title("error"), xlnt::key_not_found);
const auto &wb_const = wb;
2016-08-05 01:52:05 -04:00
TS_ASSERT_THROWS(wb_const.get_sheet_by_title("error"), xlnt::key_not_found);
2014-05-18 21:29:19 -04:00
}
2016-08-05 01:52:05 -04:00
void test_get_sheet_by_title_const()
{
xlnt::workbook wb;
auto new_sheet = wb.create_sheet();
std::string title = "my sheet";
new_sheet.set_title(title);
const xlnt::workbook& wbconst = wb;
2016-08-05 01:52:05 -04:00
auto found_sheet = wbconst.get_sheet_by_title(title);
TS_ASSERT_EQUALS(new_sheet, found_sheet);
}
2016-03-06 10:39:50 +08:00
void test_index_operator() // test_getitem
{
xlnt::workbook wb;
2016-08-12 23:06:25 -04:00
TS_ASSERT_THROWS_NOTHING(wb["Sheet1"]);
2016-07-29 18:55:49 -04:00
TS_ASSERT_THROWS(wb["NotThere"], xlnt::key_not_found);
2016-03-06 10:39:50 +08:00
}
// void test_delitem() {} doesn't make sense in c++
void test_contains()
{
xlnt::workbook wb;
2016-08-12 23:06:25 -04:00
TS_ASSERT(wb.contains("Sheet1"));
2016-03-06 10:39:50 +08:00
TS_ASSERT(!wb.contains("NotThere"));
}
void test_iter()
2014-05-18 21:29:19 -04:00
{
xlnt::workbook wb;
2016-03-06 10:39:50 +08:00
for(auto ws : wb)
{
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS(ws.get_title(), "Sheet1");
2016-03-06 10:39:50 +08:00
}
2014-05-08 15:32:12 -04:00
}
2016-03-06 10:39:50 +08:00
void test_get_index()
2014-05-08 15:32:12 -04:00
{
2014-05-18 21:29:19 -04:00
xlnt::workbook wb;
2016-07-17 14:59:11 -04:00
wb.create_sheet().set_title("1");
wb.create_sheet().set_title("2");
2016-08-05 01:52:05 -04:00
auto sheet_index = wb.get_index(wb.get_sheet_by_title("1"));
2016-07-17 14:59:11 -04:00
TS_ASSERT_EQUALS(sheet_index, 1);
2016-08-05 01:52:05 -04:00
sheet_index = wb.get_index(wb.get_sheet_by_title("2"));
2016-07-17 14:59:11 -04:00
TS_ASSERT_EQUALS(sheet_index, 2);
2014-05-08 15:32:12 -04:00
}
void test_get_sheet_names()
{
2014-05-18 21:29:19 -04:00
xlnt::workbook wb;
2016-08-01 18:33:43 -04:00
wb.create_sheet().set_title("test_get_sheet_titles");
2016-08-12 23:06:25 -04:00
const std::vector<std::string> expected_titles = { "Sheet1", "test_get_sheet_titles" };
2016-08-01 18:33:43 -04:00
TS_ASSERT_EQUALS(wb.get_sheet_titles(), expected_titles);
2014-05-08 15:32:12 -04:00
}
2016-03-06 10:39:50 +08:00
2014-05-08 15:32:12 -04:00
void test_add_named_range()
{
2016-07-17 14:59:11 -04:00
xlnt::workbook wb, wb2;
2014-05-18 21:29:19 -04:00
auto new_sheet = wb.create_sheet();
wb.create_named_range("test_nr", new_sheet, "A1");
TS_ASSERT(new_sheet.has_named_range("test_nr"));
TS_ASSERT(wb.has_named_range("test_nr"));
2016-07-17 14:59:11 -04:00
TS_ASSERT_THROWS(wb2.create_named_range("test_nr", new_sheet, "A1"), std::runtime_error);
2014-05-08 15:32:12 -04:00
}
2016-03-06 10:39:50 +08:00
void test_get_named_range()
2014-05-08 15:32:12 -04:00
{
2014-05-18 21:29:19 -04:00
xlnt::workbook wb;
auto new_sheet = wb.create_sheet();
wb.create_named_range("test_nr", new_sheet, "A1");
auto found_range = wb.get_named_range("test_nr");
auto expected_range = new_sheet.get_range("A1");
TS_ASSERT_EQUALS(expected_range, found_range);
2016-07-17 14:59:11 -04:00
TS_ASSERT_THROWS(wb.get_named_range("test_nr2"), std::runtime_error);
2014-05-08 15:32:12 -04:00
}
2014-05-18 21:29:19 -04:00
void test_remove_named_range()
2014-05-08 15:32:12 -04:00
{
2014-05-18 21:29:19 -04:00
xlnt::workbook wb;
auto new_sheet = wb.create_sheet();
wb.create_named_range("test_nr", new_sheet, "A1");
wb.remove_named_range("test_nr");
TS_ASSERT(!new_sheet.has_named_range("test_nr"));
TS_ASSERT(!wb.has_named_range("test_nr"));
2016-07-17 14:59:11 -04:00
TS_ASSERT_THROWS(wb.remove_named_range("test_nr2"), std::runtime_error);
2014-05-08 15:32:12 -04:00
}
2016-07-09 10:02:58 -04:00
void test_post_increment_iterator()
{
xlnt::workbook wb;
2016-08-01 18:33:43 -04:00
wb.create_sheet().set_title("Sheet2");
2016-08-12 23:06:25 -04:00
wb.create_sheet().set_title("Sheet3");
2016-07-09 10:02:58 -04:00
auto iter = wb.begin();
TS_ASSERT_EQUALS((*(iter++)).get_title(), "Sheet1");
TS_ASSERT_EQUALS((*(iter++)).get_title(), "Sheet2");
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS((*(iter++)).get_title(), "Sheet3");
2016-07-09 10:02:58 -04:00
TS_ASSERT_EQUALS(iter, wb.end());
2016-07-09 10:20:08 -04:00
const auto wb_const = wb;
auto const_iter = wb_const.begin();
TS_ASSERT_EQUALS((*(const_iter++)).get_title(), "Sheet1");
TS_ASSERT_EQUALS((*(const_iter++)).get_title(), "Sheet2");
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS((*(const_iter++)).get_title(), "Sheet3");
2016-07-09 10:20:08 -04:00
TS_ASSERT_EQUALS(const_iter, wb_const.end());
2016-07-09 10:02:58 -04:00
}
void test_copy_iterator()
{
xlnt::workbook wb;
2016-08-01 18:33:43 -04:00
wb.create_sheet().set_title("Sheet2");
2016-08-12 23:06:25 -04:00
wb.create_sheet().set_title("Sheet3");
2016-07-09 10:02:58 -04:00
auto iter = wb.begin();
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS((*iter).get_title(), "Sheet1");
2016-07-09 10:02:58 -04:00
iter++;
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS((*iter).get_title(), "Sheet2");
2016-07-09 10:02:58 -04:00
auto copy = wb.begin();
copy = iter;
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS((*iter).get_title(), "Sheet2");
2016-07-09 10:02:58 -04:00
TS_ASSERT_EQUALS(iter, copy);
iter++;
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS((*iter).get_title(), "Sheet3");
2016-07-09 10:02:58 -04:00
TS_ASSERT_DIFFERS(iter, copy);
copy++;
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS((*iter).get_title(), "Sheet3");
2016-07-09 10:02:58 -04:00
TS_ASSERT_EQUALS(iter, copy);
}
2016-03-06 10:39:50 +08:00
2016-07-16 15:57:50 -04:00
void test_manifest()
{
2016-08-05 01:52:05 -04:00
xlnt::manifest m;
2016-07-22 22:48:50 -04:00
TS_ASSERT(!m.has_default_type("xml"));
2016-08-05 01:52:05 -04:00
TS_ASSERT_THROWS(m.get_default_type("xml"), xlnt::key_not_found);
TS_ASSERT(!m.has_relationship(xlnt::path("/"), xlnt::relationship::type::office_document));
2016-08-12 23:06:25 -04:00
TS_ASSERT(m.get_relationships(xlnt::path("xl/workbook.xml")).empty());
2016-07-17 14:59:11 -04:00
}
void test_memory()
{
xlnt::workbook wb, wb2;
wb.get_active_sheet().set_title("swap");
std::swap(wb, wb2);
2016-08-12 23:06:25 -04:00
TS_ASSERT_EQUALS(wb.get_active_sheet().get_title(), "Sheet1");
2016-07-17 14:59:11 -04:00
TS_ASSERT_EQUALS(wb2.get_active_sheet().get_title(), "swap");
wb = wb2;
TS_ASSERT_EQUALS(wb.get_active_sheet().get_title(), "swap");
}
void test_clear()
{
xlnt::workbook wb;
xlnt::style s = wb.create_style("s");
wb.get_active_sheet().get_cell("B2").set_value("B2");
wb.get_active_sheet().get_cell("B2").style(s);
2016-07-17 14:59:11 -04:00
TS_ASSERT(wb.get_active_sheet().get_cell("B2").has_style());
wb.clear_styles();
TS_ASSERT(!wb.get_active_sheet().get_cell("B2").has_style());
2016-08-18 07:34:18 -04:00
xlnt::format format = wb.create_format();
2016-07-17 14:59:11 -04:00
xlnt::font font;
2016-08-18 07:34:18 -04:00
font.size(41);
format.font(font, true);
wb.get_active_sheet().get_cell("B2").format(format);
2016-07-17 14:59:11 -04:00
TS_ASSERT(wb.get_active_sheet().get_cell("B2").has_format());
wb.clear_formats();
TS_ASSERT(!wb.get_active_sheet().get_cell("B2").has_format());
wb.clear();
2016-08-01 18:33:43 -04:00
TS_ASSERT(wb.get_sheet_titles().empty());
2016-07-17 14:59:11 -04:00
}
void test_comparison()
{
xlnt::workbook wb, wb2;
TS_ASSERT(wb == wb);
TS_ASSERT(!(wb != wb));
TS_ASSERT(!(wb == wb2));
TS_ASSERT(wb != wb2)
const auto &wb_const = wb;
//TODO these aren't tests...
wb_const.get_manifest();
2016-08-03 00:12:18 -04:00
TS_ASSERT(wb.has_theme());
wb.create_style("style1");
wb.style("style1");
wb_const.style("style1");
}
2014-05-08 15:32:12 -04:00
};