2016-08-06 10:40:17 -04:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <cxxtest/TestSuite.h>
|
|
|
|
|
2016-10-30 15:48:40 -04:00
|
|
|
#include <detail/vector_streambuf.hpp>
|
2016-08-06 10:40:17 -04:00
|
|
|
#include <helpers/temporary_file.hpp>
|
|
|
|
#include <helpers/path_helper.hpp>
|
|
|
|
#include <helpers/xml_helper.hpp>
|
|
|
|
#include <xlnt/workbook/workbook.hpp>
|
|
|
|
|
|
|
|
class test_produce_xlsx : public CxxTest::TestSuite
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
bool workbook_matches_file(xlnt::workbook &wb, const xlnt::path &file)
|
|
|
|
{
|
2016-10-30 15:48:40 -04:00
|
|
|
std::vector<std::uint8_t> wb_data;
|
|
|
|
wb.save(wb_data);
|
2016-08-06 10:40:17 -04:00
|
|
|
|
2016-10-30 15:48:40 -04:00
|
|
|
std::ifstream file_stream(file.string(), std::ios::binary);
|
|
|
|
std::vector<std::uint8_t> file_data;
|
2016-08-06 10:40:17 -04:00
|
|
|
|
2016-10-30 15:48:40 -04:00
|
|
|
{
|
|
|
|
xlnt::detail::vector_ostreambuf file_data_buffer(file_data);
|
|
|
|
std::ostream file_data_stream(&file_data_buffer);
|
|
|
|
file_data_stream << file_stream.rdbuf();
|
|
|
|
}
|
|
|
|
|
|
|
|
return xml_helper::xlsx_archives_match(wb_data, file_data);
|
2016-08-06 10:40:17 -04:00
|
|
|
}
|
|
|
|
|
2016-12-29 18:36:29 -05:00
|
|
|
void test_produce_empty()
|
2016-08-13 14:45:26 -04:00
|
|
|
{
|
2017-01-22 14:54:07 -05:00
|
|
|
xlnt::workbook wb;
|
|
|
|
const auto path = path_helper::data_directory("3_default.xlsx");
|
|
|
|
TS_ASSERT(workbook_matches_file(wb, path));
|
2016-08-16 00:23:49 -04:00
|
|
|
}
|
|
|
|
|
2016-08-18 07:34:18 -04:00
|
|
|
void test_produce_simple_excel()
|
|
|
|
{
|
2016-12-29 18:36:29 -05:00
|
|
|
xlnt::workbook wb;
|
2016-12-02 14:37:50 +01:00
|
|
|
auto ws = wb.active_sheet();
|
2016-08-18 07:34:18 -04:00
|
|
|
|
|
|
|
auto bold_font = xlnt::font().bold(true);
|
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A1").value("Type");
|
|
|
|
ws.cell("A1").font(bold_font);
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("B1").value("Value");
|
|
|
|
ws.cell("B1").font(bold_font);
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A2").value("null");
|
|
|
|
ws.cell("B2").value(nullptr);
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A3").value("bool (true)");
|
|
|
|
ws.cell("B3").value(true);
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A4").value("bool (false)");
|
|
|
|
ws.cell("B4").value(false);
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2017-03-21 19:31:23 -04:00
|
|
|
ws.cell("A5").value("number (int)");
|
|
|
|
ws.cell("B5").value(std::numeric_limits<int>::max());
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2017-03-21 19:31:23 -04:00
|
|
|
ws.cell("A5").value("number (unsigned int)");
|
|
|
|
ws.cell("B5").value(std::numeric_limits<unsigned int>::max());
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2017-03-21 19:31:23 -04:00
|
|
|
ws.cell("A6").value("number (long long int)");
|
|
|
|
ws.cell("B6").value(std::numeric_limits<long long int>::max());
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2017-03-21 19:31:23 -04:00
|
|
|
ws.cell("A6").value("number (unsigned long long int)");
|
|
|
|
ws.cell("B6").value(std::numeric_limits<unsigned long long int>::max());
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A13").value("number (float)");
|
|
|
|
ws.cell("B13").value(std::numeric_limits<float>::max());
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A14").value("number (double)");
|
|
|
|
ws.cell("B14").value(std::numeric_limits<double>::max());
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A15").value("number (long double)");
|
|
|
|
ws.cell("B15").value(std::numeric_limits<long double>::max());
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A16").value("text (char *)");
|
|
|
|
ws.cell("B16").value("string");
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A17").value("text (std::string)");
|
|
|
|
ws.cell("B17").value(std::string("string"));
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A18").value("date");
|
|
|
|
ws.cell("B18").value(xlnt::date(2016, 2, 3));
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A19").value("time");
|
|
|
|
ws.cell("B19").value(xlnt::time(1, 2, 3, 4));
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A20").value("datetime");
|
|
|
|
ws.cell("B20").value(xlnt::datetime(2016, 2, 3, 1, 2, 3, 4));
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
ws.cell("A21").value("timedelta");
|
|
|
|
ws.cell("B21").value(xlnt::timedelta(1, 2, 3, 4, 5));
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-09-07 18:48:08 -04:00
|
|
|
ws.freeze_panes("B2");
|
2016-08-18 07:34:18 -04:00
|
|
|
|
2016-10-25 20:21:58 -04:00
|
|
|
std::vector<std::uint8_t> temp_buffer;
|
|
|
|
wb.save(temp_buffer);
|
|
|
|
TS_ASSERT(!temp_buffer.empty());
|
2016-08-18 07:34:18 -04:00
|
|
|
}
|
2016-10-22 13:53:44 -04:00
|
|
|
|
|
|
|
void test_save_after_sheet_deletion()
|
|
|
|
{
|
|
|
|
xlnt::workbook workbook;
|
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
TS_ASSERT_EQUALS(workbook.sheet_titles().size(), 1);
|
2016-10-22 13:53:44 -04:00
|
|
|
|
|
|
|
auto sheet = workbook.create_sheet();
|
2016-12-02 14:37:50 +01:00
|
|
|
sheet.title("XXX1");
|
|
|
|
TS_ASSERT_EQUALS(workbook.sheet_titles().size(), 2);
|
2016-10-22 13:53:44 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
workbook.remove_sheet(workbook.sheet_by_title("XXX1"));
|
|
|
|
TS_ASSERT_EQUALS(workbook.sheet_titles().size(), 1);
|
2016-10-22 13:53:44 -04:00
|
|
|
|
2016-10-25 20:21:58 -04:00
|
|
|
std::vector<std::uint8_t> temp_buffer;
|
|
|
|
TS_ASSERT_THROWS_NOTHING(workbook.save(temp_buffer));
|
|
|
|
TS_ASSERT(!temp_buffer.empty());
|
2016-10-22 13:53:44 -04:00
|
|
|
}
|
2016-10-29 16:31:30 -04:00
|
|
|
|
2017-02-17 23:11:06 -06:00
|
|
|
void test_write_comments_hyperlinks_formulae()
|
2016-10-29 16:31:30 -04:00
|
|
|
{
|
|
|
|
xlnt::workbook wb;
|
2016-12-02 14:37:50 +01:00
|
|
|
auto sheet1 = wb.active_sheet();
|
2016-12-23 06:51:30 -05:00
|
|
|
auto comment_font = xlnt::font().bold(true).size(10).color(xlnt::indexed_color(81)).name("Calibri");
|
2016-10-29 16:31:30 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
sheet1.cell("A1").value("Sheet1!A1");
|
2016-12-23 06:51:30 -05:00
|
|
|
sheet1.cell("A1").comment("Sheet1 comment", comment_font, "Microsoft Office User");
|
2016-11-27 19:12:38 +01:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
sheet1.cell("A2").value("Sheet1!A2");
|
2016-12-23 06:51:30 -05:00
|
|
|
sheet1.cell("A2").comment("Sheet1 comment2", comment_font, "Microsoft Office User");
|
2016-11-27 19:12:38 +01:00
|
|
|
|
2017-02-17 23:11:06 -06:00
|
|
|
sheet1.cell("A4").hyperlink("https://microsoft.com", "hyperlink1");
|
|
|
|
sheet1.cell("A5").hyperlink("https://google.com");
|
|
|
|
sheet1.cell("A6").hyperlink(sheet1.cell("A1"));
|
|
|
|
sheet1.cell("A7").hyperlink("mailto:invalid@example.com?subject=important");
|
|
|
|
|
|
|
|
sheet1.cell("C1").formula("=CONCATENATE(C2,C3)");
|
|
|
|
sheet1.cell("C2").value("a");
|
|
|
|
sheet1.cell("C3").value("b");
|
|
|
|
|
2016-10-29 16:31:30 -04:00
|
|
|
auto sheet2 = wb.create_sheet();
|
2016-12-02 14:37:50 +01:00
|
|
|
sheet2.cell("A1").value("Sheet2!A1");
|
2016-12-23 06:51:30 -05:00
|
|
|
sheet2.cell("A2").comment("Sheet2 comment", comment_font, "Microsoft Office User");
|
2016-10-29 16:31:30 -04:00
|
|
|
|
2016-12-02 14:37:50 +01:00
|
|
|
sheet2.cell("A2").value("Sheet2!A2");
|
2016-12-23 06:51:30 -05:00
|
|
|
sheet2.cell("A2").comment("Sheet2 comment2", comment_font, "Microsoft Office User");
|
2016-10-29 16:31:30 -04:00
|
|
|
|
2017-02-17 23:11:06 -06:00
|
|
|
sheet2.cell("A4").hyperlink("https://apple.com", "hyperlink2");
|
|
|
|
|
|
|
|
sheet2.cell("C1").formula("=C2*C3");
|
|
|
|
sheet2.cell("C2").value(2);
|
|
|
|
sheet2.cell("C3").value(3);
|
|
|
|
|
2017-01-22 14:54:07 -05:00
|
|
|
const auto path = path_helper::data_directory("10_comments_hyperlinks_formulae.xlsx");
|
|
|
|
TS_ASSERT(workbook_matches_file(wb, path));
|
2016-10-29 16:31:30 -04:00
|
|
|
}
|
2017-01-02 19:12:23 -05:00
|
|
|
|
|
|
|
void test_save_after_clear_all_formulae()
|
|
|
|
{
|
|
|
|
xlnt::workbook wb;
|
2017-01-22 14:54:07 -05:00
|
|
|
const auto path = path_helper::data_directory("10_comments_hyperlinks_formulae.xlsx");
|
|
|
|
wb.load(path);
|
|
|
|
|
|
|
|
auto ws1 = wb.sheet_by_index(0);
|
|
|
|
TS_ASSERT(ws1.cell("C1").has_formula());
|
|
|
|
TS_ASSERT_EQUALS(ws1.cell("C1").formula(), "CONCATENATE(C2,C3)");
|
|
|
|
ws1.cell("C1").clear_formula();
|
|
|
|
|
|
|
|
auto ws2 = wb.sheet_by_index(1);
|
|
|
|
TS_ASSERT(ws2.cell("C1").has_formula());
|
|
|
|
TS_ASSERT_EQUALS(ws2.cell("C1").formula(), "C2*C3");
|
|
|
|
ws2.cell("C1").clear_formula();
|
|
|
|
|
2017-01-02 19:12:23 -05:00
|
|
|
wb.save("clear_formulae.xlsx");
|
|
|
|
}
|
2016-08-06 10:40:17 -04:00
|
|
|
};
|