2014-05-08 15:32:12 -04:00
# pragma once
# include <iostream>
# include <cxxtest/TestSuite.h>
2014-05-13 14:40:28 -04:00
# include "pugixml.hpp"
2014-06-05 16:19:31 -04:00
# include <xlnt/xlnt.hpp>
2014-05-08 15:32:12 -04:00
2014-06-05 16:19:31 -04:00
class test_worksheet : public CxxTest : : TestSuite
2014-05-08 15:32:12 -04:00
{
public :
void test_new_worksheet ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws = wb_ . create_sheet ( ) ;
2014-07-18 16:20:41 -04:00
TS_ASSERT ( wb_ = = ws . get_parent ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_new_sheet_name ( )
{
2014-07-18 16:20:41 -04:00
xlnt : : worksheet ws = wb_ . create_sheet ( " TestName " ) ;
2014-06-15 12:16:34 -04:00
TS_ASSERT_EQUALS ( ws . to_string ( ) , " <Worksheet \" TestName \" > " ) ;
2014-05-08 15:32:12 -04:00
}
void test_get_cell ( )
{
2014-07-18 16:20:41 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-21 10:20:30 -04:00
auto cell = ws . get_cell ( " A1 " ) ;
TS_ASSERT_EQUALS ( cell . get_reference ( ) . to_string ( ) , " A1 " ) ;
2014-05-08 15:32:12 -04:00
}
void test_set_bad_title ( )
{
2014-05-12 19:59:33 -04:00
std : : string title ( 50 , ' X ' ) ;
2014-07-18 16:20:41 -04:00
TS_ASSERT_THROWS ( wb_ . create_sheet ( title ) , xlnt : : sheet_title_exception ) ;
}
void test_increment_title ( )
{
auto ws1 = wb_ . create_sheet ( " Test " ) ;
TS_ASSERT_EQUALS ( ws1 . get_title ( ) , " Test " ) ;
auto ws2 = wb_ . create_sheet ( " Test " ) ;
2014-07-19 16:59:05 -04:00
TS_ASSERT_EQUALS ( ws2 . get_title ( ) , " Test1 " ) ;
2014-05-08 15:32:12 -04:00
}
void test_set_bad_title_character ( )
{
2014-06-15 12:16:34 -04:00
TS_ASSERT_THROWS ( wb_ . create_sheet ( " [ " ) , xlnt : : sheet_title_exception ) ;
TS_ASSERT_THROWS ( wb_ . create_sheet ( " ] " ) , xlnt : : sheet_title_exception ) ;
TS_ASSERT_THROWS ( wb_ . create_sheet ( " * " ) , xlnt : : sheet_title_exception ) ;
TS_ASSERT_THROWS ( wb_ . create_sheet ( " : " ) , xlnt : : sheet_title_exception ) ;
TS_ASSERT_THROWS ( wb_ . create_sheet ( " ? " ) , xlnt : : sheet_title_exception ) ;
TS_ASSERT_THROWS ( wb_ . create_sheet ( " / " ) , xlnt : : sheet_title_exception ) ;
TS_ASSERT_THROWS ( wb_ . create_sheet ( " \\ " ) , xlnt : : sheet_title_exception ) ;
2014-05-08 15:32:12 -04:00
}
void test_worksheet_dimension ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-21 10:20:30 -04:00
ws . get_cell ( " A1 " ) = " AAA " ;
2014-06-10 17:12:15 -04:00
TS_ASSERT_EQUALS ( " A1:A1 " , ws . calculate_dimension ( ) . to_string ( ) ) ;
2014-05-21 10:20:30 -04:00
ws . get_cell ( " B12 " ) = " AAA " ;
TS_ASSERT_EQUALS ( " A1:B12 " , ws . calculate_dimension ( ) . to_string ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_worksheet_range ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-21 10:20:30 -04:00
auto xlrange = ws . get_range ( " A1:C4 " ) ;
2014-07-19 16:59:05 -04:00
TS_ASSERT_EQUALS ( 4 , xlrange . length ( ) ) ;
2014-05-21 17:48:51 -04:00
TS_ASSERT_EQUALS ( 3 , xlrange [ 0 ] . num_cells ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_worksheet_named_range ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
wb_ . create_named_range ( " test_range " , ws , " C5 " ) ;
2014-05-21 10:20:30 -04:00
auto xlrange = ws . get_named_range ( " test_range " ) ;
2014-07-19 16:59:05 -04:00
TS_ASSERT_EQUALS ( 1 , xlrange . length ( ) ) ;
2014-05-21 17:48:51 -04:00
TS_ASSERT_EQUALS ( 1 , xlrange [ 0 ] . num_cells ( ) ) ;
2014-05-13 14:40:28 -04:00
TS_ASSERT_EQUALS ( 5 , xlrange [ 0 ] [ 0 ] . get_row ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_bad_named_range ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-21 10:20:30 -04:00
TS_ASSERT_THROWS_ANYTHING ( ws . get_range ( " bad_range " ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_named_range_wrong_sheet ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws1 ( wb_ ) ;
xlnt : : worksheet ws2 ( wb_ ) ;
wb_ . create_named_range ( " wrong_sheet_range " , ws1 , " C5 " ) ;
2014-07-18 16:20:41 -04:00
TS_ASSERT_THROWS ( ws2 . get_named_range ( " wrong_sheet_range " ) , xlnt : : named_range_exception ) ;
2014-05-08 15:32:12 -04:00
}
void test_cell_offset ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-29 20:52:14 -04:00
TS_ASSERT_EQUALS ( " C17 " , ws . get_cell ( xlnt : : cell_reference ( " B15 " ) . make_offset ( 1 , 2 ) ) . get_reference ( ) . to_string ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_range_offset ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-21 10:20:30 -04:00
auto xlrange = ws . get_range ( xlnt : : range_reference ( " A1:C4 " ) . make_offset ( 3 , 1 ) ) ;
2014-07-19 16:59:05 -04:00
TS_ASSERT_EQUALS ( 4 , xlrange . length ( ) ) ;
2014-05-21 17:48:51 -04:00
TS_ASSERT_EQUALS ( 3 , xlrange [ 0 ] . num_cells ( ) ) ;
2014-05-21 10:20:30 -04:00
TS_ASSERT_EQUALS ( " D2 " , xlrange [ 0 ] [ 0 ] . get_reference ( ) . to_string ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_cell_alternate_coordinates ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-21 10:20:30 -04:00
auto cell = ws . get_cell ( xlnt : : cell_reference ( 4 , 8 ) ) ;
TS_ASSERT_EQUALS ( " E9 " , cell . get_reference ( ) . to_string ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_cell_range_name ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
wb_ . create_named_range ( " test_range_single " , ws , " B12 " ) ;
2014-05-30 18:42:25 -04:00
TS_ASSERT_THROWS ( ws . get_cell ( " test_range_single " ) , xlnt : : cell_coordinates_exception ) ;
2014-05-21 10:20:30 -04:00
auto c_range_name = ws . get_named_range ( " test_range_single " ) ;
auto c_range_coord = ws . get_range ( " B12 " ) ;
auto c_cell = ws . get_cell ( " B12 " ) ;
2014-05-12 13:42:28 -04:00
TS_ASSERT_EQUALS ( c_range_coord , c_range_name ) ;
2014-05-13 16:32:33 -04:00
TS_ASSERT ( c_range_coord [ 0 ] [ 0 ] = = c_cell ) ;
2014-05-08 15:32:12 -04:00
}
void test_garbage_collect ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-13 14:40:28 -04:00
2014-05-21 10:20:30 -04:00
ws . get_cell ( " A1 " ) = " " ;
ws . get_cell ( " B2 " ) = " 0 " ;
ws . get_cell ( " C4 " ) = 0 ;
2014-05-13 14:40:28 -04:00
2014-05-12 13:42:28 -04:00
ws . garbage_collect ( ) ;
2014-05-13 14:40:28 -04:00
2014-05-21 10:20:30 -04:00
std : : list < xlnt : : cell > comparison_cells = { ws . get_cell ( " B2 " ) , ws . get_cell ( " C4 " ) } ;
2014-05-13 14:40:28 -04:00
for ( auto cell : ws . get_cell_collection ( ) )
2014-05-12 13:42:28 -04:00
{
2014-05-13 14:40:28 -04:00
auto match = std : : find ( comparison_cells . begin ( ) , comparison_cells . end ( ) , cell ) ;
TS_ASSERT_DIFFERS ( match , comparison_cells . end ( ) ) ;
comparison_cells . erase ( match ) ;
2014-05-12 13:42:28 -04:00
}
2014-05-14 18:31:48 -04:00
TS_ASSERT ( comparison_cells . empty ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_hyperlink_relationships ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-13 14:40:28 -04:00
TS_ASSERT_EQUALS ( ws . get_relationships ( ) . size ( ) , 0 ) ;
2014-06-10 17:12:15 -04:00
ws . get_cell ( " A1 " ) . set_hyperlink ( " http://test.com " ) ;
2014-05-13 14:40:28 -04:00
TS_ASSERT_EQUALS ( ws . get_relationships ( ) . size ( ) , 1 ) ;
2014-06-10 17:12:15 -04:00
TS_ASSERT_EQUALS ( " rId1 " , ws . get_cell ( " A1 " ) . get_hyperlink ( ) . get_id ( ) ) ;
2014-05-13 14:40:28 -04:00
TS_ASSERT_EQUALS ( " rId1 " , ws . get_relationships ( ) [ 0 ] . get_id ( ) ) ;
2014-06-10 17:12:15 -04:00
TS_ASSERT_EQUALS ( " http://test.com " , ws . get_relationships ( ) [ 0 ] . get_target_uri ( ) ) ;
2014-05-14 18:31:48 -04:00
TS_ASSERT_EQUALS ( xlnt : : target_mode : : external , ws . get_relationships ( ) [ 0 ] . get_target_mode ( ) ) ;
2014-05-13 14:40:28 -04:00
2014-06-10 17:12:15 -04:00
ws . get_cell ( " A2 " ) . set_hyperlink ( " http://test2.com " ) ;
2014-05-13 14:40:28 -04:00
TS_ASSERT_EQUALS ( ws . get_relationships ( ) . size ( ) , 2 ) ;
2014-06-10 17:12:15 -04:00
TS_ASSERT_EQUALS ( " rId2 " , ws . get_cell ( " A2 " ) . get_hyperlink ( ) . get_id ( ) ) ;
2014-05-13 14:40:28 -04:00
TS_ASSERT_EQUALS ( " rId2 " , ws . get_relationships ( ) [ 1 ] . get_id ( ) ) ;
2014-06-10 17:12:15 -04:00
TS_ASSERT_EQUALS ( " http://test2.com " , ws . get_relationships ( ) [ 1 ] . get_target_uri ( ) ) ;
2014-05-14 18:31:48 -04:00
TS_ASSERT_EQUALS ( xlnt : : target_mode : : external , ws . get_relationships ( ) [ 1 ] . get_target_mode ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_bad_relationship_type ( )
{
2014-07-19 14:43:48 -04:00
xlnt : : relationship rel ( " bad " ) ;
2014-05-08 15:32:12 -04:00
}
void test_append_list ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-08 15:32:12 -04:00
2014-05-13 14:40:28 -04:00
ws . append ( std : : vector < std : : string > { " This is A1 " , " This is B1 " } ) ;
2014-05-08 15:32:12 -04:00
2014-05-21 10:20:30 -04:00
TS_ASSERT_EQUALS ( " This is A1 " , ws . get_cell ( " A1 " ) ) ;
TS_ASSERT_EQUALS ( " This is B1 " , ws . get_cell ( " B1 " ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_append_dict_letter ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-08 15:32:12 -04:00
2014-05-13 14:40:28 -04:00
ws . append ( std : : unordered_map < std : : string , std : : string > { { " A " , " This is A1 " } , { " C " , " This is C1 " } } ) ;
2014-05-08 15:32:12 -04:00
2014-05-21 10:20:30 -04:00
TS_ASSERT_EQUALS ( " This is A1 " , ws . get_cell ( " A1 " ) ) ;
TS_ASSERT_EQUALS ( " This is C1 " , ws . get_cell ( " C1 " ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_append_dict_index ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-08 15:32:12 -04:00
2014-05-13 14:40:28 -04:00
ws . append ( std : : unordered_map < int , std : : string > { { 0 , " This is A1 " } , { 2 , " This is C1 " } } ) ;
2014-05-08 15:32:12 -04:00
2014-05-21 10:20:30 -04:00
TS_ASSERT_EQUALS ( " This is A1 " , ws . get_cell ( " A1 " ) ) ;
TS_ASSERT_EQUALS ( " This is C1 " , ws . get_cell ( " C1 " ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_append_2d_list ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-08 15:32:12 -04:00
2014-05-13 14:40:28 -04:00
ws . append ( std : : vector < std : : string > { " This is A1 " , " This is B1 " } ) ;
ws . append ( std : : vector < std : : string > { " This is A2 " , " This is B2 " } ) ;
2014-05-08 15:32:12 -04:00
2014-05-21 10:20:30 -04:00
auto vals = ws . get_range ( " A1:B2 " ) ;
2014-05-08 15:32:12 -04:00
2014-05-13 14:40:28 -04:00
TS_ASSERT_EQUALS ( vals [ 0 ] [ 0 ] , " This is A1 " ) ;
TS_ASSERT_EQUALS ( vals [ 0 ] [ 1 ] , " This is B1 " ) ;
TS_ASSERT_EQUALS ( vals [ 1 ] [ 0 ] , " This is A2 " ) ;
2014-05-16 02:03:05 -04:00
TS_ASSERT_EQUALS ( vals [ 1 ] [ 1 ] , " This is B2 " ) ;
2014-05-08 15:32:12 -04:00
}
void test_rows ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-08 15:32:12 -04:00
2014-05-21 10:20:30 -04:00
ws . get_cell ( " A1 " ) = " first " ;
ws . get_cell ( " C9 " ) = " last " ;
2014-05-08 15:32:12 -04:00
2014-05-13 14:40:28 -04:00
auto rows = ws . rows ( ) ;
2014-05-08 15:32:12 -04:00
2014-07-18 16:20:41 -04:00
TS_ASSERT_EQUALS ( rows . length ( ) , 9 ) ;
2014-05-08 15:32:12 -04:00
2014-05-13 14:40:28 -04:00
TS_ASSERT_EQUALS ( rows [ 0 ] [ 0 ] , " first " ) ;
TS_ASSERT_EQUALS ( rows [ 8 ] [ 2 ] , " last " ) ;
2014-05-08 15:32:12 -04:00
}
2014-07-18 16:20:41 -04:00
void test_cols ( )
{
xlnt : : worksheet ws ( wb_ ) ;
ws . get_cell ( " A1 " ) = " first " ;
ws . get_cell ( " C9 " ) = " last " ;
auto cols = ws . columns ( ) ;
TS_ASSERT_EQUALS ( cols . length ( ) , 3 ) ;
2014-07-19 16:59:05 -04:00
TS_ASSERT_EQUALS ( cols [ 0 ] [ 0 ] , " first " ) ;
TS_ASSERT_EQUALS ( cols [ 2 ] [ 8 ] , " last " ) ;
2014-07-18 16:20:41 -04:00
}
2014-05-08 15:32:12 -04:00
void test_auto_filter ( )
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-13 14:40:28 -04:00
2014-06-04 18:42:17 -04:00
ws . auto_filter ( ws . get_range ( " a1:f1 " ) ) ;
2014-05-19 20:47:15 -04:00
TS_ASSERT_EQUALS ( ws . get_auto_filter ( ) , " A1:F1 " ) ;
2014-05-08 15:32:12 -04:00
2014-05-18 21:29:19 -04:00
ws . unset_auto_filter ( ) ;
TS_ASSERT_EQUALS ( ws . has_auto_filter ( ) , false ) ;
2014-05-08 15:32:12 -04:00
2014-06-04 18:42:17 -04:00
ws . auto_filter ( " c1:g9 " ) ;
2014-05-18 21:29:19 -04:00
TS_ASSERT_EQUALS ( ws . get_auto_filter ( ) , " C1:G9 " ) ;
2014-05-08 15:32:12 -04:00
}
2014-07-18 16:20:41 -04:00
void test_freeze ( )
2014-05-08 15:32:12 -04:00
{
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-13 14:40:28 -04:00
2014-07-18 16:20:41 -04:00
ws . freeze_panes ( ws . get_cell ( " b2 " ) ) ;
TS_ASSERT_EQUALS ( ws . get_frozen_panes ( ) . to_string ( ) , " B2 " ) ;
2014-05-18 21:29:19 -04:00
2014-07-18 16:20:41 -04:00
ws . unfreeze_panes ( ) ;
TS_ASSERT ( ! ws . has_frozen_panes ( ) ) ;
2014-05-13 14:40:28 -04:00
2014-07-18 16:20:41 -04:00
ws . freeze_panes ( " c5 " ) ;
TS_ASSERT_EQUALS ( ws . get_frozen_panes ( ) . to_string ( ) , " C5 " ) ;
ws . freeze_panes ( ws . get_cell ( " A1 " ) ) ;
TS_ASSERT ( ! ws . has_frozen_panes ( ) ) ;
2014-05-08 15:32:12 -04:00
}
2014-07-18 16:20:41 -04:00
void test_write_empty ( )
2014-05-08 15:32:12 -04:00
{
2014-07-19 17:42:04 -04:00
TS_SKIP ( " not implemented " ) ;
2014-07-18 16:20:41 -04:00
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-07-18 16:20:41 -04:00
auto xml_string = xlnt : : writer : : write_worksheet ( ws ) ;
2014-05-13 14:40:28 -04:00
2014-05-18 21:29:19 -04:00
pugi : : xml_document doc ;
doc . load ( xml_string . c_str ( ) ) ;
2014-05-08 15:32:12 -04:00
}
2014-07-18 16:20:41 -04:00
void test_page_margins ( )
2014-05-08 15:32:12 -04:00
{
2014-07-19 17:42:04 -04:00
TS_SKIP ( " not implemented " ) ;
2014-07-18 16:20:41 -04:00
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-07-18 16:20:41 -04:00
auto xml_string = xlnt : : writer : : write_worksheet ( ws ) ;
2014-05-08 15:32:12 -04:00
2014-07-18 16:20:41 -04:00
pugi : : xml_document doc ;
doc . load ( xml_string . c_str ( ) ) ;
}
void test_merge ( )
{
2014-07-19 17:42:04 -04:00
TS_SKIP ( " not implemented " ) ;
2014-07-18 16:20:41 -04:00
xlnt : : worksheet ws ( wb_ ) ;
auto xml_string = xlnt : : writer : : write_worksheet ( ws ) ;
2014-05-13 14:40:28 -04:00
2014-07-18 16:20:41 -04:00
pugi : : xml_document doc ;
doc . load ( xml_string . c_str ( ) ) ;
2014-05-08 15:32:12 -04:00
}
void test_printer_settings ( )
{
2014-07-19 17:42:04 -04:00
TS_SKIP ( " not implemented " ) ;
2014-07-18 16:20:41 -04:00
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws ( wb_ ) ;
2014-05-13 14:40:28 -04:00
2014-05-19 20:47:15 -04:00
ws . get_page_setup ( ) . set_orientation ( xlnt : : page_setup : : orientation : : landscape ) ;
2014-05-21 10:20:30 -04:00
ws . get_page_setup ( ) . set_paper_size ( xlnt : : page_setup : : paper_size : : tabloid ) ;
2014-05-19 20:47:15 -04:00
ws . get_page_setup ( ) . set_fit_to_page ( true ) ;
ws . get_page_setup ( ) . set_fit_to_height ( false ) ;
ws . get_page_setup ( ) . set_fit_to_width ( true ) ;
2014-05-18 21:29:19 -04:00
auto xml_string = xlnt : : writer : : write_worksheet ( ws ) ;
2014-05-19 20:47:15 -04:00
2014-05-18 21:29:19 -04:00
pugi : : xml_document doc ;
doc . load ( xml_string . c_str ( ) ) ;
2014-05-19 20:47:15 -04:00
2014-06-15 12:16:34 -04:00
xlnt : : worksheet ws2 ( wb_ ) ;
2014-05-18 21:29:19 -04:00
xml_string = xlnt : : writer : : write_worksheet ( ws2 ) ;
doc . load ( xml_string . c_str ( ) ) ;
2014-07-18 16:20:41 -04:00
}
void test_header_footer ( )
{
auto ws = wb_ . create_sheet ( ) ;
ws . get_header_footer ( ) . get_left_header ( ) . set_text ( " Left Header Text " ) ;
ws . get_header_footer ( ) . get_center_header ( ) . set_text ( " Center Header Text " ) ;
ws . get_header_footer ( ) . get_center_header ( ) . set_font_name ( " Arial,Regular " ) ;
ws . get_header_footer ( ) . get_center_header ( ) . set_font_size ( 6 ) ;
ws . get_header_footer ( ) . get_center_header ( ) . set_font_color ( " 445566 " ) ;
ws . get_header_footer ( ) . get_right_header ( ) . set_text ( " Right Header Text " ) ;
ws . get_header_footer ( ) . get_right_header ( ) . set_font_name ( " Arial,Bold " ) ;
ws . get_header_footer ( ) . get_right_header ( ) . set_font_size ( 8 ) ;
ws . get_header_footer ( ) . get_right_header ( ) . set_font_color ( " 112233 " ) ;
ws . get_header_footer ( ) . get_left_footer ( ) . set_text ( " Left Footer Text \n And &[Date] and &[Time] " ) ;
ws . get_header_footer ( ) . get_left_footer ( ) . set_font_name ( " Times New Roman,Regular " ) ;
ws . get_header_footer ( ) . get_left_footer ( ) . set_font_size ( 10 ) ;
ws . get_header_footer ( ) . get_left_footer ( ) . set_font_color ( " 445566 " ) ;
ws . get_header_footer ( ) . get_center_footer ( ) . set_text ( " Center Footer Text &[Path]&[File] on &[Tab] " ) ;
ws . get_header_footer ( ) . get_center_footer ( ) . set_font_name ( " Times New Roman,Bold " ) ;
ws . get_header_footer ( ) . get_center_footer ( ) . set_font_size ( 12 ) ;
ws . get_header_footer ( ) . get_center_footer ( ) . set_font_color ( " 778899 " ) ;
ws . get_header_footer ( ) . get_right_footer ( ) . set_text ( " Right Footer Text &[Page] of &[Pages] " ) ;
ws . get_header_footer ( ) . get_right_footer ( ) . set_font_name ( " Times New Roman,Italic " ) ;
ws . get_header_footer ( ) . get_right_footer ( ) . set_font_size ( 14 ) ;
ws . get_header_footer ( ) . get_right_footer ( ) . set_font_color ( " AABBCC " ) ;
2014-07-19 16:59:05 -04:00
std : : string expected_xml_string =
2014-07-18 16:20:41 -04:00
" <worksheet xmlns= \" http://schemas.openxmlformats.org/spreadsheetml/2006/main \" xmlns:r= \" http://schemas.openxmlformats.org/officeDocument/2006/relationships \" > "
" <sheetPr> "
" <outlinePr summaryRight= \" 1 \" summaryBelow= \" 1 \" /> "
" </sheetPr> "
" <dimension ref= \" A1:A1 \" /> "
" <sheetViews> "
" <sheetView workbookViewId= \" 0 \" > "
" <selection sqref= \" A1 \" activeCell= \" A1 \" /> "
" </sheetView> "
" </sheetViews> "
" <sheetFormatPr baseColWidth= \" 10 \" defaultRowHeight= \" 15 \" /> "
" <sheetData/> "
" <pageMargins left= \" 0.75 \" right= \" 0.75 \" top= \" 1 \" bottom= \" 1 \" header= \" 0.5 \" footer= \" 0.5 \" /> "
" <headerFooter> "
" <oddHeader>&L& \" Calibri,Regular \" &K000000Left Header Text&C& \" Arial,Regular \" &6&K445566Center Header Text&R& \" Arial,Bold \" &8&K112233Right Header Text</oddHeader> "
" <oddFooter>&L& \" Times New Roman,Regular \" &10&K445566Left Footer Text_x000D_And &D and &T&C& \" Times New Roman,Bold \" &12&K778899Center Footer Text &Z&F on &A&R& \" Times New Roman,Italic \" &14&KAABBCCRight Footer Text &P of &N</oddFooter> "
" </headerFooter> "
" </worksheet> " ;
2014-07-19 16:59:05 -04:00
pugi : : xml_document expected_doc ;
pugi : : xml_document observed_doc ;
2014-07-18 16:20:41 -04:00
2014-07-19 16:59:05 -04:00
expected_doc . load ( expected_xml_string . c_str ( ) ) ;
observed_doc . load ( xlnt : : writer : : write_worksheet ( ws , { } , { } ) . c_str ( ) ) ;
2014-07-18 16:20:41 -04:00
2014-07-19 16:59:05 -04:00
TS_ASSERT ( Helper : : compare_xml ( expected_doc , observed_doc ) ) ;
2014-07-18 16:20:41 -04:00
2014-07-19 16:59:05 -04:00
ws = wb_ . create_sheet ( ) ;
2014-07-18 16:20:41 -04:00
expected_xml_string =
" <worksheet xmlns= \" http://schemas.openxmlformats.org/spreadsheetml/2006/main \" xmlns:r= \" http://schemas.openxmlformats.org/officeDocument/2006/relationships \" > "
" <sheetPr> "
2014-07-19 16:59:05 -04:00
" <outlinePr summaryRight= \" 1 \" summaryBelow= \" 1 \" /> "
2014-07-18 16:20:41 -04:00
" </sheetPr> "
2014-07-19 16:59:05 -04:00
" <dimension ref= \" A1:A1 \" /> "
2014-07-18 16:20:41 -04:00
" <sheetViews> "
2014-07-19 16:59:05 -04:00
" <sheetView workbookViewId= \" 0 \" > "
" <selection sqref= \" A1 \" activeCell= \" A1 \" /> "
2014-07-18 16:20:41 -04:00
" </sheetView> "
" </sheetViews> "
2014-07-19 16:59:05 -04:00
" <sheetFormatPr baseColWidth= \" 10 \" defaultRowHeight= \" 15 \" /> "
2014-07-18 16:20:41 -04:00
" <sheetData/> "
2014-07-19 16:59:05 -04:00
" <pageMargins left= \" 0.75 \" right= \" 0.75 \" top= \" 1 \" bottom= \" 1 \" header= \" 0.5 \" footer= \" 0.5 \" /> "
2014-07-18 16:20:41 -04:00
" </worksheet> " ;
2014-07-19 16:59:05 -04:00
expected_doc . load ( expected_xml_string . c_str ( ) ) ;
observed_doc . load ( xlnt : : writer : : write_worksheet ( ws , { } , { } ) . c_str ( ) ) ;
2014-07-18 16:20:41 -04:00
2014-07-19 16:59:05 -04:00
TS_ASSERT ( Helper : : compare_xml ( expected_doc , observed_doc ) ) ;
2014-07-18 16:20:41 -04:00
}
void test_positioning_point ( )
{
2014-07-19 17:42:04 -04:00
TS_SKIP ( " not implemented " ) ;
2014-07-19 16:59:05 -04:00
/*
auto ws = wb_ . create_sheet ( ) ;
*/
2014-07-18 16:20:41 -04:00
}
void test_positioning_roundtrip ( )
{
2014-07-19 17:42:04 -04:00
TS_SKIP ( " not implemented " ) ;
2014-07-19 16:59:05 -04:00
/*
2014-07-18 16:20:41 -04:00
auto ws = wb_ . create_sheet ( ) ;
TS_ASSERT_EQUALS ( ws . get_point_pos ( ws . get_cell ( " A1 " ) . get_anchor ( ) ) , xlnt : : cell_reference ( " A1 " ) ) ;
TS_ASSERT_EQUALS ( ws . get_point_pos ( ws . get_cell ( " D52 " ) . get_anchor ( ) ) , xlnt : : cell_reference ( " D52 " ) ) ;
TS_ASSERT_EQUALS ( ws . get_point_pos ( ws . get_cell ( " X11 " ) . get_anchor ( ) ) , xlnt : : cell_reference ( " X11 " ) ) ;
2014-07-19 16:59:05 -04:00
*/
2014-07-18 16:20:41 -04:00
}
void test_page_setup ( )
{
2014-07-19 17:42:04 -04:00
TS_SKIP ( " not implemented " ) ;
2014-07-19 16:59:05 -04:00
/*
2014-07-18 16:20:41 -04:00
xlnt : : page_setup p ;
2014-07-19 16:59:05 -04:00
TS_ASSERT ( p . get_page_setup ( ) . empty ( ) ) ;
2014-07-18 16:20:41 -04:00
p . set_scale ( 1 ) ;
2014-07-19 16:59:05 -04:00
TS_ASSERT_EQUALS ( p . get_page_setup ( ) . at ( " scale " ) , 1 ) ;
*/
2014-07-18 16:20:41 -04:00
}
void test_page_options ( )
{
2014-07-19 17:42:04 -04:00
TS_SKIP ( " not implemented " ) ;
2014-07-19 16:59:05 -04:00
/*
2014-07-18 16:20:41 -04:00
xlnt : : page_setup p ;
TS_ASSERT ( p . get_options ( ) . empty ( ) ) ;
p . set_horizontal_centered ( true ) ;
p . set_vertical_centered ( true ) ;
TS_ASSERT_EQUALS ( p . get_options ( ) . at ( " verticalCentered " ) , " 1 " ) ;
TS_ASSERT_EQUALS ( p . get_options ( ) . at ( " horizontalCentered " ) , " 1 " ) ;
2014-07-19 16:59:05 -04:00
*/
2014-05-08 15:32:12 -04:00
}
2014-05-13 14:40:28 -04:00
private :
2014-06-15 12:16:34 -04:00
xlnt : : workbook wb_ ;
2014-05-08 15:32:12 -04:00
} ;