write_xlsx 0.89.0 → 1.01.0
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.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/Changes +98 -0
- data/LICENSE.txt +1 -1
- data/README.md +2 -2
- data/examples/a_simple.rb +2 -7
- data/examples/add_vba_project.rb +1 -1
- data/examples/array_formula.rb +1 -1
- data/examples/chart_area.rb +5 -2
- data/examples/chart_bar.rb +5 -2
- data/examples/chart_clustered.rb +1 -1
- data/examples/chart_column.rb +5 -2
- data/examples/chart_combined.rb +1 -1
- data/examples/chart_data_table.rb +9 -3
- data/examples/chart_data_tools.rb +25 -7
- data/examples/chart_doughnut.rb +17 -5
- data/examples/chart_gauge.rb +73 -0
- data/examples/chart_line.rb +5 -2
- data/examples/chart_pareto.rb +1 -1
- data/examples/chart_pie.rb +9 -3
- data/examples/chart_radar.rb +13 -4
- data/examples/chart_scatter.rb +5 -2
- data/examples/chart_secondary_axis.rb +5 -2
- data/examples/chart_stock.rb +1 -1
- data/examples/chart_styles.rb +1 -1
- data/examples/colors.rb +1 -1
- data/examples/conditional_format.rb +73 -46
- data/examples/data_validate.rb +1 -1
- data/examples/date_time.rb +1 -1
- data/examples/demo.rb +5 -8
- data/examples/formats.rb +1 -1
- data/examples/headers.rb +1 -1
- data/examples/hide_row_col.rb +1 -1
- data/examples/hide_sheet.rb +1 -1
- data/examples/hyperlink1.rb +5 -12
- data/examples/indent.rb +1 -1
- data/examples/macros.rb +1 -1
- data/examples/merge1.rb +1 -1
- data/examples/merge2.rb +1 -1
- data/examples/merge3.rb +1 -1
- data/examples/merge4.rb +1 -1
- data/examples/merge5.rb +1 -1
- data/examples/merge6.rb +1 -1
- data/examples/outline.rb +1 -1
- data/examples/outline_collapsed.rb +1 -1
- data/examples/panes.rb +1 -1
- data/examples/properties.rb +1 -1
- data/examples/regions.rb +1 -1
- data/examples/rich_strings.rb +1 -1
- data/examples/right_to_left.rb +1 -1
- data/examples/shape1.rb +1 -1
- data/examples/shape2.rb +1 -1
- data/examples/shape3.rb +1 -1
- data/examples/shape4.rb +1 -1
- data/examples/shape5.rb +1 -1
- data/examples/shape6.rb +1 -1
- data/examples/shape7.rb +1 -1
- data/examples/shape8.rb +1 -1
- data/examples/shape_all.rb +1 -1
- data/examples/sparklines1.rb +1 -1
- data/examples/sparklines2.rb +1 -1
- data/examples/stats.rb +1 -1
- data/examples/stats_ext.rb +1 -1
- data/examples/stocks.rb +1 -1
- data/examples/tab_colors.rb +1 -1
- data/examples/tables.rb +1 -1
- data/lib/write_xlsx/chart.rb +124 -240
- data/lib/write_xlsx/chart/area.rb +1 -1
- data/lib/write_xlsx/chart/axis.rb +4 -4
- data/lib/write_xlsx/chart/bar.rb +1 -1
- data/lib/write_xlsx/chart/caption.rb +3 -1
- data/lib/write_xlsx/chart/column.rb +1 -1
- data/lib/write_xlsx/chart/doughnut.rb +1 -1
- data/lib/write_xlsx/chart/legend.rb +14 -0
- data/lib/write_xlsx/chart/line.rb +1 -1
- data/lib/write_xlsx/chart/pie.rb +32 -15
- data/lib/write_xlsx/chart/radar.rb +1 -1
- data/lib/write_xlsx/chart/scatter.rb +1 -1
- data/lib/write_xlsx/chart/series.rb +11 -7
- data/lib/write_xlsx/chart/stock.rb +1 -1
- data/lib/write_xlsx/chartsheet.rb +35 -7
- data/lib/write_xlsx/drawing.rb +28 -8
- data/lib/write_xlsx/format.rb +19 -15
- data/lib/write_xlsx/package/comments.rb +57 -54
- data/lib/write_xlsx/package/conditional_format.rb +360 -39
- data/lib/write_xlsx/package/content_types.rb +10 -0
- data/lib/write_xlsx/package/core.rb +8 -6
- data/lib/write_xlsx/package/custom.rb +125 -0
- data/lib/write_xlsx/package/packager.rb +26 -0
- data/lib/write_xlsx/package/styles.rb +53 -21
- data/lib/write_xlsx/package/table.rb +16 -4
- data/lib/write_xlsx/shape.rb +4 -3
- data/lib/write_xlsx/sheets.rb +11 -1
- data/lib/write_xlsx/sparkline.rb +1 -1
- data/lib/write_xlsx/utility.rb +305 -35
- data/lib/write_xlsx/version.rb +1 -1
- data/lib/write_xlsx/workbook.rb +132 -12
- data/lib/write_xlsx/worksheet.rb +397 -163
- data/lib/write_xlsx/worksheet/data_validation.rb +10 -14
- data/lib/write_xlsx/worksheet/hyperlink.rb +4 -13
- data/test/chart/test_write_legend_pos.rb +9 -1
- data/test/chartsheet/test_write_sheet_protection.rb +91 -0
- data/test/drawing/test_drawing_chart_01.rb +6 -2
- data/test/drawing/test_drawing_image_01.rb +12 -3
- data/test/drawing/test_drawing_shape_01.rb +8 -5
- data/test/drawing/test_drawing_shape_02.rb +12 -5
- data/test/drawing/test_drawing_shape_03.rb +8 -5
- data/test/drawing/test_drawing_shape_04.rb +8 -24
- data/test/drawing/test_drawing_shape_05.rb +8 -5
- data/test/drawing/test_drawing_shape_06.rb +11 -6
- data/test/drawing/test_drawing_shape_07.rb +11 -6
- data/test/drawing/test_write_a_graphic_frame_locks.rb +1 -1
- data/test/drawing/test_write_c_chart.rb +1 -1
- data/test/drawing/test_write_c_nv_graphic_frame_pr.rb +1 -1
- data/test/drawing/test_write_c_nv_pr.rb +1 -1
- data/test/drawing/test_write_col.rb +1 -1
- data/test/drawing/test_write_col_off.rb +1 -1
- data/test/drawing/test_write_ext.rb +1 -1
- data/test/drawing/test_write_pos.rb +1 -1
- data/test/drawing/test_write_row.rb +1 -1
- data/test/drawing/test_write_row_off.rb +1 -1
- data/test/drawing/test_write_xfrm_extension.rb +1 -1
- data/test/drawing/test_write_xfrm_offset.rb +1 -1
- data/test/helper.rb +6 -1
- data/test/package/comments/test_comments_01.rb +54 -0
- data/test/package/comments/test_comments_02.rb +54 -0
- data/test/perl_output/chart_gauge.xlsx +0 -0
- data/test/perl_output/formats.xlsx +0 -0
- data/test/regression/_test_hyperlink31.rb +26 -0
- data/test/regression/images/happy.jpg +0 -0
- data/test/regression/images/zero_dpi.jpg +0 -0
- data/test/regression/test_array_formula03.rb +36 -0
- data/test/regression/test_autofilter08.rb +110 -0
- data/test/regression/test_autofilter09.rb +110 -0
- data/test/regression/test_autofilter10.rb +110 -0
- data/test/regression/test_chart_axis26.rb +10 -8
- data/test/regression/test_chart_axis27.rb +1 -1
- data/test/regression/test_chart_axis28.rb +1 -1
- data/test/regression/test_chart_axis29.rb +1 -1
- data/test/regression/test_chart_axis33.rb +1 -1
- data/test/regression/test_chart_axis42.rb +44 -0
- data/test/regression/test_chart_axis43.rb +44 -0
- data/test/regression/test_chart_axis44.rb +54 -0
- data/test/regression/test_chart_axis45.rb +54 -0
- data/test/regression/test_chart_axis46.rb +54 -0
- data/test/regression/test_chart_bar08.rb +3 -0
- data/test/regression/test_chart_bar11.rb +3 -0
- data/test/regression/test_chart_bar14.rb +3 -0
- data/test/regression/test_chart_chartarea05.rb +16 -17
- data/test/regression/test_chart_chartarea06.rb +49 -0
- data/test/regression/test_chart_combined10.rb +43 -0
- data/test/regression/test_chart_combined11.rb +63 -0
- data/test/regression/test_chart_data_labels25.rb +61 -0
- data/test/regression/test_chart_doughnut07.rb +37 -0
- data/test/regression/test_chart_font09.rb +1 -1
- data/test/regression/test_chart_format26.rb +48 -0
- data/test/regression/test_chart_format27.rb +58 -0
- data/test/regression/test_chart_format28.rb +52 -0
- data/test/regression/test_chart_format29.rb +59 -0
- data/test/regression/test_chart_format30.rb +53 -0
- data/test/regression/test_chart_format31.rb +60 -0
- data/test/regression/test_chart_legend03.rb +41 -0
- data/test/regression/test_chart_legend04.rb +41 -0
- data/test/regression/test_chart_legend05.rb +41 -0
- data/test/regression/test_chart_legend06.rb +41 -0
- data/test/regression/test_chart_legend07.rb +38 -0
- data/test/regression/test_chart_size03.rb +4 -1
- data/test/regression/test_chart_table03.rb +56 -0
- data/test/regression/test_comment13.rb +36 -0
- data/test/regression/test_comment14.rb +29 -0
- data/test/regression/test_cond_format14.rb +42 -0
- data/test/regression/test_cond_format15.rb +53 -0
- data/test/regression/test_cond_format16.rb +53 -0
- data/test/regression/test_cond_format17.rb +37 -0
- data/test/regression/test_cond_format18.rb +136 -0
- data/test/regression/test_cond_format19.rb +64 -0
- data/test/regression/test_cond_format20.rb +43 -0
- data/test/regression/test_date_1904_01.rb +1 -1
- data/test/regression/test_escapes04.rb +3 -0
- data/test/regression/test_escapes05.rb +3 -0
- data/test/regression/test_escapes07.rb +3 -0
- data/test/regression/test_escapes08.rb +3 -0
- data/test/regression/test_format15.rb +26 -0
- data/test/regression/test_hyperlink01.rb +3 -0
- data/test/regression/test_hyperlink02.rb +3 -0
- data/test/regression/test_hyperlink03.rb +4 -0
- data/test/regression/test_hyperlink04.rb +3 -0
- data/test/regression/test_hyperlink05.rb +3 -0
- data/test/regression/test_hyperlink06.rb +3 -0
- data/test/regression/test_hyperlink07.rb +3 -0
- data/test/regression/test_hyperlink08.rb +3 -0
- data/test/regression/test_hyperlink09.rb +3 -0
- data/test/regression/test_hyperlink10.rb +3 -0
- data/test/regression/test_hyperlink11.rb +3 -0
- data/test/regression/test_hyperlink12.rb +3 -0
- data/test/regression/test_hyperlink13.rb +3 -0
- data/test/regression/test_hyperlink14.rb +3 -0
- data/test/regression/test_hyperlink15.rb +3 -0
- data/test/regression/test_hyperlink16.rb +3 -0
- data/test/regression/test_hyperlink17.rb +3 -0
- data/test/regression/test_hyperlink18.rb +3 -0
- data/test/regression/test_hyperlink20.rb +3 -0
- data/test/regression/test_hyperlink21.rb +3 -0
- data/test/regression/test_hyperlink22.rb +3 -0
- data/test/regression/test_hyperlink23.rb +3 -0
- data/test/regression/test_hyperlink24.rb +3 -0
- data/test/regression/test_hyperlink25.rb +3 -0
- data/test/regression/test_hyperlink26.rb +3 -0
- data/test/regression/test_hyperlink27.rb +27 -0
- data/test/regression/test_hyperlink28.rb +50 -0
- data/test/regression/test_hyperlink29.rb +27 -0
- data/test/regression/test_hyperlink30.rb +36 -0
- data/test/regression/test_image08.rb +5 -4
- data/test/regression/test_image15.rb +4 -2
- data/test/regression/test_image28.rb +1 -1
- data/test/regression/test_image35.rb +26 -0
- data/test/regression/test_image36.rb +26 -0
- data/test/regression/test_image44.rb +28 -0
- data/test/regression/test_image45.rb +28 -0
- data/test/regression/test_image46.rb +29 -0
- data/test/regression/test_image47.rb +28 -0
- data/test/regression/test_object_position01.rb +26 -0
- data/test/regression/test_object_position02.rb +26 -0
- data/test/regression/test_object_position03.rb +26 -0
- data/test/regression/test_object_position04.rb +44 -0
- data/test/regression/test_object_position06.rb +28 -0
- data/test/regression/test_object_position07.rb +28 -0
- data/test/regression/test_object_position08.rb +47 -0
- data/test/regression/test_object_position09.rb +50 -0
- data/test/regression/test_object_position10.rb +28 -0
- data/test/regression/test_properties01.rb +1 -4
- data/test/regression/test_properties02.rb +1 -4
- data/test/regression/test_properties03.rb +26 -0
- data/test/regression/test_properties04.rb +61 -0
- data/test/regression/test_properties05.rb +30 -0
- data/test/regression/test_shape_connect01.rb +4 -2
- data/test/regression/test_table03.rb +3 -0
- data/test/regression/test_table04.rb +3 -0
- data/test/regression/test_table05.rb +3 -0
- data/test/regression/test_table06.rb +3 -0
- data/test/regression/test_table20.rb +34 -0
- data/test/regression/test_table21.rb +36 -0
- data/test/regression/test_table22.rb +32 -0
- data/test/regression/test_table23.rb +56 -0
- data/test/regression/test_utf8_11.rb +23 -0
- data/test/regression/xlsx_files/array_formula03.xlsx +0 -0
- data/test/regression/xlsx_files/autofilter08.xlsx +0 -0
- data/test/regression/xlsx_files/autofilter09.xlsx +0 -0
- data/test/regression/xlsx_files/autofilter10.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis26.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis27.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis28.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis29.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis33.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis42.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis43.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis44.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis45.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis46.xlsx +0 -0
- data/test/regression/xlsx_files/chart_chartarea05.xlsx +0 -0
- data/test/regression/xlsx_files/chart_chartarea06.xlsx +0 -0
- data/test/regression/xlsx_files/chart_combined10.xlsx +0 -0
- data/test/regression/xlsx_files/chart_combined11.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels25.xlsx +0 -0
- data/test/regression/xlsx_files/chart_doughnut07.xlsx +0 -0
- data/test/regression/xlsx_files/chart_font09.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format26.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format27.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format28.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format29.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format30.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format31.xlsx +0 -0
- data/test/regression/xlsx_files/chart_legend03.xlsx +0 -0
- data/test/regression/xlsx_files/chart_legend04.xlsx +0 -0
- data/test/regression/xlsx_files/chart_legend05.xlsx +0 -0
- data/test/regression/xlsx_files/chart_legend06.xlsx +0 -0
- data/test/regression/xlsx_files/chart_legend07.xlsx +0 -0
- data/test/regression/xlsx_files/chart_table03.xlsx +0 -0
- data/test/regression/xlsx_files/comment13.xlsx +0 -0
- data/test/regression/xlsx_files/comment14.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format14.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format15.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format16.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format17.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format18.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format19.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format20.xlsx +0 -0
- data/test/regression/xlsx_files/date_1904_01.xlsx +0 -0
- data/test/regression/xlsx_files/format15.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink27.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink28.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink29.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink30.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink31.xlsx +0 -0
- data/test/regression/xlsx_files/image35.xlsx +0 -0
- data/test/regression/xlsx_files/image36.xlsx +0 -0
- data/test/regression/xlsx_files/image44.xlsx +0 -0
- data/test/regression/xlsx_files/image45.xlsx +0 -0
- data/test/regression/xlsx_files/image46.xlsx +0 -0
- data/test/regression/xlsx_files/image47.xlsx +0 -0
- data/test/regression/xlsx_files/object_position01.xlsx +0 -0
- data/test/regression/xlsx_files/object_position02.xlsx +0 -0
- data/test/regression/xlsx_files/object_position03.xlsx +0 -0
- data/test/regression/xlsx_files/object_position04.xlsx +0 -0
- data/test/regression/xlsx_files/object_position06.xlsx +0 -0
- data/test/regression/xlsx_files/object_position07.xlsx +0 -0
- data/test/regression/xlsx_files/object_position08.xlsx +0 -0
- data/test/regression/xlsx_files/object_position09.xlsx +0 -0
- data/test/regression/xlsx_files/object_position10.xlsx +0 -0
- data/test/regression/xlsx_files/properties03.xlsx +0 -0
- data/test/regression/xlsx_files/properties04.xlsx +0 -0
- data/test/regression/xlsx_files/properties05.xlsx +0 -0
- data/test/regression/xlsx_files/table21.xlsx +0 -0
- data/test/regression/xlsx_files/table22.xlsx +0 -0
- data/test/regression/xlsx_files/table23.xlsx +0 -0
- data/test/regression/xlsx_files/utf8_11.xlsx +0 -0
- data/test/test_example_match.rb +836 -771
- data/test/workbook/test_check_sheetname.rb +61 -0
- data/test/workbook/test_worksheet_by_name.rb +35 -0
- data/test/workbook/test_write_workbook_view.rb +117 -0
- data/test/worksheet/test_cond_format_22.rb +266 -0
- data/test/worksheet/test_cond_format_23.rb +242 -0
- data/test/worksheet/test_cond_format_24.rb +303 -0
- data/test/worksheet/test_data_bar_01.rb +53 -0
- data/test/worksheet/test_data_bar_02.rb +79 -0
- data/test/worksheet/test_data_bar_03.rb +147 -0
- data/test/worksheet/test_data_bar_04.rb +145 -0
- data/test/worksheet/test_data_bar_05.rb +147 -0
- data/test/worksheet/test_data_bar_06.rb +145 -0
- data/test/worksheet/test_data_bar_07.rb +146 -0
- data/test/worksheet/test_data_bar_08.rb +54 -0
- data/test/worksheet/test_data_bar_09.rb +80 -0
- data/test/worksheet/test_data_bar_10.rb +165 -0
- data/test/worksheet/test_data_bar_11.rb +167 -0
- data/test/worksheet/test_data_bar_12.rb +104 -0
- data/test/worksheet/test_write_data_validation_02.rb +44 -0
- data/test/worksheet/test_write_hyperlink.rb +0 -7
- data/test/worksheet/test_write_sheet_view.rb +19 -1
- metadata +308 -5
- data/test/package/comments/test_write_text_t.rb +0 -44
@@ -0,0 +1,64 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
require 'helper'
|
3
|
+
|
4
|
+
class TestRegressionCondFormat19 < Minitest::Test
|
5
|
+
def setup
|
6
|
+
setup_dir_var
|
7
|
+
end
|
8
|
+
|
9
|
+
def teardown
|
10
|
+
@tempfile.close(true)
|
11
|
+
end
|
12
|
+
|
13
|
+
def test_cond_format19_with_double_quote
|
14
|
+
create_xlsx('"X"')
|
15
|
+
compare_for_regression(
|
16
|
+
nil,
|
17
|
+
{ 'xl/workbook.xml' => ['<workbookView'] }
|
18
|
+
)
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_cond_format19_without_double_quote
|
22
|
+
create_xlsx('X')
|
23
|
+
compare_for_regression(
|
24
|
+
nil,
|
25
|
+
{ 'xl/workbook.xml' => ['<workbookView'] }
|
26
|
+
)
|
27
|
+
end
|
28
|
+
|
29
|
+
private
|
30
|
+
|
31
|
+
def create_xlsx(value)
|
32
|
+
@xlsx = 'cond_format19.xlsx'
|
33
|
+
workbook = WriteXLSX.new(@io)
|
34
|
+
worksheet = workbook.add_worksheet
|
35
|
+
format = workbook.add_format(
|
36
|
+
:color => '#9C0006',
|
37
|
+
:bg_color => '#FFC7CE',
|
38
|
+
:font_condense => 1,
|
39
|
+
:font_extend => 1
|
40
|
+
)
|
41
|
+
|
42
|
+
worksheet.write('A1', 10)
|
43
|
+
worksheet.write('A2', 20)
|
44
|
+
worksheet.write('A3', 30)
|
45
|
+
worksheet.write('A4', 40)
|
46
|
+
|
47
|
+
worksheet.conditional_formatting(
|
48
|
+
'A1',
|
49
|
+
{
|
50
|
+
:type => 'cell',
|
51
|
+
:format => format,
|
52
|
+
:criteria => '==',
|
53
|
+
:value => value
|
54
|
+
}
|
55
|
+
)
|
56
|
+
|
57
|
+
workbook.close
|
58
|
+
compare_for_regression(
|
59
|
+
nil,
|
60
|
+
{ 'xl/workbook.xml' => ['<workbookView'] }
|
61
|
+
)
|
62
|
+
|
63
|
+
end
|
64
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
require 'helper'
|
3
|
+
|
4
|
+
class TestRegressionCondFormat20 < Minitest::Test
|
5
|
+
def setup
|
6
|
+
setup_dir_var
|
7
|
+
end
|
8
|
+
|
9
|
+
def teardown
|
10
|
+
@tempfile.close(true)
|
11
|
+
end
|
12
|
+
|
13
|
+
def test_cond_format20
|
14
|
+
@xlsx = 'cond_format20.xlsx'
|
15
|
+
workbook = WriteXLSX.new(@io)
|
16
|
+
worksheet = workbook.add_worksheet
|
17
|
+
|
18
|
+
worksheet.write('A1', 10)
|
19
|
+
worksheet.write('A2', 20)
|
20
|
+
worksheet.write('A3', 30)
|
21
|
+
worksheet.write('A4', 40)
|
22
|
+
|
23
|
+
worksheet.conditional_formatting(
|
24
|
+
'A1:A4',
|
25
|
+
{
|
26
|
+
:type => 'icon_set',
|
27
|
+
:icon_style => '3_arrows',
|
28
|
+
:icons => [
|
29
|
+
{ :criteria => '>', :type => 'percent', :value => 0 },
|
30
|
+
{ :criteria => '<', :type => 'percent', :value => 0 },
|
31
|
+
{ :criteria => '>=', :type => 'percent', :value => 0 }
|
32
|
+
]
|
33
|
+
}
|
34
|
+
)
|
35
|
+
|
36
|
+
workbook.close
|
37
|
+
compare_for_regression(
|
38
|
+
nil,
|
39
|
+
{ 'xl/workbook.xml' => ['<workbookView'] }
|
40
|
+
)
|
41
|
+
|
42
|
+
end
|
43
|
+
end
|
@@ -18,7 +18,7 @@ def test_date_1904_01
|
|
18
18
|
|
19
19
|
worksheet.set_column('A:A', 12)
|
20
20
|
|
21
|
-
worksheet.write_date_time('A1', '1900-01-
|
21
|
+
worksheet.write_date_time('A1', '1900-01-01T', format)
|
22
22
|
worksheet.write_date_time('A2', '1902-09-26T', format)
|
23
23
|
worksheet.write_date_time('A3', '1913-09-08T', format)
|
24
24
|
worksheet.write_date_time('A4', '1927-05-18T', format)
|
@@ -15,6 +15,9 @@ def test_escapes04
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'http://www.perl.com/?a=1&b=2')
|
19
22
|
|
20
23
|
workbook.close
|
@@ -16,6 +16,9 @@ def test_escapes05
|
|
16
16
|
worksheet1 = workbook.add_worksheet('Start')
|
17
17
|
worksheet2 = workbook.add_worksheet('A & B')
|
18
18
|
|
19
|
+
# Turn off default URL format for testing.
|
20
|
+
worksheet1.instance_variable_set(:@default_url_format, nil)
|
21
|
+
|
19
22
|
worksheet1.write_url('A1', "internal:'A & B'!A1", 'Jump to A & B')
|
20
23
|
|
21
24
|
workbook.close
|
@@ -15,6 +15,9 @@ def test_escapes07
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url(
|
19
22
|
'A1',
|
20
23
|
"http://example.com/!\"$%&'( )*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~"
|
@@ -15,6 +15,9 @@ def test_escapes08
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
# Test an already escaped string.
|
19
22
|
worksheet.write_url(
|
20
23
|
'A1',
|
@@ -0,0 +1,26 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
require 'helper'
|
3
|
+
|
4
|
+
class TestRegressionFormat15 < Minitest::Test
|
5
|
+
def setup
|
6
|
+
setup_dir_var
|
7
|
+
end
|
8
|
+
|
9
|
+
def teardown
|
10
|
+
@tempfile.close(true)
|
11
|
+
end
|
12
|
+
|
13
|
+
def test_format15
|
14
|
+
@xlsx = 'format15.xlsx'
|
15
|
+
workbook = WriteXLSX.new(@io)
|
16
|
+
worksheet = workbook.add_worksheet
|
17
|
+
format1 = workbook.add_format(:bold => 1)
|
18
|
+
format2 = workbook.add_format(:bold => 1, :num_format => 0)
|
19
|
+
|
20
|
+
worksheet.write('A1', 1, format1)
|
21
|
+
worksheet.write('A2', 2, format2)
|
22
|
+
|
23
|
+
workbook.close
|
24
|
+
compare_for_regression
|
25
|
+
end
|
26
|
+
end
|
@@ -15,6 +15,9 @@ def test_hyperlink01
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write('A1', 'http://www.perl.org/')
|
19
22
|
|
20
23
|
workbook.close
|
@@ -15,6 +15,9 @@ def test_hyperlink02
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write('A1', 'http://www.perl.org/')
|
19
22
|
worksheet.write('D4', 'http://www.perl.org/')
|
20
23
|
worksheet.write('A8', 'http://www.perl.org/')
|
@@ -16,6 +16,10 @@ def test_hyperlink03
|
|
16
16
|
worksheet1 = workbook.add_worksheet
|
17
17
|
worksheet2 = workbook.add_worksheet
|
18
18
|
|
19
|
+
# Turn off default URL format for testing.
|
20
|
+
worksheet1.instance_variable_set(:@default_url_format, nil)
|
21
|
+
worksheet2.instance_variable_set(:@default_url_format, nil)
|
22
|
+
|
19
23
|
worksheet1.write_url('A1', 'http://www.perl.org/')
|
20
24
|
worksheet1.write_url('D4', 'http://www.perl.org/')
|
21
25
|
worksheet1.write_url('A8', 'http://www.perl.org/')
|
@@ -17,6 +17,9 @@ def test_hyperlink04
|
|
17
17
|
worksheet2 = workbook.add_worksheet
|
18
18
|
worksheet3 = workbook.add_worksheet('Data Sheet')
|
19
19
|
|
20
|
+
# Turn off default URL format for testing.
|
21
|
+
worksheet1.instance_variable_set(:@default_url_format, nil)
|
22
|
+
|
20
23
|
worksheet1.write_url('A1', "internal:Sheet2!A1")
|
21
24
|
worksheet1.write_url('A3', "internal:Sheet2!A1:A5")
|
22
25
|
worksheet1.write_url('A5', "internal:'Data Sheet'!D5", 'Some text')
|
@@ -15,6 +15,9 @@ def test_hyperlink05
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'http://www.perl.org/')
|
19
22
|
worksheet.write_url('A3', 'http://www.perl.org/', 'Perl home')
|
20
23
|
worksheet.write_url('A5', 'http://www.perl.org/', 'Perl home', nil, 'Tool Tip')
|
@@ -15,6 +15,9 @@ def test_hyperlink06
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'external:C:\Temp\foo.xlsx')
|
19
22
|
worksheet.write_url('A3', 'external:C:\Temp\foo.xlsx#Sheet1!A1')
|
20
23
|
worksheet.write_url('A5', 'external:C:\Temp\foo.xlsx#Sheet1!A1', 'External', nil, 'Tip')
|
@@ -11,6 +11,9 @@ def test_hyperlink07
|
|
11
11
|
workbook = WriteXLSX.new(@io)
|
12
12
|
worksheet = workbook.add_worksheet
|
13
13
|
|
14
|
+
# Turn off default URL format for testing.
|
15
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
16
|
+
|
14
17
|
worksheet.write_url('A1', 'external:\\\\VBOXSVR\share\foo.xlsx', 'J:\foo.xlsx')
|
15
18
|
worksheet.write_url('A3', 'external:foo.xlsx')
|
16
19
|
|
@@ -15,6 +15,9 @@ def test_hyperlink08
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'external://VBOXSVR/share/foo.xlsx', 'J:/foo.xlsx')
|
19
22
|
worksheet.write_url('A3', 'external:foo.xlsx')
|
20
23
|
|
@@ -15,6 +15,9 @@ def test_hyperlink09
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'external:..\foo.xlsx')
|
19
22
|
worksheet.write_url('A3', 'external:..\foo.xlsx#Sheet1!A1')
|
20
23
|
worksheet.write_url('A5', 'external:\\\\VBOXSVR\share\foo.xlsx#Sheet1!B2', 'J:\foo.xlsx#Sheet1!B2')
|
@@ -16,6 +16,9 @@ def test_hyperlink10
|
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
format = workbook.add_format(:color => 'red', :underline => 1)
|
18
18
|
|
19
|
+
# Turn off default URL format for testing.
|
20
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
21
|
+
|
19
22
|
worksheet.write_url('A1', 'http://www.perl.org/', format)
|
20
23
|
|
21
24
|
workbook.close
|
@@ -16,6 +16,9 @@ def test_hyperlink11
|
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
format = workbook.add_format(:color => 'blue', :underline => 1)
|
18
18
|
|
19
|
+
# Turn off default URL format for testing.
|
20
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
21
|
+
|
19
22
|
worksheet.write_url('A1', 'http://www.perl.org/', format)
|
20
23
|
|
21
24
|
workbook.close
|
@@ -16,6 +16,9 @@ def test_hyperlink12
|
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
format = workbook.add_format(:color => 'blue', :underline => 1)
|
18
18
|
|
19
|
+
# Turn off default URL format for testing.
|
20
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
21
|
+
|
19
22
|
worksheet.write_url('A1', 'mailto:jmcnamara@cpan.org', format)
|
20
23
|
worksheet.write_url('A3', 'ftp://perl.org/', format)
|
21
24
|
|
@@ -16,6 +16,9 @@ def test_hyperlink13
|
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
format = workbook.add_format(:align => 'center')
|
18
18
|
|
19
|
+
# Turn off default URL format for testing.
|
20
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
21
|
+
|
19
22
|
worksheet.merge_range('C4:E5', 'http://www.perl.org/', format)
|
20
23
|
|
21
24
|
workbook.close
|
@@ -16,6 +16,9 @@ def test_hyperlink14
|
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
format = workbook.add_format(:align => 'center')
|
18
18
|
|
19
|
+
# Turn off default URL format for testing.
|
20
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
21
|
+
|
19
22
|
worksheet.merge_range('C4:E5', 'http://www.perl.org/', format, 'Perl Home')
|
20
23
|
|
21
24
|
workbook.close
|
@@ -15,6 +15,9 @@ def test_hyperlink15
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('B2', 'external:./subdir/blank.xlsx')
|
19
22
|
|
20
23
|
workbook.close
|
@@ -15,6 +15,9 @@ def test_hyperlink16
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('B2', 'external:./subdir/blank.xlsx')
|
19
22
|
|
20
23
|
workbook.close
|
@@ -15,6 +15,9 @@ def test_hyperlink17
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
# Test URL with whitespace.
|
19
22
|
worksheet.write_url('A1', 'http://google.com/some link')
|
20
23
|
|
@@ -15,6 +15,9 @@ def test_hyperlink18
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
# Test long URL at Excel limit.
|
19
22
|
worksheet.write_url('A1', 'http://google.com/00000000001111111111222222222233333333334444444444555555555566666666666777777777778888888888999999999990000000000111111111122222222223333333333444444444455555555556666666666677777777777888888888899999999999000000000011111111112222222222x')
|
20
23
|
|
@@ -19,6 +19,9 @@ def test_hyperlink20
|
|
19
19
|
format1 = workbook.add_format(:color => 'blue', :underline => 1)
|
20
20
|
format2 = workbook.add_format(:color => 'red', :underline => 1)
|
21
21
|
|
22
|
+
# Turn off default URL format for testing.
|
23
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
24
|
+
|
22
25
|
worksheet.write_url('A1', 'http://www.python.org/1', format1)
|
23
26
|
worksheet.write_url('A2', 'http://www.python.org/2', format2)
|
24
27
|
|
@@ -15,6 +15,9 @@ def test_hyperlink21
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'external:C:\Temp\Test 1')
|
19
22
|
|
20
23
|
workbook.close
|
@@ -15,6 +15,9 @@ def test_hyperlink22
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'external:\\\\Vboxsvr\share\foo bar.xlsx')
|
19
22
|
|
20
23
|
workbook.close
|
@@ -15,6 +15,9 @@ def test_hyperlink23
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'https://en.wikipedia.org/wiki/Microsoft_Excel#Data_storage_and_communication', 'Display text')
|
19
22
|
|
20
23
|
workbook.close
|
@@ -15,6 +15,9 @@ def test_hyperlink24
|
|
15
15
|
workbook = WriteXLSX.new(@io)
|
16
16
|
worksheet = workbook.add_worksheet
|
17
17
|
|
18
|
+
# Turn off default URL format for testing.
|
19
|
+
worksheet.instance_variable_set(:@default_url_format, nil)
|
20
|
+
|
18
21
|
worksheet.write_url('A1', 'http://www.example.com/some_long_url_that_is_255_characters_long_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_z#some_long_location_that_is_255_characters_long_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_abcdefgh_z')
|
19
22
|
|
20
23
|
workbook.close
|