write_xlsx 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (261) hide show
  1. data/.document +5 -0
  2. data/.gitattributes +1 -0
  3. data/Gemfile +12 -0
  4. data/LICENSE.txt +20 -0
  5. data/README.rdoc +82 -0
  6. data/Rakefile +78 -0
  7. data/VERSION +1 -0
  8. data/examples/a_simple.rb +45 -0
  9. data/examples/array_formula.rb +33 -0
  10. data/examples/autofilter.rb +235 -0
  11. data/examples/chart_area.rb +59 -0
  12. data/examples/chart_bar.rb +59 -0
  13. data/examples/chart_column.rb +58 -0
  14. data/examples/chart_line.rb +59 -0
  15. data/examples/chart_pie.rb +49 -0
  16. data/examples/chart_scatter.rb +59 -0
  17. data/examples/chart_stock.rb +65 -0
  18. data/examples/colors.rb +130 -0
  19. data/examples/comments1.rb +12 -0
  20. data/examples/comments2.rb +335 -0
  21. data/examples/conditional_format.rb +67 -0
  22. data/examples/data_validate.rb +279 -0
  23. data/examples/defined_name.rb +28 -0
  24. data/examples/demo.rb +104 -0
  25. data/examples/diag_border.rb +26 -0
  26. data/examples/headers.rb +119 -0
  27. data/examples/hide_sheet.rb +30 -0
  28. data/examples/hyperlink1.rb +58 -0
  29. data/examples/indent.rb +28 -0
  30. data/examples/merge1.rb +38 -0
  31. data/examples/merge2.rb +48 -0
  32. data/examples/merge3.rb +43 -0
  33. data/examples/merge4.rb +82 -0
  34. data/examples/merge5.rb +70 -0
  35. data/examples/merge6.rb +48 -0
  36. data/examples/outline.rb +252 -0
  37. data/examples/properties.rb +33 -0
  38. data/examples/protection.rb +34 -0
  39. data/examples/rich_strings.rb +42 -0
  40. data/examples/right_to_left.rb +24 -0
  41. data/examples/tab_colors.rb +26 -0
  42. data/lib/write_xlsx.rb +77 -0
  43. data/lib/write_xlsx/chart.rb +3027 -0
  44. data/lib/write_xlsx/chart/area.rb +52 -0
  45. data/lib/write_xlsx/chart/bar.rb +126 -0
  46. data/lib/write_xlsx/chart/column.rb +132 -0
  47. data/lib/write_xlsx/chart/line.rb +51 -0
  48. data/lib/write_xlsx/chart/pie.rb +210 -0
  49. data/lib/write_xlsx/chart/scatter.rb +252 -0
  50. data/lib/write_xlsx/chart/stock.rb +134 -0
  51. data/lib/write_xlsx/chartsheet.rb +173 -0
  52. data/lib/write_xlsx/colors.rb +65 -0
  53. data/lib/write_xlsx/compatibility.rb +71 -0
  54. data/lib/write_xlsx/drawing.rb +547 -0
  55. data/lib/write_xlsx/format.rb +683 -0
  56. data/lib/write_xlsx/package/app.rb +218 -0
  57. data/lib/write_xlsx/package/comments.rb +221 -0
  58. data/lib/write_xlsx/package/content_types.rb +189 -0
  59. data/lib/write_xlsx/package/core.rb +196 -0
  60. data/lib/write_xlsx/package/packager.rb +510 -0
  61. data/lib/write_xlsx/package/relationships.rb +98 -0
  62. data/lib/write_xlsx/package/shared_strings.rb +96 -0
  63. data/lib/write_xlsx/package/styles.rb +705 -0
  64. data/lib/write_xlsx/package/theme.rb +45 -0
  65. data/lib/write_xlsx/package/vml.rb +386 -0
  66. data/lib/write_xlsx/package/xml_writer_simple.rb +90 -0
  67. data/lib/write_xlsx/utility.rb +113 -0
  68. data/lib/write_xlsx/workbook.rb +1488 -0
  69. data/lib/write_xlsx/worksheet.rb +6578 -0
  70. data/lib/write_xlsx/zip_file_utils.rb +98 -0
  71. data/test/chart/test_add_series.rb +113 -0
  72. data/test/chart/test_process_names.rb +27 -0
  73. data/test/chart/test_write_auto.rb +15 -0
  74. data/test/chart/test_write_ax_id.rb +15 -0
  75. data/test/chart/test_write_ax_pos.rb +15 -0
  76. data/test/chart/test_write_chart_space.rb +15 -0
  77. data/test/chart/test_write_cross_ax.rb +15 -0
  78. data/test/chart/test_write_crosses.rb +15 -0
  79. data/test/chart/test_write_format_code.rb +15 -0
  80. data/test/chart/test_write_idx.rb +15 -0
  81. data/test/chart/test_write_label_align.rb +15 -0
  82. data/test/chart/test_write_label_offset.rb +15 -0
  83. data/test/chart/test_write_lang.rb +15 -0
  84. data/test/chart/test_write_layout.rb +15 -0
  85. data/test/chart/test_write_legend.rb +16 -0
  86. data/test/chart/test_write_legend_pos.rb +15 -0
  87. data/test/chart/test_write_major_gridlines.rb +15 -0
  88. data/test/chart/test_write_marker.rb +17 -0
  89. data/test/chart/test_write_marker_size.rb +15 -0
  90. data/test/chart/test_write_marker_value.rb +16 -0
  91. data/test/chart/test_write_num_cache.rb +16 -0
  92. data/test/chart/test_write_num_fmt.rb +16 -0
  93. data/test/chart/test_write_number_format.rb +15 -0
  94. data/test/chart/test_write_order.rb +15 -0
  95. data/test/chart/test_write_orientation.rb +15 -0
  96. data/test/chart/test_write_page_margins.rb +15 -0
  97. data/test/chart/test_write_page_setup.rb +15 -0
  98. data/test/chart/test_write_plot_vis_only.rb +15 -0
  99. data/test/chart/test_write_pt.rb +16 -0
  100. data/test/chart/test_write_pt_count.rb +16 -0
  101. data/test/chart/test_write_series_formula.rb +16 -0
  102. data/test/chart/test_write_style.rb +41 -0
  103. data/test/chart/test_write_symbol.rb +16 -0
  104. data/test/chart/test_write_tick_lbl_pos.rb +16 -0
  105. data/test/chart/test_write_v.rb +16 -0
  106. data/test/drawing/test_drawing_chart_01.rb +50 -0
  107. data/test/drawing/test_drawing_image_01.rb +59 -0
  108. data/test/helper.rb +90 -0
  109. data/test/package/app/test_app01.rb +44 -0
  110. data/test/package/app/test_app02.rb +46 -0
  111. data/test/package/app/test_app03.rb +53 -0
  112. data/test/package/comments/test_comments01.rb +36 -0
  113. data/test/package/comments/test_write_text_t.rb +44 -0
  114. data/test/package/content_types/test_content_types.rb +35 -0
  115. data/test/package/content_types/test_write_default.rb +13 -0
  116. data/test/package/content_types/test_write_override.rb +13 -0
  117. data/test/package/core/test_core01.rb +28 -0
  118. data/test/package/core/test_core02.rb +42 -0
  119. data/test/package/relationships/test_relationships.rb +28 -0
  120. data/test/package/relationships/test_sheet_rels.rb +22 -0
  121. data/test/package/shared_strings/test_shared_strings01.rb +30 -0
  122. data/test/package/shared_strings/test_shared_strings02.rb +30 -0
  123. data/test/package/shared_strings/test_write_si.rb +13 -0
  124. data/test/package/shared_strings/test_write_sst.rb +15 -0
  125. data/test/package/styles/test_styles_01.rb +69 -0
  126. data/test/package/styles/test_styles_02.rb +104 -0
  127. data/test/package/styles/test_styles_03.rb +90 -0
  128. data/test/package/styles/test_styles_04.rb +216 -0
  129. data/test/package/styles/test_styles_05.rb +150 -0
  130. data/test/package/styles/test_styles_06.rb +104 -0
  131. data/test/package/styles/test_styles_07.rb +104 -0
  132. data/test/package/styles/test_styles_08.rb +109 -0
  133. data/test/package/styles/test_styles_09.rb +95 -0
  134. data/test/package/vml/test_vml_01.rb +42 -0
  135. data/test/package/vml/test_write_anchor.rb +14 -0
  136. data/test/package/vml/test_write_auto_fill.rb +14 -0
  137. data/test/package/vml/test_write_column.rb +14 -0
  138. data/test/package/vml/test_write_div.rb +14 -0
  139. data/test/package/vml/test_write_fill.rb +14 -0
  140. data/test/package/vml/test_write_idmap.rb +14 -0
  141. data/test/package/vml/test_write_move_with_cells.rb +14 -0
  142. data/test/package/vml/test_write_path.rb +22 -0
  143. data/test/package/vml/test_write_row.rb +14 -0
  144. data/test/package/vml/test_write_shadow.rb +14 -0
  145. data/test/package/vml/test_write_shapelayout.rb +14 -0
  146. data/test/package/vml/test_write_shapetype.rb +14 -0
  147. data/test/package/vml/test_write_size_with_cells.rb +14 -0
  148. data/test/package/vml/test_write_stroke.rb +14 -0
  149. data/test/package/vml/test_write_textbox.rb +14 -0
  150. data/test/perl_output/a_simple.xlsx +0 -0
  151. data/test/perl_output/array_formula.xlsx +0 -0
  152. data/test/perl_output/autofilter.xlsx +0 -0
  153. data/test/perl_output/chart_area.xlsx +0 -0
  154. data/test/perl_output/chart_bar.xlsx +0 -0
  155. data/test/perl_output/chart_column.xlsx +0 -0
  156. data/test/perl_output/chart_line.xlsx +0 -0
  157. data/test/perl_output/chart_pie.xlsx +0 -0
  158. data/test/perl_output/chart_scatter.xlsx +0 -0
  159. data/test/perl_output/chart_stock.xlsx +0 -0
  160. data/test/perl_output/comments1.xlsx +0 -0
  161. data/test/perl_output/comments2.xlsx +0 -0
  162. data/test/perl_output/conditional_format.xlsx +0 -0
  163. data/test/perl_output/data_validate.xlsx +0 -0
  164. data/test/perl_output/defined_name.xlsx +0 -0
  165. data/test/perl_output/demo.xlsx +0 -0
  166. data/test/perl_output/diag_border.xlsx +0 -0
  167. data/test/perl_output/fit_to_pages.xlsx +0 -0
  168. data/test/perl_output/headers.xlsx +0 -0
  169. data/test/perl_output/hide_sheet.xlsx +0 -0
  170. data/test/perl_output/hyperlink.xlsx +0 -0
  171. data/test/perl_output/indent.xlsx +0 -0
  172. data/test/perl_output/merge1.xlsx +0 -0
  173. data/test/perl_output/merge2.xlsx +0 -0
  174. data/test/perl_output/merge3.xlsx +0 -0
  175. data/test/perl_output/merge4.xlsx +0 -0
  176. data/test/perl_output/merge5.xlsx +0 -0
  177. data/test/perl_output/merge6.xlsx +0 -0
  178. data/test/perl_output/outline.xlsx +0 -0
  179. data/test/perl_output/print_scale.xlsx +0 -0
  180. data/test/perl_output/properties.xlsx +0 -0
  181. data/test/perl_output/protection.xlsx +0 -0
  182. data/test/perl_output/rich_strings.xlsx +0 -0
  183. data/test/perl_output/right_to_left.xlsx +0 -0
  184. data/test/perl_output/tab_colors.xlsx +0 -0
  185. data/test/test_delete_files.rb +37 -0
  186. data/test/test_example_match.rb +2281 -0
  187. data/test/test_xml_writer_simple.rb +63 -0
  188. data/test/workbook/test_get_chart_range.rb +59 -0
  189. data/test/workbook/test_sort_defined_names.rb +77 -0
  190. data/test/workbook/test_workbook_01.rb +29 -0
  191. data/test/workbook/test_workbook_02.rb +31 -0
  192. data/test/workbook/test_workbook_03.rb +31 -0
  193. data/test/workbook/test_workbook_new.rb +18 -0
  194. data/test/workbook/test_write_defined_name.rb +17 -0
  195. data/test/workbook/test_write_defined_names.rb +41 -0
  196. data/test/worksheet/test_calculate_spans.rb +58 -0
  197. data/test/worksheet/test_convert_date_time_01.rb +439 -0
  198. data/test/worksheet/test_convert_date_time_02.rb +478 -0
  199. data/test/worksheet/test_convert_date_time_03.rb +435 -0
  200. data/test/worksheet/test_extract_filter_tokens.rb +109 -0
  201. data/test/worksheet/test_parse_filter_expression.rb +143 -0
  202. data/test/worksheet/test_position_object.rb +50 -0
  203. data/test/worksheet/test_repeat_formula.rb +55 -0
  204. data/test/worksheet/test_worksheet_01.rb +32 -0
  205. data/test/worksheet/test_worksheet_02.rb +38 -0
  206. data/test/worksheet/test_worksheet_03.rb +44 -0
  207. data/test/worksheet/test_worksheet_04.rb +45 -0
  208. data/test/worksheet/test_write_array_formula_01.rb +99 -0
  209. data/test/worksheet/test_write_autofilter.rb +260 -0
  210. data/test/worksheet/test_write_brk.rb +18 -0
  211. data/test/worksheet/test_write_cell.rb +49 -0
  212. data/test/worksheet/test_write_cell_value.rb +33 -0
  213. data/test/worksheet/test_write_col_breaks.rb +27 -0
  214. data/test/worksheet/test_write_col_info.rb +95 -0
  215. data/test/worksheet/test_write_conditional_formatting.rb +72 -0
  216. data/test/worksheet/test_write_custom_filter.rb +18 -0
  217. data/test/worksheet/test_write_custom_filters.rb +25 -0
  218. data/test/worksheet/test_write_data_validation_01.rb +113 -0
  219. data/test/worksheet/test_write_data_validation_02.rb +528 -0
  220. data/test/worksheet/test_write_dimension.rb +94 -0
  221. data/test/worksheet/test_write_ext.rb +18 -0
  222. data/test/worksheet/test_write_ext_lst.rb +18 -0
  223. data/test/worksheet/test_write_filter.rb +18 -0
  224. data/test/worksheet/test_write_filter_column.rb +18 -0
  225. data/test/worksheet/test_write_filters.rb +32 -0
  226. data/test/worksheet/test_write_header_footer.rb +53 -0
  227. data/test/worksheet/test_write_hyperlink.rb +39 -0
  228. data/test/worksheet/test_write_hyperlinks.rb +27 -0
  229. data/test/worksheet/test_write_legacy_drawing.rb +19 -0
  230. data/test/worksheet/test_write_merge_cell.rb +18 -0
  231. data/test/worksheet/test_write_merge_cells.rb +192 -0
  232. data/test/worksheet/test_write_methods.rb +353 -0
  233. data/test/worksheet/test_write_mx_plv.rb +19 -0
  234. data/test/worksheet/test_write_page_margins.rb +98 -0
  235. data/test/worksheet/test_write_page_set_up_pr.rb +19 -0
  236. data/test/worksheet/test_write_page_setup.rb +54 -0
  237. data/test/worksheet/test_write_pane.rb +123 -0
  238. data/test/worksheet/test_write_phonetic_pr.rb +19 -0
  239. data/test/worksheet/test_write_print_options.rb +77 -0
  240. data/test/worksheet/test_write_row_breaks.rb +27 -0
  241. data/test/worksheet/test_write_row_element.rb +69 -0
  242. data/test/worksheet/test_write_selection.rb +18 -0
  243. data/test/worksheet/test_write_sheet_calc_pr.rb +18 -0
  244. data/test/worksheet/test_write_sheet_data.rb +18 -0
  245. data/test/worksheet/test_write_sheet_format_pr.rb +18 -0
  246. data/test/worksheet/test_write_sheet_pr.rb +36 -0
  247. data/test/worksheet/test_write_sheet_protection.rb +174 -0
  248. data/test/worksheet/test_write_sheet_view.rb +62 -0
  249. data/test/worksheet/test_write_sheet_view1.rb +64 -0
  250. data/test/worksheet/test_write_sheet_view2.rb +56 -0
  251. data/test/worksheet/test_write_sheet_view3.rb +83 -0
  252. data/test/worksheet/test_write_sheet_view4.rb +83 -0
  253. data/test/worksheet/test_write_sheet_view5.rb +74 -0
  254. data/test/worksheet/test_write_sheet_view6.rb +51 -0
  255. data/test/worksheet/test_write_sheet_view7.rb +71 -0
  256. data/test/worksheet/test_write_sheet_view8.rb +51 -0
  257. data/test/worksheet/test_write_sheet_view9.rb +51 -0
  258. data/test/worksheet/test_write_tab_color.rb +23 -0
  259. data/test/worksheet/test_write_worksheet.rb +19 -0
  260. data/write_xlsx.gemspec +308 -0
  261. metadata +363 -0
@@ -0,0 +1,19 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx'
4
+ require 'stringio'
5
+
6
+ class TestWritePageSetUpPr < Test::Unit::TestCase
7
+ def setup
8
+ @workbook = WriteXLSX.new(StringIO.new)
9
+ @worksheet = @workbook.add_worksheet('')
10
+ end
11
+
12
+ def test_write_page_set_up_pr
13
+ @worksheet.instance_variable_get(:@print_style).fit_page = true
14
+ @worksheet.__send__('write_page_set_up_pr')
15
+ result = @worksheet.instance_variable_get(:@writer).string
16
+ expected = '<pageSetUpPr fitToPage="1" />'
17
+ assert_equal(expected, result)
18
+ end
19
+ end
@@ -0,0 +1,54 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx'
4
+ require 'stringio'
5
+
6
+ class TestWorksheetWritePageSetup < Test::Unit::TestCase
7
+ def setup
8
+ @workbook = WriteXLSX.new(StringIO.new)
9
+ @worksheet = @workbook.add_worksheet('')
10
+ end
11
+
12
+ def test_write_page_setup
13
+ assert @worksheet
14
+ end
15
+
16
+ def test_write_page_setup
17
+ @worksheet.__send__('write_page_setup')
18
+ result = @worksheet.instance_variable_get(:@writer).string
19
+ expected = ''
20
+ assert_equal(expected, result)
21
+ end
22
+
23
+ def test_write_page_setup_with_set_landscape
24
+ @worksheet.set_landscape
25
+ @worksheet.__send__('write_page_setup')
26
+ result = @worksheet.instance_variable_get(:@writer).string
27
+ expected = '<pageSetup orientation="landscape" />'
28
+ assert_equal(expected, result)
29
+ end
30
+
31
+ def test_write_page_setup_with_set_portrait
32
+ @worksheet.set_portrait
33
+ @worksheet.__send__('write_page_setup')
34
+ result = @worksheet.instance_variable_get(:@writer).string
35
+ expected = '<pageSetup orientation="portrait" />'
36
+ assert_equal(expected, result)
37
+ end
38
+
39
+ def test_write_page_setup_with_set_paper
40
+ @worksheet.set_paper(9)
41
+ @worksheet.__send__('write_page_setup')
42
+ result = @worksheet.instance_variable_get(:@writer).string
43
+ expected = '<pageSetup paperSize="9" orientation="portrait" />'
44
+ assert_equal(expected, result)
45
+ end
46
+
47
+ def test_write_page_setup_with_print_across
48
+ @worksheet.print_across
49
+ @worksheet.__send__('write_page_setup')
50
+ result = @worksheet.instance_variable_get(:@writer).string
51
+ expected = '<pageSetup pageOrder="overThenDown" orientation="portrait" />'
52
+ assert_equal(expected, result)
53
+ end
54
+ end
@@ -0,0 +1,123 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx'
4
+ require 'stringio'
5
+
6
+ class TestWritePane < Test::Unit::TestCase
7
+ def setup
8
+ @workbook = WriteXLSX.new(StringIO.new)
9
+ @worksheet = @workbook.add_worksheet('')
10
+ end
11
+
12
+ def test_write_panes_freeze_1
13
+ @worksheet.freeze_panes(1)
14
+ @worksheet.__send__('write_panes')
15
+ result = @worksheet.instance_variable_get(:@writer).string
16
+ expected = '<pane ySplit="1" topLeftCell="A2" activePane="bottomLeft" state="frozen" />'
17
+ assert_equal(expected, result)
18
+ end
19
+
20
+ def test_write_panes_freeze_0_1
21
+ @worksheet.freeze_panes(0, 1)
22
+ @worksheet.__send__('write_panes')
23
+ result = @worksheet.instance_variable_get(:@writer).string
24
+ expected = '<pane xSplit="1" topLeftCell="B1" activePane="topRight" state="frozen" />'
25
+ assert_equal(expected, result)
26
+ end
27
+
28
+ def test_write_panes_freeze_1_1
29
+ @worksheet.freeze_panes(1, 1)
30
+ @worksheet.__send__('write_panes')
31
+ result = @worksheet.instance_variable_get(:@writer).string
32
+ expected = '<pane xSplit="1" ySplit="1" topLeftCell="B2" activePane="bottomRight" state="frozen" />'
33
+ assert_equal(expected, result)
34
+ end
35
+
36
+ def test_write_panes_freeze_1_0_19
37
+ @worksheet.freeze_panes(1, 0, 19)
38
+ @worksheet.__send__('write_panes')
39
+ result = @worksheet.instance_variable_get(:@writer).string
40
+ expected = '<pane ySplit="1" topLeftCell="A20" activePane="bottomLeft" state="frozen" />'
41
+ assert_equal(expected, result)
42
+ end
43
+
44
+ def test_write_panes_freeze_G4
45
+ @worksheet.freeze_panes('G4')
46
+ @worksheet.__send__('write_panes')
47
+ result = @worksheet.instance_variable_get(:@writer).string
48
+ expected = '<pane xSplit="6" ySplit="3" topLeftCell="G4" activePane="bottomRight" state="frozen" />'
49
+ assert_equal(expected, result)
50
+ end
51
+
52
+ def test_write_panes_freeze_3_6_3_6_1
53
+ @worksheet.freeze_panes(3, 6, 3, 6, 1)
54
+ @worksheet.__send__('write_panes')
55
+ result = @worksheet.instance_variable_get(:@writer).string
56
+ expected = '<pane xSplit="6" ySplit="3" topLeftCell="G4" activePane="bottomRight" state="frozenSplit" />'
57
+ assert_equal(expected, result)
58
+ end
59
+
60
+ def test_write_panes_freeze_split_15
61
+ @worksheet.split_panes(15)
62
+ @worksheet.__send__('write_panes')
63
+ result = @worksheet.instance_variable_get(:@writer).string
64
+ expected = '<pane ySplit="600" topLeftCell="A2" />'
65
+ assert_equal(expected, result)
66
+ end
67
+
68
+ def test_write_panes_freeze_split_30
69
+ @worksheet.split_panes(30)
70
+ @worksheet.__send__('write_panes')
71
+ result = @worksheet.instance_variable_get(:@writer).string
72
+ expected = '<pane ySplit="900" topLeftCell="A3" />'
73
+ assert_equal(expected, result)
74
+ end
75
+
76
+ def test_write_panes_freeze_split_105
77
+ @worksheet.split_panes(105)
78
+ @worksheet.__send__('write_panes')
79
+ result = @worksheet.instance_variable_get(:@writer).string
80
+ expected = '<pane ySplit="2400" topLeftCell="A8" />'
81
+ assert_equal(expected, result)
82
+ end
83
+
84
+ def test_write_panes_freeze_split_0_843
85
+ @worksheet.split_panes(0, 8.43)
86
+ @worksheet.__send__('write_panes')
87
+ result = @worksheet.instance_variable_get(:@writer).string
88
+ expected = '<pane xSplit="1350" topLeftCell="B1" />'
89
+ assert_equal(expected, result)
90
+ end
91
+
92
+ def test_write_panes_freeze_split_0_1757
93
+ @worksheet.split_panes(0, 17.57)
94
+ @worksheet.__send__('write_panes')
95
+ result = @worksheet.instance_variable_get(:@writer).string
96
+ expected = '<pane xSplit="2310" topLeftCell="C1" />'
97
+ assert_equal(expected, result)
98
+ end
99
+
100
+ def test_write_panes_freeze_split_0_45
101
+ @worksheet.split_panes(0, 45)
102
+ @worksheet.__send__('write_panes')
103
+ result = @worksheet.instance_variable_get(:@writer).string
104
+ expected = '<pane xSplit="5190" topLeftCell="F1" />'
105
+ assert_equal(expected, result)
106
+ end
107
+
108
+ def test_write_panes_freeze_split_15_843
109
+ @worksheet.split_panes(15, 8.43)
110
+ @worksheet.__send__('write_panes')
111
+ result = @worksheet.instance_variable_get(:@writer).string
112
+ expected = '<pane xSplit="1350" ySplit="600" topLeftCell="B2" />'
113
+ assert_equal(expected, result)
114
+ end
115
+
116
+ def test_write_panes_freeze_split_45_5114
117
+ @worksheet.split_panes(45, 54.14)
118
+ @worksheet.__send__('write_panes')
119
+ result = @worksheet.instance_variable_get(:@writer).string
120
+ expected = '<pane xSplit="6150" ySplit="1200" topLeftCell="G4" />'
121
+ assert_equal(expected, result)
122
+ end
123
+ end
@@ -0,0 +1,19 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx/workbook'
4
+ require 'write_xlsx/worksheet'
5
+ require 'stringio'
6
+
7
+ class TestWritePhoneticPr < Test::Unit::TestCase
8
+ def setup
9
+ @workbook = WriteXLSX.new(StringIO.new)
10
+ @worksheet = @workbook.add_worksheet('')
11
+ end
12
+
13
+ def test_write_phonetic_pr
14
+ @worksheet.__send__('write_phonetic_pr')
15
+ result = @worksheet.instance_variable_get(:@writer).string
16
+ expected = '<phoneticPr fontId="1" type="noConversion" />'
17
+ assert_equal(expected, result)
18
+ end
19
+ end
@@ -0,0 +1,77 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx/workbook'
4
+ require 'write_xlsx/worksheet'
5
+ require 'stringio'
6
+
7
+ class TestWritePrintOptions < Test::Unit::TestCase
8
+ def setup
9
+ @workbook = WriteXLSX.new(StringIO.new)
10
+ @worksheet = @workbook.add_worksheet('')
11
+ end
12
+
13
+ def test_write_print_options
14
+ @worksheet.__send__('write_print_options')
15
+ result = @worksheet.instance_variable_get(:@writer).string
16
+ expected = ''
17
+ assert_equal(expected, result)
18
+ end
19
+
20
+ def test_write_print_options_center_horizontally
21
+ @worksheet.center_horizontally
22
+ @worksheet.__send__('write_print_options')
23
+ result = @worksheet.instance_variable_get(:@writer).string
24
+ expected = '<printOptions horizontalCentered="1" />'
25
+ assert_equal(expected, result)
26
+ end
27
+
28
+ def test_write_print_options_center_vertically
29
+ @worksheet.center_vertically
30
+ @worksheet.__send__('write_print_options')
31
+ result = @worksheet.instance_variable_get(:@writer).string
32
+ expected = '<printOptions verticalCentered="1" />'
33
+ assert_equal(expected, result)
34
+ end
35
+
36
+ def test_write_print_options_center_horizontally_and_vertically
37
+ @worksheet.center_horizontally
38
+ @worksheet.center_vertically
39
+ @worksheet.__send__('write_print_options')
40
+ result = @worksheet.instance_variable_get(:@writer).string
41
+ expected = '<printOptions horizontalCentered="1" verticalCentered="1" />'
42
+ assert_equal(expected, result)
43
+ end
44
+
45
+ def test_write_print_options_hide_gridlines
46
+ @worksheet.hide_gridlines
47
+ @worksheet.__send__('write_print_options')
48
+ result = @worksheet.instance_variable_get(:@writer).string
49
+ expected = ''
50
+ assert_equal(expected, result)
51
+ end
52
+
53
+ def test_write_print_options_hide_gridlines_false
54
+ @worksheet.hide_gridlines(false)
55
+ @worksheet.__send__('write_print_options')
56
+ result = @worksheet.instance_variable_get(:@writer).string
57
+ expected = '<printOptions gridLines="1" />'
58
+ assert_equal(expected, result)
59
+ end
60
+ =begin
61
+ def test_write_print_options_1_hide_gridlines
62
+ @worksheet.hide_gridlines
63
+ @worksheet.__send__('write_print_options', 1)
64
+ result = @worksheet.instance_variable_get(:@writer).string
65
+ expected = ''
66
+ assert_equal(expected, result)
67
+ end
68
+
69
+ def test_write_print_options_2_hide_gridlines_false
70
+ @worksheet.hide_gridlines(false)
71
+ @worksheet.__send__('write_print_options', 2)
72
+ result = @worksheet.instance_variable_get(:@writer).string
73
+ expected = '<printOptions gridLines="1" />'
74
+ assert_equal(expected, result)
75
+ end
76
+ =end
77
+ end
@@ -0,0 +1,27 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx'
4
+ require 'stringio'
5
+
6
+ class TestWriteRowBreaks < Test::Unit::TestCase
7
+ def setup
8
+ @workbook = WriteXLSX.new(StringIO.new)
9
+ @worksheet = @workbook.add_worksheet('')
10
+ end
11
+
12
+ def test_write_row_breaks_1
13
+ @worksheet.instance_variable_get(:@print_style).hbreaks = [1]
14
+ @worksheet.__send__('write_row_breaks')
15
+ result = @worksheet.instance_variable_get(:@writer).string
16
+ expected = '<rowBreaks count="1" manualBreakCount="1"><brk id="1" max="16383" man="1" /></rowBreaks>'
17
+ assert_equal(expected, result)
18
+ end
19
+
20
+ def test_write_row_breaks_15_7_3_0
21
+ @worksheet.instance_variable_get(:@print_style).hbreaks = [15, 7, 3, 0]
22
+ @worksheet.__send__('write_row_breaks')
23
+ result = @worksheet.instance_variable_get(:@writer).string
24
+ expected = '<rowBreaks count="3" manualBreakCount="3"><brk id="3" max="16383" man="1" /><brk id="7" max="16383" man="1" /><brk id="15" max="16383" man="1" /></rowBreaks>'
25
+ assert_equal(expected, result)
26
+ end
27
+ end
@@ -0,0 +1,69 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx/workbook'
4
+ require 'write_xlsx/worksheet'
5
+ require 'stringio'
6
+
7
+ class TestWriteRow < Test::Unit::TestCase
8
+ def setup
9
+ @workbook = WriteXLSX.new(StringIO.new)
10
+ @worksheet = @workbook.add_worksheet('')
11
+ end
12
+
13
+ def test_write_row_0
14
+ @worksheet.__send__('write_row_element', 0)
15
+ result = @worksheet.instance_variable_get(:@writer).string
16
+ expected = '<row r="1">'
17
+ assert_equal(expected, result)
18
+ end
19
+
20
+ def test_write_row_2_22
21
+ @worksheet.__send__('write_row_element', 2, '2:2')
22
+ result = @worksheet.instance_variable_get(:@writer).string
23
+ expected = '<row r="3" spans="2:2">'
24
+ assert_equal(expected, result)
25
+ end
26
+
27
+ def test_write_row_1_nil_30
28
+ @worksheet.__send__('write_row_element', 1, nil, 30)
29
+ result = @worksheet.instance_variable_get(:@writer).string
30
+ expected = '<row r="2" ht="30" customHeight="1">'
31
+ assert_equal(expected, result)
32
+ end
33
+
34
+ def test_write_row_3_nil_nil_nil_1
35
+ @worksheet.__send__('write_row_element', 3, nil, nil, nil, 1)
36
+ result = @worksheet.instance_variable_get(:@writer).string
37
+ expected = '<row r="4" hidden="1">'
38
+ assert_equal(expected, result)
39
+ end
40
+
41
+ def test_write_row_6_nil_nil_format
42
+ format = Writexlsx::Format.new({}, {}, :xf_index => 1)
43
+ @worksheet.__send__('write_row_element', 6, nil, nil, format)
44
+ result = @worksheet.instance_variable_get(:@writer).string
45
+ expected = '<row r="7" s="1" customFormat="1">'
46
+ assert_equal(expected, result)
47
+ end
48
+
49
+ def test_write_row_9_nil_3
50
+ @worksheet.__send__('write_row_element', 9, nil, 3)
51
+ result = @worksheet.instance_variable_get(:@writer).string
52
+ expected = '<row r="10" ht="3" customHeight="1">'
53
+ assert_equal(expected, result)
54
+ end
55
+
56
+ def test_write_row_12_nil_24_nil_1
57
+ @worksheet.__send__('write_row_element', 12, nil, 24, nil, 1)
58
+ result = @worksheet.instance_variable_get(:@writer).string
59
+ expected = '<row r="13" ht="24" hidden="1" customHeight="1">'
60
+ assert_equal(expected, result)
61
+ end
62
+
63
+ def test_write_empty_row_12_nil_24_nil_1
64
+ @worksheet.__send__('write_empty_row', 12, nil, 24, nil, 1)
65
+ result = @worksheet.instance_variable_get(:@writer).string
66
+ expected = '<row r="13" ht="24" hidden="1" customHeight="1" />'
67
+ assert_equal(expected, result)
68
+ end
69
+ end
@@ -0,0 +1,18 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx'
4
+ require 'stringio'
5
+
6
+ class TestWriteSelection < Test::Unit::TestCase
7
+ def setup
8
+ @workbook = WriteXLSX.new(StringIO.new)
9
+ @worksheet = @workbook.add_worksheet('')
10
+ end
11
+
12
+ def test_write_selection
13
+ @worksheet.__send__('write_selection', nil, 'A1', 'A1')
14
+ result = @worksheet.instance_variable_get(:@writer).string
15
+ expected = '<selection activeCell="A1" sqref="A1" />'
16
+ assert_equal(expected, result)
17
+ end
18
+ end
@@ -0,0 +1,18 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx'
4
+ require 'stringio'
5
+
6
+ class TestWriteSheetCalcPr < Test::Unit::TestCase
7
+ def setup
8
+ @workbook = WriteXLSX.new(StringIO.new)
9
+ @worksheet = @workbook.add_worksheet('')
10
+ end
11
+
12
+ def test_write_sheet_calc_pr
13
+ @worksheet.__send__('write_sheet_calc_pr')
14
+ result = @worksheet.instance_variable_get(:@writer).string
15
+ expected = '<sheetCalcPr fullCalcOnLoad="1" />'
16
+ assert_equal(expected, result)
17
+ end
18
+ end
@@ -0,0 +1,18 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx'
4
+ require 'stringio'
5
+
6
+ class TestWriteSheetData < Test::Unit::TestCase
7
+ def setup
8
+ @workbook = WriteXLSX.new(StringIO.new)
9
+ @worksheet = @workbook.add_worksheet('')
10
+ end
11
+
12
+ def test_write_sheet_data
13
+ @worksheet.__send__('write_sheet_data')
14
+ result = @worksheet.instance_variable_get(:@writer).string
15
+ expected = '<sheetData />'
16
+ assert_equal(expected, result)
17
+ end
18
+ end