caxlsx 2.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 (305) hide show
  1. checksums.yaml +7 -0
  2. data/.yardopts +9 -0
  3. data/.yardopts_guide +19 -0
  4. data/CHANGELOG.md +239 -0
  5. data/LICENSE +22 -0
  6. data/README.md +256 -0
  7. data/Rakefile +31 -0
  8. data/examples/2010_comments.rb +17 -0
  9. data/examples/anchor_swapping.rb +28 -0
  10. data/examples/auto_filter.rb +16 -0
  11. data/examples/basic_charts.rb +58 -0
  12. data/examples/chart_colors.rb +88 -0
  13. data/examples/colored_links.rb +59 -0
  14. data/examples/conditional_formatting/example_conditional_formatting.rb +74 -0
  15. data/examples/conditional_formatting/getting_barred.rb +37 -0
  16. data/examples/conditional_formatting/hitting_the_high_notes.rb +37 -0
  17. data/examples/conditional_formatting/scaled_colors.rb +39 -0
  18. data/examples/conditional_formatting/stop_and_go.rb +37 -0
  19. data/examples/data_validation.rb +50 -0
  20. data/examples/example.rb +777 -0
  21. data/examples/extractive.rb +45 -0
  22. data/examples/image1.jpeg +0 -0
  23. data/examples/ios_preview.rb +14 -0
  24. data/examples/page_setup.rb +11 -0
  25. data/examples/pivot_table.rb +39 -0
  26. data/examples/sheet_protection.rb +10 -0
  27. data/examples/skydrive/real_example.rb +63 -0
  28. data/examples/styles.rb +66 -0
  29. data/examples/underline.rb +13 -0
  30. data/examples/wrap_text.rb +21 -0
  31. data/lib/axlsx.rb +152 -0
  32. data/lib/axlsx/content_type/abstract_content_type.rb +32 -0
  33. data/lib/axlsx/content_type/content_type.rb +26 -0
  34. data/lib/axlsx/content_type/default.rb +25 -0
  35. data/lib/axlsx/content_type/override.rb +25 -0
  36. data/lib/axlsx/doc_props/app.rb +235 -0
  37. data/lib/axlsx/doc_props/core.rb +39 -0
  38. data/lib/axlsx/drawing/ax_data_source.rb +26 -0
  39. data/lib/axlsx/drawing/axes.rb +61 -0
  40. data/lib/axlsx/drawing/axis.rb +187 -0
  41. data/lib/axlsx/drawing/bar_3D_chart.rb +151 -0
  42. data/lib/axlsx/drawing/bar_series.rb +82 -0
  43. data/lib/axlsx/drawing/cat_axis.rb +85 -0
  44. data/lib/axlsx/drawing/chart.rb +232 -0
  45. data/lib/axlsx/drawing/d_lbls.rb +90 -0
  46. data/lib/axlsx/drawing/drawing.rb +162 -0
  47. data/lib/axlsx/drawing/graphic_frame.rb +54 -0
  48. data/lib/axlsx/drawing/hyperlink.rb +102 -0
  49. data/lib/axlsx/drawing/line_3D_chart.rb +68 -0
  50. data/lib/axlsx/drawing/line_chart.rb +99 -0
  51. data/lib/axlsx/drawing/line_series.rb +81 -0
  52. data/lib/axlsx/drawing/marker.rb +84 -0
  53. data/lib/axlsx/drawing/num_data.rb +52 -0
  54. data/lib/axlsx/drawing/num_data_source.rb +62 -0
  55. data/lib/axlsx/drawing/num_val.rb +32 -0
  56. data/lib/axlsx/drawing/one_cell_anchor.rb +98 -0
  57. data/lib/axlsx/drawing/pic.rb +205 -0
  58. data/lib/axlsx/drawing/picture_locking.rb +44 -0
  59. data/lib/axlsx/drawing/pie_3D_chart.rb +48 -0
  60. data/lib/axlsx/drawing/pie_series.rb +74 -0
  61. data/lib/axlsx/drawing/scaling.rb +60 -0
  62. data/lib/axlsx/drawing/scatter_chart.rb +74 -0
  63. data/lib/axlsx/drawing/scatter_series.rb +65 -0
  64. data/lib/axlsx/drawing/ser_axis.rb +45 -0
  65. data/lib/axlsx/drawing/series.rb +69 -0
  66. data/lib/axlsx/drawing/series_title.rb +23 -0
  67. data/lib/axlsx/drawing/str_data.rb +42 -0
  68. data/lib/axlsx/drawing/str_val.rb +32 -0
  69. data/lib/axlsx/drawing/title.rb +78 -0
  70. data/lib/axlsx/drawing/two_cell_anchor.rb +92 -0
  71. data/lib/axlsx/drawing/val_axis.rb +37 -0
  72. data/lib/axlsx/drawing/view_3D.rb +115 -0
  73. data/lib/axlsx/drawing/vml_drawing.rb +42 -0
  74. data/lib/axlsx/drawing/vml_shape.rb +66 -0
  75. data/lib/axlsx/package.rb +352 -0
  76. data/lib/axlsx/rels/relationship.rb +129 -0
  77. data/lib/axlsx/rels/relationships.rb +29 -0
  78. data/lib/axlsx/stylesheet/border.rb +71 -0
  79. data/lib/axlsx/stylesheet/border_pr.rb +71 -0
  80. data/lib/axlsx/stylesheet/cell_alignment.rb +134 -0
  81. data/lib/axlsx/stylesheet/cell_protection.rb +43 -0
  82. data/lib/axlsx/stylesheet/cell_style.rb +74 -0
  83. data/lib/axlsx/stylesheet/color.rb +78 -0
  84. data/lib/axlsx/stylesheet/dxf.rb +79 -0
  85. data/lib/axlsx/stylesheet/fill.rb +35 -0
  86. data/lib/axlsx/stylesheet/font.rb +148 -0
  87. data/lib/axlsx/stylesheet/gradient_fill.rb +103 -0
  88. data/lib/axlsx/stylesheet/gradient_stop.rb +37 -0
  89. data/lib/axlsx/stylesheet/num_fmt.rb +79 -0
  90. data/lib/axlsx/stylesheet/pattern_fill.rb +73 -0
  91. data/lib/axlsx/stylesheet/styles.rb +420 -0
  92. data/lib/axlsx/stylesheet/table_style.rb +54 -0
  93. data/lib/axlsx/stylesheet/table_style_element.rb +79 -0
  94. data/lib/axlsx/stylesheet/table_styles.rb +46 -0
  95. data/lib/axlsx/stylesheet/xf.rb +147 -0
  96. data/lib/axlsx/util/accessors.rb +64 -0
  97. data/lib/axlsx/util/constants.rb +392 -0
  98. data/lib/axlsx/util/options_parser.rb +15 -0
  99. data/lib/axlsx/util/parser.rb +44 -0
  100. data/lib/axlsx/util/serialized_attributes.rb +79 -0
  101. data/lib/axlsx/util/simple_typed_list.rb +203 -0
  102. data/lib/axlsx/util/storage.rb +146 -0
  103. data/lib/axlsx/util/validators.rb +300 -0
  104. data/lib/axlsx/version.rb +5 -0
  105. data/lib/axlsx/workbook/defined_name.rb +129 -0
  106. data/lib/axlsx/workbook/defined_names.rb +21 -0
  107. data/lib/axlsx/workbook/shared_strings_table.rb +77 -0
  108. data/lib/axlsx/workbook/workbook.rb +354 -0
  109. data/lib/axlsx/workbook/worksheet/auto_filter/auto_filter.rb +77 -0
  110. data/lib/axlsx/workbook/worksheet/auto_filter/filter_column.rb +94 -0
  111. data/lib/axlsx/workbook/worksheet/auto_filter/filters.rb +246 -0
  112. data/lib/axlsx/workbook/worksheet/break.rb +37 -0
  113. data/lib/axlsx/workbook/worksheet/cell.rb +416 -0
  114. data/lib/axlsx/workbook/worksheet/cell_serializer.rb +144 -0
  115. data/lib/axlsx/workbook/worksheet/cfvo.rb +62 -0
  116. data/lib/axlsx/workbook/worksheet/cfvos.rb +15 -0
  117. data/lib/axlsx/workbook/worksheet/col.rb +144 -0
  118. data/lib/axlsx/workbook/worksheet/col_breaks.rb +35 -0
  119. data/lib/axlsx/workbook/worksheet/color_scale.rb +110 -0
  120. data/lib/axlsx/workbook/worksheet/cols.rb +20 -0
  121. data/lib/axlsx/workbook/worksheet/comment.rb +92 -0
  122. data/lib/axlsx/workbook/worksheet/comments.rb +85 -0
  123. data/lib/axlsx/workbook/worksheet/conditional_formatting.rb +82 -0
  124. data/lib/axlsx/workbook/worksheet/conditional_formatting_rule.rb +220 -0
  125. data/lib/axlsx/workbook/worksheet/conditional_formattings.rb +25 -0
  126. data/lib/axlsx/workbook/worksheet/data_bar.rb +131 -0
  127. data/lib/axlsx/workbook/worksheet/data_validation.rb +244 -0
  128. data/lib/axlsx/workbook/worksheet/data_validations.rb +28 -0
  129. data/lib/axlsx/workbook/worksheet/date_time_converter.rb +30 -0
  130. data/lib/axlsx/workbook/worksheet/dimension.rb +64 -0
  131. data/lib/axlsx/workbook/worksheet/header_footer.rb +54 -0
  132. data/lib/axlsx/workbook/worksheet/icon_set.rb +83 -0
  133. data/lib/axlsx/workbook/worksheet/merged_cells.rb +35 -0
  134. data/lib/axlsx/workbook/worksheet/page_margins.rb +99 -0
  135. data/lib/axlsx/workbook/worksheet/page_set_up_pr.rb +44 -0
  136. data/lib/axlsx/workbook/worksheet/page_setup.rb +242 -0
  137. data/lib/axlsx/workbook/worksheet/pane.rb +141 -0
  138. data/lib/axlsx/workbook/worksheet/pivot_table.rb +273 -0
  139. data/lib/axlsx/workbook/worksheet/pivot_table_cache_definition.rb +66 -0
  140. data/lib/axlsx/workbook/worksheet/pivot_tables.rb +24 -0
  141. data/lib/axlsx/workbook/worksheet/print_options.rb +41 -0
  142. data/lib/axlsx/workbook/worksheet/protected_range.rb +49 -0
  143. data/lib/axlsx/workbook/worksheet/protected_ranges.rb +34 -0
  144. data/lib/axlsx/workbook/worksheet/row.rb +172 -0
  145. data/lib/axlsx/workbook/worksheet/row_breaks.rb +33 -0
  146. data/lib/axlsx/workbook/worksheet/selection.rb +103 -0
  147. data/lib/axlsx/workbook/worksheet/sheet_calc_pr.rb +29 -0
  148. data/lib/axlsx/workbook/worksheet/sheet_data.rb +25 -0
  149. data/lib/axlsx/workbook/worksheet/sheet_format_pr.rb +60 -0
  150. data/lib/axlsx/workbook/worksheet/sheet_pr.rb +69 -0
  151. data/lib/axlsx/workbook/worksheet/sheet_protection.rb +120 -0
  152. data/lib/axlsx/workbook/worksheet/sheet_view.rb +213 -0
  153. data/lib/axlsx/workbook/worksheet/table.rb +102 -0
  154. data/lib/axlsx/workbook/worksheet/table_style_info.rb +51 -0
  155. data/lib/axlsx/workbook/worksheet/tables.rb +31 -0
  156. data/lib/axlsx/workbook/worksheet/worksheet.rb +769 -0
  157. data/lib/axlsx/workbook/worksheet/worksheet_comments.rb +58 -0
  158. data/lib/axlsx/workbook/worksheet/worksheet_drawing.rb +58 -0
  159. data/lib/axlsx/workbook/worksheet/worksheet_hyperlink.rb +74 -0
  160. data/lib/axlsx/workbook/worksheet/worksheet_hyperlinks.rb +38 -0
  161. data/lib/schema/dc.xsd +118 -0
  162. data/lib/schema/dcmitype.xsd +52 -0
  163. data/lib/schema/dcterms.xsd +331 -0
  164. data/lib/schema/dml-chart.xsd +1499 -0
  165. data/lib/schema/dml-chartDrawing.xsd +146 -0
  166. data/lib/schema/dml-compatibility.xsd +14 -0
  167. data/lib/schema/dml-diagram.xsd +1091 -0
  168. data/lib/schema/dml-lockedCanvas.xsd +11 -0
  169. data/lib/schema/dml-main.xsd +3048 -0
  170. data/lib/schema/dml-picture.xsd +23 -0
  171. data/lib/schema/dml-spreadsheetDrawing.xsd +185 -0
  172. data/lib/schema/dml-wordprocessingDrawing.xsd +185 -0
  173. data/lib/schema/opc-contentTypes.xsd +42 -0
  174. data/lib/schema/opc-coreProperties.xsd +54 -0
  175. data/lib/schema/opc-digSig.xsd +49 -0
  176. data/lib/schema/opc-relationships.xsd +33 -0
  177. data/lib/schema/pml.xsd +1676 -0
  178. data/lib/schema/shared-additionalCharacteristics.xsd +28 -0
  179. data/lib/schema/shared-bibliography.xsd +144 -0
  180. data/lib/schema/shared-commonSimpleTypes.xsd +166 -0
  181. data/lib/schema/shared-customXmlDataProperties.xsd +25 -0
  182. data/lib/schema/shared-customXmlSchemaProperties.xsd +18 -0
  183. data/lib/schema/shared-documentPropertiesCustom.xsd +59 -0
  184. data/lib/schema/shared-documentPropertiesExtended.xsd +56 -0
  185. data/lib/schema/shared-documentPropertiesVariantTypes.xsd +195 -0
  186. data/lib/schema/shared-math.xsd +582 -0
  187. data/lib/schema/shared-relationshipReference.xsd +25 -0
  188. data/lib/schema/sml.xsd +4434 -0
  189. data/lib/schema/vml-main.xsd +569 -0
  190. data/lib/schema/vml-officeDrawing.xsd +509 -0
  191. data/lib/schema/vml-presentationDrawing.xsd +12 -0
  192. data/lib/schema/vml-spreadsheetDrawing.xsd +108 -0
  193. data/lib/schema/vml-wordprocessingDrawing.xsd +96 -0
  194. data/lib/schema/wml.xsd +3644 -0
  195. data/lib/schema/xml.xsd +116 -0
  196. data/test/benchmark.rb +72 -0
  197. data/test/content_type/tc_content_type.rb +76 -0
  198. data/test/content_type/tc_default.rb +16 -0
  199. data/test/content_type/tc_override.rb +14 -0
  200. data/test/doc_props/tc_app.rb +43 -0
  201. data/test/doc_props/tc_core.rb +42 -0
  202. data/test/drawing/tc_axes.rb +8 -0
  203. data/test/drawing/tc_axis.rb +85 -0
  204. data/test/drawing/tc_bar_3D_chart.rb +71 -0
  205. data/test/drawing/tc_bar_series.rb +37 -0
  206. data/test/drawing/tc_cat_axis.rb +31 -0
  207. data/test/drawing/tc_cat_axis_data.rb +27 -0
  208. data/test/drawing/tc_chart.rb +110 -0
  209. data/test/drawing/tc_d_lbls.rb +57 -0
  210. data/test/drawing/tc_data_source.rb +17 -0
  211. data/test/drawing/tc_drawing.rb +80 -0
  212. data/test/drawing/tc_graphic_frame.rb +27 -0
  213. data/test/drawing/tc_hyperlink.rb +64 -0
  214. data/test/drawing/tc_line_3d_chart.rb +47 -0
  215. data/test/drawing/tc_line_chart.rb +39 -0
  216. data/test/drawing/tc_line_series.rb +30 -0
  217. data/test/drawing/tc_marker.rb +44 -0
  218. data/test/drawing/tc_named_axis_data.rb +27 -0
  219. data/test/drawing/tc_num_data.rb +31 -0
  220. data/test/drawing/tc_num_val.rb +29 -0
  221. data/test/drawing/tc_one_cell_anchor.rb +66 -0
  222. data/test/drawing/tc_pic.rb +107 -0
  223. data/test/drawing/tc_picture_locking.rb +72 -0
  224. data/test/drawing/tc_pie_3D_chart.rb +28 -0
  225. data/test/drawing/tc_pie_series.rb +32 -0
  226. data/test/drawing/tc_scaling.rb +36 -0
  227. data/test/drawing/tc_scatter_chart.rb +48 -0
  228. data/test/drawing/tc_scatter_series.rb +21 -0
  229. data/test/drawing/tc_ser_axis.rb +31 -0
  230. data/test/drawing/tc_series.rb +23 -0
  231. data/test/drawing/tc_series_title.rb +33 -0
  232. data/test/drawing/tc_str_data.rb +18 -0
  233. data/test/drawing/tc_str_val.rb +21 -0
  234. data/test/drawing/tc_title.rb +49 -0
  235. data/test/drawing/tc_two_cell_anchor.rb +36 -0
  236. data/test/drawing/tc_val_axis.rb +24 -0
  237. data/test/drawing/tc_view_3D.rb +54 -0
  238. data/test/drawing/tc_vml_drawing.rb +25 -0
  239. data/test/drawing/tc_vml_shape.rb +106 -0
  240. data/test/profile.rb +24 -0
  241. data/test/rels/tc_relationship.rb +44 -0
  242. data/test/rels/tc_relationships.rb +37 -0
  243. data/test/stylesheet/tc_border.rb +37 -0
  244. data/test/stylesheet/tc_border_pr.rb +32 -0
  245. data/test/stylesheet/tc_cell_alignment.rb +81 -0
  246. data/test/stylesheet/tc_cell_protection.rb +29 -0
  247. data/test/stylesheet/tc_cell_style.rb +57 -0
  248. data/test/stylesheet/tc_color.rb +43 -0
  249. data/test/stylesheet/tc_dxf.rb +81 -0
  250. data/test/stylesheet/tc_fill.rb +18 -0
  251. data/test/stylesheet/tc_font.rb +121 -0
  252. data/test/stylesheet/tc_gradient_fill.rb +72 -0
  253. data/test/stylesheet/tc_gradient_stop.rb +31 -0
  254. data/test/stylesheet/tc_num_fmt.rb +30 -0
  255. data/test/stylesheet/tc_pattern_fill.rb +43 -0
  256. data/test/stylesheet/tc_styles.rb +235 -0
  257. data/test/stylesheet/tc_table_style.rb +44 -0
  258. data/test/stylesheet/tc_table_style_element.rb +45 -0
  259. data/test/stylesheet/tc_table_styles.rb +29 -0
  260. data/test/stylesheet/tc_xf.rb +120 -0
  261. data/test/tc_axlsx.rb +72 -0
  262. data/test/tc_helper.rb +10 -0
  263. data/test/tc_package.rb +227 -0
  264. data/test/util/tc_serialized_attributes.rb +19 -0
  265. data/test/util/tc_simple_typed_list.rb +78 -0
  266. data/test/util/tc_validators.rb +186 -0
  267. data/test/workbook/tc_defined_name.rb +41 -0
  268. data/test/workbook/tc_shared_strings_table.rb +44 -0
  269. data/test/workbook/tc_workbook.rb +125 -0
  270. data/test/workbook/worksheet/auto_filter/tc_auto_filter.rb +38 -0
  271. data/test/workbook/worksheet/auto_filter/tc_filter_column.rb +76 -0
  272. data/test/workbook/worksheet/auto_filter/tc_filters.rb +50 -0
  273. data/test/workbook/worksheet/tc_break.rb +49 -0
  274. data/test/workbook/worksheet/tc_cell.rb +319 -0
  275. data/test/workbook/worksheet/tc_cfvo.rb +31 -0
  276. data/test/workbook/worksheet/tc_col.rb +78 -0
  277. data/test/workbook/worksheet/tc_color_scale.rb +58 -0
  278. data/test/workbook/worksheet/tc_comment.rb +72 -0
  279. data/test/workbook/worksheet/tc_comments.rb +57 -0
  280. data/test/workbook/worksheet/tc_conditional_formatting.rb +224 -0
  281. data/test/workbook/worksheet/tc_data_bar.rb +46 -0
  282. data/test/workbook/worksheet/tc_data_validation.rb +265 -0
  283. data/test/workbook/worksheet/tc_date_time_converter.rb +124 -0
  284. data/test/workbook/worksheet/tc_header_footer.rb +151 -0
  285. data/test/workbook/worksheet/tc_icon_set.rb +45 -0
  286. data/test/workbook/worksheet/tc_page_margins.rb +97 -0
  287. data/test/workbook/worksheet/tc_page_set_up_pr.rb +15 -0
  288. data/test/workbook/worksheet/tc_page_setup.rb +143 -0
  289. data/test/workbook/worksheet/tc_pane.rb +54 -0
  290. data/test/workbook/worksheet/tc_pivot_table.rb +120 -0
  291. data/test/workbook/worksheet/tc_pivot_table_cache_definition.rb +54 -0
  292. data/test/workbook/worksheet/tc_print_options.rb +72 -0
  293. data/test/workbook/worksheet/tc_protected_range.rb +17 -0
  294. data/test/workbook/worksheet/tc_row.rb +117 -0
  295. data/test/workbook/worksheet/tc_selection.rb +55 -0
  296. data/test/workbook/worksheet/tc_sheet_calc_pr.rb +18 -0
  297. data/test/workbook/worksheet/tc_sheet_format_pr.rb +88 -0
  298. data/test/workbook/worksheet/tc_sheet_pr.rb +27 -0
  299. data/test/workbook/worksheet/tc_sheet_protection.rb +117 -0
  300. data/test/workbook/worksheet/tc_sheet_view.rb +214 -0
  301. data/test/workbook/worksheet/tc_table.rb +68 -0
  302. data/test/workbook/worksheet/tc_table_style_info.rb +53 -0
  303. data/test/workbook/worksheet/tc_worksheet.rb +538 -0
  304. data/test/workbook/worksheet/tc_worksheet_hyperlink.rb +55 -0
  305. metadata +546 -0
@@ -0,0 +1,64 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestHyperlink < Test::Unit::TestCase
4
+
5
+ def setup
6
+ @p = Axlsx::Package.new
7
+ ws = @p.workbook.add_worksheet
8
+ @test_img = File.dirname(__FILE__) + "/../../examples/image1.jpeg"
9
+ @image = ws.add_image :image_src => @test_img, :hyperlink => "http://axlsx.blogspot.com"
10
+ @hyperlink = @image.hyperlink
11
+ end
12
+
13
+ def teardown
14
+ end
15
+
16
+
17
+ def test_href
18
+ assert_nothing_raised { @hyperlink.href = "http://axlsx.blogspot.com" }
19
+ assert_equal(@hyperlink.href, "http://axlsx.blogspot.com")
20
+ end
21
+
22
+ def test_tgtFrame
23
+ assert_nothing_raised { @hyperlink.tgtFrame = "http://axlsx.blogspot.com" }
24
+ assert_equal(@hyperlink.tgtFrame, "http://axlsx.blogspot.com")
25
+ end
26
+
27
+ def test_tooltip
28
+ assert_nothing_raised { @hyperlink.tooltip = "http://axlsx.blogspot.com" }
29
+ assert_equal(@hyperlink.tooltip, "http://axlsx.blogspot.com")
30
+ end
31
+
32
+ def test_invalidUrl
33
+ assert_nothing_raised { @hyperlink.invalidUrl = "http://axlsx.blogspot.com" }
34
+ assert_equal(@hyperlink.invalidUrl, "http://axlsx.blogspot.com")
35
+ end
36
+
37
+ def test_action
38
+ assert_nothing_raised { @hyperlink.action = "flee" }
39
+ assert_equal(@hyperlink.action, "flee")
40
+ end
41
+
42
+ def test_endSnd
43
+ assert_nothing_raised { @hyperlink.endSnd = "true" }
44
+ assert_raise(ArgumentError) {@hyperlink.endSnd = "bob"}
45
+ assert_equal(@hyperlink.endSnd, "true")
46
+ end
47
+
48
+ def test_highlightClick
49
+ assert_nothing_raised { @hyperlink.highlightClick = false }
50
+ assert_raise(ArgumentError) {@hyperlink.highlightClick = "bob"}
51
+ assert_equal(@hyperlink.highlightClick, false )
52
+ end
53
+
54
+ def test_history
55
+ assert_nothing_raised { @hyperlink.history = false }
56
+ assert_raise(ArgumentError) {@hyperlink.history = "bob"}
57
+ assert_equal(@hyperlink.history, false )
58
+ end
59
+
60
+ def test_to_xml_string
61
+ doc = Nokogiri::XML(@p.workbook.worksheets.first.drawing.to_xml_string)
62
+ assert(doc.xpath("//a:hlinkClick"))
63
+ end
64
+ end
@@ -0,0 +1,47 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestLine3DChart < Test::Unit::TestCase
4
+
5
+ def setup
6
+ @p = Axlsx::Package.new
7
+ ws = @p.workbook.add_worksheet
8
+ @row = ws.add_row ["one", 1, Time.now]
9
+ @chart = ws.add_chart Axlsx::Line3DChart, :title => "fishery"
10
+ end
11
+
12
+ def teardown
13
+ end
14
+
15
+ def test_initialization
16
+ assert_equal(@chart.grouping, :standard, "grouping defualt incorrect")
17
+ assert_equal(@chart.series_type, Axlsx::LineSeries, "series type incorrect")
18
+ assert(@chart.catAxis.is_a?(Axlsx::CatAxis), "category axis not created")
19
+ assert(@chart.valAxis.is_a?(Axlsx::ValAxis), "value access not created")
20
+ assert(@chart.serAxis.is_a?(Axlsx::SerAxis), "value access not created")
21
+ end
22
+
23
+ def test_grouping
24
+ assert_raise(ArgumentError, "require valid grouping") { @chart.grouping = :inverted }
25
+ assert_nothing_raised("allow valid grouping") { @chart.grouping = :stacked }
26
+ assert(@chart.grouping == :stacked)
27
+ end
28
+
29
+ def test_gapDepth
30
+ assert_raise(ArgumentError, "require valid gapDepth") { @chart.gapDepth = 200 }
31
+ assert_nothing_raised("allow valid gapDepth") { @chart.gapDepth = "200%" }
32
+ assert(@chart.gapDepth == "200%")
33
+ end
34
+
35
+
36
+ def test_to_xml
37
+ schema = Nokogiri::XML::Schema(File.open(Axlsx::DRAWING_XSD))
38
+ doc = Nokogiri::XML(@chart.to_xml_string)
39
+ errors = []
40
+ schema.validate(doc).each do |error|
41
+ errors.push error
42
+ puts error.message
43
+ end
44
+ assert(errors.empty?, "error free validation")
45
+ end
46
+
47
+ end
@@ -0,0 +1,39 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestLineChart < Test::Unit::TestCase
4
+
5
+ def setup
6
+ @p = Axlsx::Package.new
7
+ ws = @p.workbook.add_worksheet
8
+ @row = ws.add_row ["one", 1, Time.now]
9
+ @chart = ws.add_chart Axlsx::LineChart, :title => "fishery"
10
+ end
11
+
12
+ def teardown
13
+ end
14
+
15
+ def test_initialization
16
+ assert_equal(@chart.grouping, :standard, "grouping defualt incorrect")
17
+ assert_equal(@chart.series_type, Axlsx::LineSeries, "series type incorrect")
18
+ assert(@chart.cat_axis.is_a?(Axlsx::CatAxis), "category axis not created")
19
+ assert(@chart.val_axis.is_a?(Axlsx::ValAxis), "value access not created")
20
+ end
21
+
22
+ def test_grouping
23
+ assert_raise(ArgumentError, "require valid grouping") { @chart.grouping = :inverted }
24
+ assert_nothing_raised("allow valid grouping") { @chart.grouping = :stacked }
25
+ assert(@chart.grouping == :stacked)
26
+ end
27
+
28
+ def test_to_xml
29
+ schema = Nokogiri::XML::Schema(File.open(Axlsx::DRAWING_XSD))
30
+ doc = Nokogiri::XML(@chart.to_xml_string)
31
+ errors = []
32
+ schema.validate(doc).each do |error|
33
+ errors.push error
34
+ puts error.message
35
+ end
36
+ assert(errors.empty?, "error free validation")
37
+ end
38
+
39
+ end
@@ -0,0 +1,30 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestLineSeries < Test::Unit::TestCase
4
+
5
+ def setup
6
+ p = Axlsx::Package.new
7
+ @ws = p.workbook.add_worksheet :name=>"hmmm"
8
+ chart = @ws.add_chart Axlsx::Line3DChart, :title => "fishery"
9
+ @series = chart.add_series :data=>[0,1,2], :labels=>["zero", "one", "two"], :title=>"bob", :color => "#FF0000", :show_marker => true
10
+ end
11
+
12
+ def test_initialize
13
+ assert_equal(@series.title.text, "bob", "series title has been applied")
14
+ assert_equal(@series.labels.class, Axlsx::AxDataSource)
15
+ assert_equal(@series.data.class, Axlsx::NumDataSource)
16
+
17
+ end
18
+
19
+ def test_show_marker
20
+ assert_equal(true, @series.show_marker)
21
+ @series.show_marker = false
22
+ assert_equal(false, @series.show_marker)
23
+ end
24
+ def test_to_xml_string
25
+ doc = Nokogiri::XML(@series.to_xml_string)
26
+ assert(doc.xpath("//srgbClr[@val='#{@series.color}']"))
27
+ assert(doc.xpath("//marker"))
28
+ end
29
+ #TODO serialization testing
30
+ end
@@ -0,0 +1,44 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestMarker < Test::Unit::TestCase
4
+ def setup
5
+ @marker = Axlsx::Marker.new
6
+ end
7
+
8
+ def teardown
9
+ end
10
+
11
+ def test_initialization
12
+ assert(@marker.col == 0)
13
+ assert(@marker.colOff == 0)
14
+ assert(@marker.row == 0)
15
+ assert(@marker.rowOff == 0)
16
+ end
17
+
18
+ def test_col
19
+ assert_raise(ArgumentError) { @marker.col = -1}
20
+ assert_nothing_raised {@marker.col = 10}
21
+ end
22
+
23
+ def test_colOff
24
+ assert_raise(ArgumentError) { @marker.colOff = "1"}
25
+ assert_nothing_raised {@marker.colOff = -10}
26
+ end
27
+
28
+ def test_row
29
+ assert_raise(ArgumentError) { @marker.row = -1}
30
+ assert_nothing_raised {@marker.row = 10}
31
+ end
32
+
33
+ def test_rowOff
34
+ assert_raise(ArgumentError) { @marker.rowOff = "1"}
35
+ assert_nothing_raised {@marker.rowOff = -10}
36
+ end
37
+
38
+ def test_coord
39
+ @marker.coord 5, 10
40
+ assert_equal(@marker.col, 5)
41
+ assert_equal(@marker.row, 10)
42
+ end
43
+
44
+ end
@@ -0,0 +1,27 @@
1
+ # require 'tc_helper.rb'
2
+
3
+ # class TestNamedAxisData < Test::Unit::TestCase
4
+
5
+ # def setup
6
+ # p = Axlsx::Package.new
7
+ # @ws = p.workbook.add_worksheet
8
+ # @chart = @ws.drawing.add_chart Axlsx::Line3DChart
9
+ # @series = @chart.add_series :data=>[0,1,2]
10
+ # end
11
+
12
+ # def test_initialize
13
+ # assert(@series.data.is_a?Axlsx::SimpleTypedList)
14
+ # assert_equal(@series.data, [0,1,2])
15
+ # end
16
+
17
+ # def test_to_xml_string
18
+ # doc = Nokogiri::XML(@chart.to_xml_string)
19
+ # assert_equal(doc.xpath("//c:val/c:numRef/c:f").size,1)
20
+ # assert_equal(doc.xpath("//c:numCache/c:ptCount[@val='#{@series.data.size}']").size,1)
21
+ # @series.data.each_with_index do |datum, index|
22
+ # assert_equal(doc.xpath("//c:numCache/c:pt[@idx='#{index}']").size,1)
23
+ # assert_equal(doc.xpath("//c:numCache/c:pt/c:v[text()='#{datum}']").size,1)
24
+ # end
25
+ # end
26
+
27
+ # end
@@ -0,0 +1,31 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestNumData < Test::Unit::TestCase
4
+
5
+ def setup
6
+ @num_data = Axlsx::NumData.new :data => [1, 2, 3]
7
+ end
8
+
9
+ def test_initialize
10
+ assert_equal(@num_data.format_code, "General")
11
+ end
12
+
13
+ def test_formula_based_cell
14
+
15
+ end
16
+
17
+ def test_format_code
18
+ assert_raise(ArgumentError) {@num_data.format_code = 7}
19
+ assert_nothing_raised {@num_data.format_code = 'foo_bar'}
20
+ end
21
+
22
+ def test_to_xml_string
23
+ str = '<?xml version="1.0" encoding="UTF-8"?>'
24
+ str << '<c:chartSpace xmlns:c="' << Axlsx::XML_NS_C << '">'
25
+ str << @num_data.to_xml_string
26
+ doc = Nokogiri::XML(str)
27
+ assert_equal(doc.xpath("//c:numLit/c:ptCount[@val=3]").size, 1)
28
+ assert_equal(doc.xpath("//c:numLit/c:pt/c:v[text()='1']").size, 1)
29
+ end
30
+
31
+ end
@@ -0,0 +1,29 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestNumVal < Test::Unit::TestCase
4
+
5
+ def setup
6
+ @num_val = Axlsx::NumVal.new :v => 1
7
+ end
8
+
9
+ def test_initialize
10
+ assert_equal(@num_val.format_code, "General")
11
+ assert_equal(@num_val.v, "1")
12
+ end
13
+
14
+ def test_format_code
15
+ assert_raise(ArgumentError) {@num_val.format_code = 7}
16
+ assert_nothing_raised {@num_val.format_code = 'foo_bar'}
17
+ end
18
+
19
+ def test_to_xml_string
20
+ str = '<?xml version="1.0" encoding="UTF-8"?>'
21
+ str << '<c:chartSpace xmlns:c="' << Axlsx::XML_NS_C << '">'
22
+ str << @num_val.to_xml_string(0)
23
+ doc = Nokogiri::XML(str)
24
+ # lets see if this works?
25
+ assert_equal(doc.xpath("//c:pt/c:v[text()='1']").size, 1)
26
+
27
+ end
28
+
29
+ end
@@ -0,0 +1,66 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestOneCellAnchor < Test::Unit::TestCase
4
+
5
+ def setup
6
+ @p = Axlsx::Package.new
7
+ @ws = @p.workbook.add_worksheet
8
+ @test_img = File.dirname(__FILE__) + "/../../examples/image1.jpeg"
9
+ @image = @ws.add_image :image_src => @test_img
10
+ @anchor = @image.anchor
11
+ end
12
+
13
+ def teardown
14
+ end
15
+
16
+ def test_initialization
17
+ assert(@anchor.from.col == 0)
18
+ assert(@anchor.from.row == 0)
19
+ assert(@anchor.width == 0)
20
+ assert(@anchor.height == 0)
21
+ end
22
+
23
+ def test_from
24
+ assert(@anchor.from.is_a?(Axlsx::Marker))
25
+ end
26
+
27
+ def test_object
28
+ assert(@anchor.object.is_a?(Axlsx::Pic))
29
+ end
30
+
31
+ def test_index
32
+ assert_equal(@anchor.index, @anchor.drawing.anchors.index(@anchor))
33
+ end
34
+
35
+ def test_width
36
+ assert_raise(ArgumentError) { @anchor.width = "a" }
37
+ assert_nothing_raised { @anchor.width = 600 }
38
+ assert_equal(@anchor.width, 600)
39
+ end
40
+
41
+ def test_height
42
+ assert_raise(ArgumentError) { @anchor.height = "a" }
43
+ assert_nothing_raised { @anchor.height = 400 }
44
+ assert_equal(400, @anchor.height)
45
+ end
46
+
47
+ def test_ext
48
+ ext = @anchor.send(:ext)
49
+ assert_equal(ext[:cx], (@anchor.width * 914400 / 96))
50
+ assert_equal(ext[:cy], (@anchor.height * 914400 / 96))
51
+ end
52
+
53
+ def test_options
54
+ assert_raise(ArgumentError, 'invalid start_at') { @ws.add_image :image_src=>@test_img, :start_at=>[1] }
55
+ i = @ws.add_image :image_src=>@test_img, :start_at => [1,2], :width=>100, :height=>200, :name=>"someimage", :descr=>"a neat image"
56
+
57
+ assert_equal("a neat image", i.descr)
58
+ assert_equal("someimage", i.name)
59
+ assert_equal(200, i.height)
60
+ assert_equal(100, i.width)
61
+ assert_equal(1, i.anchor.from.col)
62
+ assert_equal(2, i.anchor.from.row)
63
+ assert_equal(@test_img, i.image_src)
64
+ end
65
+
66
+ end
@@ -0,0 +1,107 @@
1
+ require 'tc_helper.rb'
2
+
3
+ class TestPic < Test::Unit::TestCase
4
+
5
+ def setup
6
+ @p = Axlsx::Package.new
7
+ ws = @p.workbook.add_worksheet
8
+ @test_img = File.dirname(__FILE__) + "/../../examples/image1.jpeg"
9
+ @test_img_up = File.dirname(__FILE__) + "/../../examples/IMAGE1UP.JPEG"
10
+ @image = ws.add_image :image_src => @test_img, :hyperlink => 'https://github.com/randym', :tooltip => "What's up doc?"
11
+ end
12
+
13
+ def teardown
14
+ end
15
+
16
+ def test_initialization
17
+ assert_equal(@p.workbook.images.first, @image)
18
+ assert_equal(@image.file_name, 'image1.jpeg')
19
+ assert_equal(@image.image_src, @test_img)
20
+ end
21
+
22
+ def test_anchor_swapping
23
+ #swap from one cell to two cell when end_at is specified
24
+ assert(@image.anchor.is_a?(Axlsx::OneCellAnchor))
25
+ start_at = @image.anchor.from
26
+ @image.end_at 10,5
27
+ assert(@image.anchor.is_a?(Axlsx::TwoCellAnchor))
28
+ assert_equal(start_at.col, @image.anchor.from.col)
29
+ assert_equal(start_at.row, @image.anchor.from.row)
30
+ assert_equal(10,@image.anchor.to.col)
31
+ assert_equal(5, @image.anchor.to.row)
32
+
33
+ #swap from two cell to one cell when width or height are specified
34
+ @image.width = 200
35
+ assert(@image.anchor.is_a?(Axlsx::OneCellAnchor))
36
+ assert_equal(start_at.col, @image.anchor.from.col)
37
+ assert_equal(start_at.row, @image.anchor.from.row)
38
+ assert_equal(200, @image.width)
39
+
40
+ end
41
+ def test_hyperlink
42
+ assert_equal(@image.hyperlink.href, "https://github.com/randym")
43
+ @image.hyperlink = "http://axlsx.blogspot.com"
44
+ assert_equal(@image.hyperlink.href, "http://axlsx.blogspot.com")
45
+ end
46
+
47
+ def test_name
48
+ assert_raise(ArgumentError) { @image.name = 49 }
49
+ assert_nothing_raised { @image.name = "unknown" }
50
+ assert_equal(@image.name, "unknown")
51
+ end
52
+
53
+ def test_start_at
54
+ assert_raise(ArgumentError) { @image.start_at "a", 1 }
55
+ assert_nothing_raised { @image.start_at 6, 7 }
56
+ assert_equal(@image.anchor.from.col, 6)
57
+ assert_equal(@image.anchor.from.row, 7)
58
+ end
59
+
60
+ def test_width
61
+ assert_raise(ArgumentError) { @image.width = "a" }
62
+ assert_nothing_raised { @image.width = 600 }
63
+ assert_equal(@image.width, 600)
64
+ end
65
+
66
+ def test_height
67
+ assert_raise(ArgumentError) { @image.height = "a" }
68
+ assert_nothing_raised { @image.height = 600 }
69
+ assert_equal(600, @image.height)
70
+ end
71
+
72
+ def test_image_src
73
+ assert_raise(ArgumentError) { @image.image_src = 49 }
74
+ assert_raise(ArgumentError) { @image.image_src = 'Unknown' }
75
+ assert_raise(ArgumentError) { @image.image_src = __FILE__ }
76
+ assert_nothing_raised { @image.image_src = @test_img }
77
+ assert_equal(@image.image_src, @test_img)
78
+ end
79
+
80
+ def test_image_src_downcase
81
+ assert_nothing_raised { @image.image_src = @test_img_up }
82
+ end
83
+
84
+ def test_descr
85
+ assert_raise(ArgumentError) { @image.descr = 49 }
86
+ assert_nothing_raised { @image.descr = "test" }
87
+ assert_equal(@image.descr, "test")
88
+ end
89
+
90
+ def test_to_xml
91
+ schema = Nokogiri::XML::Schema(File.open(Axlsx::DRAWING_XSD))
92
+ doc = Nokogiri::XML(@image.anchor.drawing.to_xml_string)
93
+ errors = []
94
+ schema.validate(doc).each do |error|
95
+ errors.push error
96
+ puts error.message
97
+ end
98
+ assert(errors.empty?, "error free validation")
99
+ end
100
+
101
+ def test_to_xml_has_correct_r_id
102
+ r_id = @image.anchor.drawing.relationships.for(@image).Id
103
+ doc = Nokogiri::XML(@image.anchor.drawing.to_xml_string)
104
+ assert_equal r_id, doc.xpath("//a:blip").first["r:embed"]
105
+ end
106
+
107
+ end