donibuchanan-roo 1.3.12 → 1.9.1.4
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +26 -6
- data/lib/roo/excel.rb +83 -45
- data/lib/roo/excelx.rb +241 -69
- data/lib/roo/generic_spreadsheet.rb +34 -8
- data/lib/roo/google.rb +63 -117
- data/lib/roo/openoffice.rb +79 -27
- data/lib/roo/version.rb +9 -9
- data/lib/roo.rb +56 -13
- data/test/1900_base.xls +0 -0
- data/test/1904_base.xls +0 -0
- data/test/Bibelbund.csv +0 -0
- data/test/bode-v1.ods.zip +0 -0
- data/test/bode-v1.xls.zip +0 -0
- data/test/boolean.xls +0 -0
- data/test/datetime.xls +0 -0
- data/test/numbers1.csv +0 -0
- data/test/test_helper.rb +1 -1
- data/test/test_roo.rb +381 -269
- data/test/whitespace.xls +0 -0
- metadata +2 -1
data/test/test_roo.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
|
-
#
|
1
|
+
# encoding: utf-8
|
2
|
+
# damit keine falschen Vermutungen aufkommen: Ich habe religioes rein gar nichts
|
2
3
|
# mit diesem Bibelbund zu tun, aber die hatten eine ziemlich grosse
|
3
4
|
# Spreadsheet-Datei mit ca. 3500 Zeilen oeffentlich im Netz, die sich ganz gut
|
4
5
|
# zum Testen eignete.
|
@@ -8,15 +9,14 @@
|
|
8
9
|
# (like 'diff') must be changed (or commented out ;-)) if you want to run
|
9
10
|
# the tests under another OS
|
10
11
|
#
|
11
|
-
|
12
|
-
|
12
|
+
require './lib/roo'
|
13
13
|
#TODO
|
14
14
|
# Look at formulas in excel - does not work with date/time
|
15
15
|
|
16
16
|
|
17
17
|
# Dump warnings that come from the test to open files
|
18
18
|
# with the wrong spreadsheet class
|
19
|
-
STDERR.reopen "/dev/null","w"
|
19
|
+
#STDERR.reopen "/dev/null","w"
|
20
20
|
|
21
21
|
TESTDIR = File.dirname(__FILE__)
|
22
22
|
require TESTDIR + '/test_helper.rb'
|
@@ -25,8 +25,8 @@ require 'fileutils'
|
|
25
25
|
require 'timeout'
|
26
26
|
require 'logger'
|
27
27
|
$log = Logger.new(File.join(ENV['HOME'],"roo.log"))
|
28
|
-
|
29
|
-
|
28
|
+
#$log.level = Logger::WARN
|
29
|
+
$log.level = Logger::DEBUG
|
30
30
|
|
31
31
|
DISPLAY_LOG = false
|
32
32
|
DB_LOG = false
|
@@ -55,26 +55,34 @@ class Test::Unit::TestCase
|
|
55
55
|
begin
|
56
56
|
|
57
57
|
return {
|
58
|
-
'formula' => 'rt4Pw1WmjxFtyfrqqy94wPw',
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
'
|
58
|
+
#'formula' => 'rt4Pw1WmjxFtyfrqqy94wPw',
|
59
|
+
'formula' => 'o10837434939102457526.3022866619437760118',
|
60
|
+
#"write.me" => 'r6m7HFlUOwst0RTUTuhQ0Ow',
|
61
|
+
"write.me" => '0AkCuGANLc3jFcHR1NmJiYWhOWnBZME4wUnJ4UWJXZHc',
|
62
|
+
#'numbers1' => "rYraCzjxTtkxw1NxHJgDU8Q",
|
63
|
+
'numbers1' => 'o10837434939102457526.4784396906364855777',
|
64
|
+
#'borders' => "r_nLYMft6uWg_PT9Rc2urXw",
|
65
|
+
'borders' => "o10837434939102457526.664868920231926255",
|
66
|
+
#'simple_spreadsheet' => "r3aMMCBCA153TmU_wyIaxfw",
|
67
|
+
'simple_spreadsheet' => "ptu6bbahNZpYe-L1vEBmgGA",
|
63
68
|
'testnichtvorhandenBibelbund.ods' => "invalidkeyforanyspreadsheet", # !!! intentionally false key
|
64
|
-
"only_one_sheet" => "rqRtkcPJ97nhQ0m9ksDw2rA",
|
65
|
-
|
66
|
-
'
|
69
|
+
#"only_one_sheet" => "rqRtkcPJ97nhQ0m9ksDw2rA",
|
70
|
+
"only_one_sheet" => "o10837434939102457526.762705759906130135",
|
71
|
+
#'time-test' => 'r2XfDBJMrLPjmuLrPQQrEYw',
|
72
|
+
'time-test' => 'ptu6bbahNZpYBMhk01UfXSg',
|
73
|
+
#'datetime' => "r2kQpXWr6xOSUpw9MyXavYg",
|
74
|
+
'datetime' => "ptu6bbahNZpYQEtZwzL_dZQ",
|
67
75
|
'whitespace' => "rZyQaoFebVGeHKzjG6e9gRQ"
|
68
76
|
}[spreadsheetname]
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
77
|
+
# 'numbers1' => "o10837434939102457526.4784396906364855777",
|
78
|
+
# 'borders' => "o10837434939102457526.664868920231926255",
|
79
|
+
# 'simple_spreadsheet' => "ptu6bbahNZpYe-L1vEBmgGA",
|
80
|
+
# 'testnichtvorhandenBibelbund.ods' => "invalidkeyforanyspreadsheet", # !!! intentionally false key
|
81
|
+
# "only_one_sheet" => "o10837434939102457526.762705759906130135",
|
82
|
+
# "write.me" => 'ptu6bbahNZpY0N0RrxQbWdw&hl',
|
83
|
+
# 'formula' => 'o10837434939102457526.3022866619437760118',
|
84
|
+
# 'time-test' => 'ptu6bbahNZpYBMhk01UfXSg',
|
85
|
+
# 'datetime' => "ptu6bbahNZpYQEtZwzL_dZQ",
|
78
86
|
rescue
|
79
87
|
raise "unknown spreadsheetname: #{spreadsheetname}"
|
80
88
|
end
|
@@ -130,11 +138,10 @@ class TestRoo < Test::Unit::TestCase
|
|
130
138
|
|
131
139
|
OPENOFFICE = true # do Openoffice-Spreadsheet Tests?
|
132
140
|
EXCEL = true # do Excel Tests?
|
133
|
-
GOOGLE = false
|
141
|
+
GOOGLE = false # do Google-Spreadsheet Tests?
|
134
142
|
EXCELX = true # do Excel-X Tests? (.xlsx-files)
|
135
|
-
EXCEL2003XML = true # do MS2003 XML tests
|
136
143
|
|
137
|
-
ONLINE =
|
144
|
+
ONLINE = false
|
138
145
|
LONG_RUN = false
|
139
146
|
GLOBAL_TIMEOUT = 48.minutes #*60 # 2*12*60 # seconds
|
140
147
|
|
@@ -151,32 +158,13 @@ class TestRoo < Test::Unit::TestCase
|
|
151
158
|
# call a block of code for each spreadsheet type
|
152
159
|
# and yield a reference to the roo object
|
153
160
|
def with_each_spreadsheet(options)
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
options[:format] = (options[:format] - options[:ignore])
|
161
|
-
end
|
162
|
-
end
|
163
|
-
yield Roo::Spreadsheet.open(File.join(TESTDIR, options[:name] + '.xls')) if EXCEL && options[:format].include?(:excel)
|
164
|
-
yield Roo::Spreadsheet.open(File.join(TESTDIR, options[:name] + '.xlsx')) if EXCELX && options[:format].include?(:excelx)
|
165
|
-
yield Roo::Spreadsheet.open(File.join(TESTDIR, options[:name] + '.ods')) if OPENOFFICE && options[:format].include?(:openoffice)
|
166
|
-
yield Roo::Spreadsheet.open(File.join(TESTDIR, options[:name] + '.xml')) if EXCEL2003XML && options[:format].include?(:excel2003xml)
|
167
|
-
yield Roo::Spreadsheet.open(key_of(options[:name]) || options[:name]) if GOOGLE && options[:format].include?(:google)
|
168
|
-
end
|
169
|
-
|
170
|
-
def with_public_google_spreadsheet(&block)
|
171
|
-
user = ENV['GOOGLE_MAIL']
|
172
|
-
pass = ENV['GOOGLE_PASSWORD']
|
173
|
-
ENV['GOOGLE_MAIL'] = ''
|
174
|
-
ENV['GOOGLE_PASSWORD'] = ''
|
175
|
-
block.call
|
176
|
-
ENV['GOOGLE_MAIL'] = user
|
177
|
-
ENV['GOOGLE_PASSWORD'] = pass
|
161
|
+
options[:format] ||= [:excel, :excelx, :openoffice, :google]
|
162
|
+
options[:format] = [options[:format]] if options[:format].class == Symbol
|
163
|
+
yield Roo::Spreadsheet.open(File.join(TESTDIR, options[:name] + '.xls')) if EXCEL && options[:format].include?(:excel)
|
164
|
+
yield Roo::Spreadsheet.open(File.join(TESTDIR, options[:name] + '.xlsx')) if EXCELX && options[:format].include?(:excelx)
|
165
|
+
yield Roo::Spreadsheet.open(File.join(TESTDIR, options[:name] + '.ods')) if OPENOFFICE && options[:format].include?(:openoffice)
|
166
|
+
yield Roo::Spreadsheet.open(key_of(options[:name]) || options[:name]) if GOOGLE && options[:format].include?(:google)
|
178
167
|
end
|
179
|
-
|
180
168
|
# Using Date.strptime so check that it's using the method
|
181
169
|
# with the value set in date_format
|
182
170
|
def test_date
|
@@ -232,11 +220,14 @@ class TestRoo < Test::Unit::TestCase
|
|
232
220
|
oo.default_sheet = sh
|
233
221
|
assert_equal sh, oo.default_sheet
|
234
222
|
}
|
235
|
-
end
|
223
|
+
end
|
236
224
|
end
|
237
|
-
|
225
|
+
|
238
226
|
def test_cells
|
239
|
-
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
227
|
+
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
228
|
+
# warum ist Auswaehlen erstes sheet hier nicht
|
229
|
+
# mehr drin?
|
230
|
+
oo.default_sheet = oo.sheets.first
|
240
231
|
assert_equal 1, oo.cell(1,1)
|
241
232
|
assert_equal 2, oo.cell(1,2)
|
242
233
|
assert_equal 3, oo.cell(1,3)
|
@@ -261,15 +252,15 @@ class TestRoo < Test::Unit::TestCase
|
|
261
252
|
assert_equal 13, oo.cell(4,'D')
|
262
253
|
assert_equal 14, oo.cell(4,'E')
|
263
254
|
assert_equal :date, oo.celltype(5,1)
|
264
|
-
assert_equal "1961-11-21", oo.cell(5,1).to_s
|
265
255
|
assert_equal Date.new(1961,11,21), oo.cell(5,1)
|
256
|
+
assert_equal "1961-11-21", oo.cell(5,1).to_s
|
266
257
|
end
|
267
258
|
end
|
268
259
|
|
269
260
|
def test_celltype
|
270
|
-
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
261
|
+
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
271
262
|
assert_equal :string, oo.celltype(2,6)
|
272
|
-
end
|
263
|
+
end
|
273
264
|
end
|
274
265
|
|
275
266
|
def test_cell_address
|
@@ -294,12 +285,13 @@ class TestRoo < Test::Unit::TestCase
|
|
294
285
|
def test_office_version
|
295
286
|
with_each_spreadsheet(:name=>'numbers1', :format=>:openoffice) do |oo|
|
296
287
|
assert_equal "1.0", oo.officeversion
|
297
|
-
end
|
288
|
+
end
|
298
289
|
end
|
299
290
|
|
300
291
|
#TODO: inkonsequente Lieferung Fixnum/Float
|
301
292
|
def test_rows
|
302
293
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
294
|
+
oo.default_sheet = oo.sheets.first
|
303
295
|
assert_equal 41, oo.cell('a',12)
|
304
296
|
assert_equal 42, oo.cell('b',12)
|
305
297
|
assert_equal 43, oo.cell('c',12)
|
@@ -317,36 +309,42 @@ class TestRoo < Test::Unit::TestCase
|
|
317
309
|
|
318
310
|
def test_last_row
|
319
311
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
312
|
+
oo.default_sheet = oo.sheets.first
|
320
313
|
assert_equal 18, oo.last_row
|
321
314
|
end
|
322
315
|
end
|
323
316
|
|
324
317
|
def test_last_column
|
325
318
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
319
|
+
oo.default_sheet = oo.sheets.first
|
326
320
|
assert_equal 7, oo.last_column
|
327
321
|
end
|
328
322
|
end
|
329
323
|
|
330
324
|
def test_last_column_as_letter
|
331
325
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
326
|
+
oo.default_sheet = oo.sheets.first
|
332
327
|
assert_equal 'G', oo.last_column_as_letter
|
333
328
|
end
|
334
329
|
end
|
335
330
|
|
336
331
|
def test_first_row
|
337
332
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
333
|
+
oo.default_sheet = oo.sheets.first
|
338
334
|
assert_equal 1, oo.first_row
|
339
335
|
end
|
340
336
|
end
|
341
337
|
|
342
338
|
def test_first_column
|
343
339
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
340
|
+
oo.default_sheet = oo.sheets.first
|
344
341
|
assert_equal 1, oo.first_column
|
345
342
|
end
|
346
343
|
end
|
347
344
|
|
348
345
|
def test_first_column_as_letter
|
349
346
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
347
|
+
oo.default_sheet = oo.sheets.first
|
350
348
|
assert_equal 'A', oo.first_column_as_letter
|
351
349
|
end
|
352
350
|
end
|
@@ -363,15 +361,19 @@ class TestRoo < Test::Unit::TestCase
|
|
363
361
|
if oo.class == Excel
|
364
362
|
assert_raise(RuntimeError) { dummy = oo.formula?('C',5,"non existing sheet name")}
|
365
363
|
assert_raise(RuntimeError) { dummy = oo.formula('C',5,"non existing sheet name")}
|
366
|
-
else
|
364
|
+
else
|
367
365
|
assert_raise(RangeError) { dummy = oo.formula?('C',5,"non existing sheet name")}
|
368
366
|
assert_raise(RangeError) { dummy = oo.formula('C',5,"non existing sheet name")}
|
369
|
-
|
370
|
-
|
367
|
+
begin
|
368
|
+
assert_raise(RangeError) { dummy = oo.set('C',5,42,"non existing sheet name")} unless oo.class == Google
|
369
|
+
rescue NameError
|
370
|
+
#
|
371
|
+
end
|
372
|
+
assert_raise(RangeError) { dummy = oo.formulas("non existing sheet name")}
|
371
373
|
end
|
372
374
|
assert_raise(RangeError) { dummy = oo.to_yaml({},1,1,1,1,"non existing sheet name")}
|
373
375
|
end
|
374
|
-
end
|
376
|
+
end
|
375
377
|
|
376
378
|
def test_boundaries
|
377
379
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
@@ -404,13 +406,14 @@ class TestRoo < Test::Unit::TestCase
|
|
404
406
|
def test_empty_eh
|
405
407
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
406
408
|
assert oo.empty?('a',14)
|
407
|
-
assert !oo.empty?('a',15)
|
409
|
+
assert ! oo.empty?('a',15)
|
408
410
|
assert oo.empty?('a',20)
|
409
411
|
end
|
410
412
|
end
|
411
413
|
|
412
414
|
def test_reload
|
413
415
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
416
|
+
oo.default_sheet = oo.sheets.first
|
414
417
|
assert_equal 1, oo.cell(1,1)
|
415
418
|
oo.reload
|
416
419
|
assert_equal 1, oo.cell(1,1)
|
@@ -521,6 +524,7 @@ class TestRoo < Test::Unit::TestCase
|
|
521
524
|
|
522
525
|
def test_formula_google
|
523
526
|
with_each_spreadsheet(:name=>'formula', :format=>:google) do |oo|
|
527
|
+
oo.default_sheet = oo.sheets.first
|
524
528
|
assert_equal 1, oo.cell('A',1)
|
525
529
|
assert_equal 2, oo.cell('A',2)
|
526
530
|
assert_equal 3, oo.cell('A',3)
|
@@ -628,6 +632,7 @@ class TestRoo < Test::Unit::TestCase
|
|
628
632
|
|
629
633
|
def test_to_yaml
|
630
634
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
635
|
+
oo.default_sheet = oo.sheets.first
|
631
636
|
assert_equal "--- \n"+yaml_entry(5,1,"date","1961-11-21"), oo.to_yaml({}, 5,1,5,1)
|
632
637
|
assert_equal "--- \n"+yaml_entry(8,3,"string","thisisc8"), oo.to_yaml({}, 8,3,8,3)
|
633
638
|
assert_equal "--- \n"+yaml_entry(12,3,"float",43.0), oo.to_yaml({}, 12,3,12,3)
|
@@ -668,9 +673,9 @@ class TestRoo < Test::Unit::TestCase
|
|
668
673
|
excel = Excel.new(url, :zip)
|
669
674
|
excel.default_sheet = excel.sheets.first
|
670
675
|
assert_equal 'ist "e" im Nenner von H(s)', excel.cell('b', 5)
|
671
|
-
ensure
|
676
|
+
ensure
|
672
677
|
excel.remove_tmp
|
673
|
-
end
|
678
|
+
end
|
674
679
|
end
|
675
680
|
end
|
676
681
|
end
|
@@ -685,7 +690,7 @@ class TestRoo < Test::Unit::TestCase
|
|
685
690
|
assert_in_delta 0.001, 505.14, sheet.cell('c', 33).to_f
|
686
691
|
ensure
|
687
692
|
sheet.remove_tmp
|
688
|
-
end
|
693
|
+
end
|
689
694
|
end
|
690
695
|
end
|
691
696
|
end
|
@@ -697,8 +702,8 @@ class TestRoo < Test::Unit::TestCase
|
|
697
702
|
assert oo
|
698
703
|
assert_equal 'ist "e" im Nenner von H(s)', oo.cell('b', 5)
|
699
704
|
ensure
|
700
|
-
oo.remove_tmp
|
701
|
-
end
|
705
|
+
oo.remove_tmp if oo
|
706
|
+
end
|
702
707
|
end
|
703
708
|
end
|
704
709
|
|
@@ -708,9 +713,9 @@ class TestRoo < Test::Unit::TestCase
|
|
708
713
|
oo = Openoffice.new(File.join(TESTDIR,"bode-v1.ods.zip"), :zip)
|
709
714
|
assert oo
|
710
715
|
assert_equal 'ist "e" im Nenner von H(s)', oo.cell('b', 5)
|
711
|
-
ensure
|
716
|
+
ensure
|
712
717
|
oo.remove_tmp
|
713
|
-
end
|
718
|
+
end
|
714
719
|
end
|
715
720
|
end
|
716
721
|
|
@@ -770,27 +775,46 @@ class TestRoo < Test::Unit::TestCase
|
|
770
775
|
# assert_equal "Tagebuch des Sekret\303\244rs. Letzte Tagung 15./16.11.75 Schweiz", oo.cell(45,'A')
|
771
776
|
#end
|
772
777
|
end
|
773
|
-
|
778
|
+
|
774
779
|
def test_huge_document_to_csv
|
775
|
-
|
776
|
-
|
777
|
-
|
778
|
-
|
779
|
-
|
780
|
-
|
781
|
-
|
782
|
-
|
783
|
-
|
784
|
-
|
785
|
-
|
786
|
-
|
787
|
-
|
780
|
+
after Date.new(2009,10,1) do
|
781
|
+
if LONG_RUN
|
782
|
+
with_each_spreadsheet(:name=>'Bibelbund', :format=>[:openoffice,
|
783
|
+
:excel,
|
784
|
+
:excelx
|
785
|
+
]) do |oo|
|
786
|
+
assert_nothing_raised(Timeout::Error) {
|
787
|
+
Timeout::timeout(GLOBAL_TIMEOUT) do |timeout_length|
|
788
|
+
File.delete_if_exist("/tmp/Bibelbund.csv")
|
789
|
+
assert_equal "Tagebuch des Sekret\303\244rs. Letzte Tagung 15./16.11.75 Schweiz", oo.cell(45,'A')
|
790
|
+
assert_equal "Tagebuch des Sekret\303\244rs. Nachrichten aus Chile", oo.cell(46,'A')
|
791
|
+
assert_equal "Tagebuch aus Chile Juli 1977", oo.cell(55,'A')
|
792
|
+
assert oo.to_csv("/tmp/Bibelbund.csv")
|
793
|
+
assert File.exists?("/tmp/Bibelbund.csv")
|
794
|
+
assert_equal "", `diff test/Bibelbund.csv /tmp/Bibelbund.csv`, "error in class #{oo.class}"
|
795
|
+
end
|
796
|
+
}
|
797
|
+
end
|
788
798
|
end
|
789
799
|
end
|
790
800
|
end
|
791
801
|
|
802
|
+
def test_bug_quotes_excelx
|
803
|
+
with_each_spreadsheet(:name=>'Bibelbund', :format=>[:openoffice,
|
804
|
+
:excel,
|
805
|
+
:excelx]) do |oo|
|
806
|
+
oo.default_sheet = oo.sheets.first
|
807
|
+
assert_equal 'Einflüsse der neuen Theologie in "de gereformeerde Kerken van Nederland"',
|
808
|
+
oo.cell('a',76)
|
809
|
+
dummy = oo.to_csv("csv#{$$}")
|
810
|
+
assert_equal 'Einflüsse der neuen Theologie in "de gereformeerde Kerken van Nederland"',
|
811
|
+
oo.cell('a',78)
|
812
|
+
delete_if_exist("csv#{$$}")
|
813
|
+
end
|
814
|
+
end
|
815
|
+
|
792
816
|
def test_to_csv
|
793
|
-
with_each_spreadsheet(:name=>'numbers1'
|
817
|
+
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
794
818
|
master = "#{TESTDIR}/numbers1.csv"
|
795
819
|
File.delete_if_exist("/tmp/numbers1.csv")
|
796
820
|
assert oo.to_csv("/tmp/numbers1.csv",oo.sheets.first)
|
@@ -799,7 +823,7 @@ class TestRoo < Test::Unit::TestCase
|
|
799
823
|
assert oo.to_csv("/tmp/numbers1.csv")
|
800
824
|
assert File.exists?("/tmp/numbers1.csv")
|
801
825
|
assert_equal "", `diff #{master} /tmp/numbers1.csv`
|
802
|
-
end
|
826
|
+
end
|
803
827
|
end
|
804
828
|
|
805
829
|
def test_bug_mehrere_datum
|
@@ -835,7 +859,7 @@ class TestRoo < Test::Unit::TestCase
|
|
835
859
|
assert_equal "ABC", oo.cell('C',6)
|
836
860
|
assert_equal "ABC", oo.cell('D',6)
|
837
861
|
assert_equal "ABC", oo.cell('E',6)
|
838
|
-
end
|
862
|
+
end
|
839
863
|
end
|
840
864
|
|
841
865
|
def test_multiple_sheets
|
@@ -892,7 +916,9 @@ class TestRoo < Test::Unit::TestCase
|
|
892
916
|
|
893
917
|
def test_find_by_row_huge_document
|
894
918
|
if LONG_RUN
|
895
|
-
with_each_spreadsheet(:name=>'Bibelbund'
|
919
|
+
with_each_spreadsheet(:name=>'Bibelbund', :format=>[:openoffice,
|
920
|
+
:excel,
|
921
|
+
:excelx]) do |oo|
|
896
922
|
Timeout::timeout(GLOBAL_TIMEOUT) do |timeout_length|
|
897
923
|
oo.default_sheet = oo.sheets.first
|
898
924
|
rec = oo.find 20
|
@@ -926,7 +952,9 @@ class TestRoo < Test::Unit::TestCase
|
|
926
952
|
|
927
953
|
def test_find_by_conditions
|
928
954
|
if LONG_RUN
|
929
|
-
with_each_spreadsheet(:name=>'Bibelbund'
|
955
|
+
with_each_spreadsheet(:name=>'Bibelbund', :format=>[:openoffice,
|
956
|
+
:excel,
|
957
|
+
:excelx]) do |oo|
|
930
958
|
assert_nothing_raised(Timeout::Error) {
|
931
959
|
Timeout::timeout(GLOBAL_TIMEOUT) do |timeout_length|
|
932
960
|
#-----------------------------------------------------------------
|
@@ -1021,6 +1049,7 @@ class TestRoo < Test::Unit::TestCase
|
|
1021
1049
|
with_each_spreadsheet(:name=>'Bibelbund', :format=>:excelx) do |oo|
|
1022
1050
|
assert_equal 'Bericht aus dem Sekretariat', oo.cell(13,1)
|
1023
1051
|
assert_equal '1981-4', oo.cell(13,'D')
|
1052
|
+
assert_equal String, oo.excelx_type(13,'E')[1].class
|
1024
1053
|
assert_equal [:numeric_or_formula,"General"], oo.excelx_type(13,'E')
|
1025
1054
|
assert_equal '428', oo.excelx_value(13,'E')
|
1026
1055
|
assert_equal 428.0, oo.cell(13,'E')
|
@@ -1037,7 +1066,9 @@ class TestRoo < Test::Unit::TestCase
|
|
1037
1066
|
|
1038
1067
|
def test_column_huge_document
|
1039
1068
|
if LONG_RUN
|
1040
|
-
with_each_spreadsheet(:name=>'Bibelbund'
|
1069
|
+
with_each_spreadsheet(:name=>'Bibelbund', :format=>[:openoffice,
|
1070
|
+
:excel,
|
1071
|
+
:excelx]) do |oo|
|
1041
1072
|
assert_nothing_raised(Timeout::Error) {
|
1042
1073
|
Timeout::timeout(GLOBAL_TIMEOUT) do |timeout_length|
|
1043
1074
|
oo.default_sheet = oo.sheets.first
|
@@ -1052,7 +1083,7 @@ class TestRoo < Test::Unit::TestCase
|
|
1052
1083
|
def test_simple_spreadsheet_find_by_condition
|
1053
1084
|
with_each_spreadsheet(:name=>'simple_spreadsheet') do |oo|
|
1054
1085
|
oo.header_line = 3
|
1055
|
-
oo.date_format = '%m/%d/%Y' if oo.class == Google
|
1086
|
+
# oo.date_format = '%m/%d/%Y' if oo.class == Google
|
1056
1087
|
erg = oo.find(:all, :conditions => {'Comment' => 'Task 1'})
|
1057
1088
|
assert_equal Date.new(2007,05,07), erg[1]['Date']
|
1058
1089
|
assert_equal 10.75 , erg[1]['Start time']
|
@@ -1063,7 +1094,7 @@ class TestRoo < Test::Unit::TestCase
|
|
1063
1094
|
end
|
1064
1095
|
end
|
1065
1096
|
|
1066
|
-
# Ruby-spreadsheet now allows us to at least give the current value
|
1097
|
+
# Ruby-spreadsheet now allows us to at least give the current value
|
1067
1098
|
# from a cell with a formula (no possible with parseexcel)
|
1068
1099
|
def test_bug_false_borders_with_formulas
|
1069
1100
|
with_each_spreadsheet(:name=>'false_encoding', :format=>:excel) do |oo|
|
@@ -1086,7 +1117,7 @@ class TestRoo < Test::Unit::TestCase
|
|
1086
1117
|
#DOES NOT WORK IN EXCEL FILES: assert_equal true, oo.formula?('B',1)
|
1087
1118
|
#DOES NOT WORK IN EXCEL FILES: assert_equal "=A1+100", oo.formula('B',1)
|
1088
1119
|
|
1089
|
-
assert_kind_of DateTime, oo.cell('C',1)
|
1120
|
+
assert_kind_of DateTime, oo.cell('C',1)
|
1090
1121
|
#DOES NOT WORK IN EXCEL FILES: assert_equal true, oo.formula?('C',1)
|
1091
1122
|
#DOES NOT WORK IN EXCEL FILES: assert_equal "=C1", oo.formula('C',1)
|
1092
1123
|
|
@@ -1098,7 +1129,7 @@ class TestRoo < Test::Unit::TestCase
|
|
1098
1129
|
assert_equal 'R2', oo.cell('B',3)
|
1099
1130
|
assert_equal 'R3', oo.cell('C',3)
|
1100
1131
|
assert_equal 'R4', oo.cell('D',3)
|
1101
|
-
end
|
1132
|
+
end
|
1102
1133
|
end
|
1103
1134
|
|
1104
1135
|
def test_excel_does_not_support_formulas
|
@@ -1106,7 +1137,7 @@ class TestRoo < Test::Unit::TestCase
|
|
1106
1137
|
assert_raise(RuntimeError) { void = oo.formula('a',1) }
|
1107
1138
|
assert_raise(RuntimeError) { void = oo.formula?('a',1) }
|
1108
1139
|
assert_raise(RuntimeError) { void = oo.formulas(oo.sheets.first) }
|
1109
|
-
end
|
1140
|
+
end
|
1110
1141
|
end
|
1111
1142
|
|
1112
1143
|
def get_extension(oo)
|
@@ -1117,9 +1148,7 @@ class TestRoo < Test::Unit::TestCase
|
|
1117
1148
|
".xls"
|
1118
1149
|
when Excelx
|
1119
1150
|
".xlsx"
|
1120
|
-
when
|
1121
|
-
".xml"
|
1122
|
-
when Google
|
1151
|
+
when Google
|
1123
1152
|
""
|
1124
1153
|
end
|
1125
1154
|
end
|
@@ -1156,10 +1185,14 @@ class TestRoo < Test::Unit::TestCase
|
|
1156
1185
|
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
1157
1186
|
ext = get_extension(oo)
|
1158
1187
|
expected = sprintf(expected_templ,ext)
|
1159
|
-
|
1160
|
-
|
1161
|
-
|
1162
|
-
|
1188
|
+
begin
|
1189
|
+
if oo.class == Google
|
1190
|
+
assert_equal expected.gsub(/numbers1/,key_of("numbers1")), oo.info
|
1191
|
+
else
|
1192
|
+
assert_equal expected, oo.info
|
1193
|
+
end
|
1194
|
+
rescue NameError
|
1195
|
+
#
|
1163
1196
|
end
|
1164
1197
|
end
|
1165
1198
|
end
|
@@ -1211,17 +1244,17 @@ class TestRoo < Test::Unit::TestCase
|
|
1211
1244
|
}
|
1212
1245
|
end
|
1213
1246
|
if GOOGLE
|
1214
|
-
|
1215
|
-
|
1216
|
-
# oo = Google.new('testnichtvorhanden')
|
1217
|
-
# }
|
1247
|
+
# assert_raise(Net::HTTPServerException) {
|
1248
|
+
# oo = Google.new(key_of('testnichtvorhanden'+'Bibelbund.ods'))
|
1249
|
+
# oo = Google.new('testnichtvorhanden')
|
1250
|
+
# }
|
1218
1251
|
end
|
1219
1252
|
end
|
1220
1253
|
|
1221
1254
|
def test_write_google
|
1222
1255
|
# write.me: http://spreadsheets.google.com/ccc?key=ptu6bbahNZpY0N0RrxQbWdw&hl=en_GB
|
1223
|
-
|
1224
1256
|
with_each_spreadsheet(:name=>'write.me', :format=>:google) do |oo|
|
1257
|
+
oo.default_sheet = oo.sheets.first
|
1225
1258
|
oo.set_value(1,1,"hello from the tests")
|
1226
1259
|
assert_equal "hello from the tests", oo.cell(1,1)
|
1227
1260
|
oo.set_value(1,1, 1.0)
|
@@ -1261,13 +1294,13 @@ class TestRoo < Test::Unit::TestCase
|
|
1261
1294
|
def test_set_value_for_non_existing_sheet_google
|
1262
1295
|
with_each_spreadsheet(:name=>'ptu6bbahNZpY0N0RrxQbWdw', :format=>:google) do |oo|
|
1263
1296
|
assert_raise(RangeError) { oo.set_value(1,1,"dummy","no_sheet") }
|
1264
|
-
end
|
1297
|
+
end
|
1265
1298
|
end
|
1266
1299
|
|
1267
1300
|
def test_bug_bbu
|
1268
1301
|
with_each_spreadsheet(:name=>'bbu', :format=>[:openoffice, :excelx, :excel]) do |oo|
|
1269
1302
|
assert_nothing_raised() {
|
1270
|
-
|
1303
|
+
assert_equal "File: bbu#{get_extension(oo)}
|
1271
1304
|
Number of sheets: 3
|
1272
1305
|
Sheets: 2007_12, Tabelle2, Tabelle3
|
1273
1306
|
Sheet 1:
|
@@ -1279,19 +1312,19 @@ Sheet 2:
|
|
1279
1312
|
- empty -
|
1280
1313
|
Sheet 3:
|
1281
1314
|
- empty -", oo.info
|
1282
|
-
|
1315
|
+
}
|
1283
1316
|
|
1284
1317
|
oo.default_sheet = oo.sheets[1] # empty sheet
|
1285
1318
|
assert_nil oo.first_row
|
1286
1319
|
assert_nil oo.last_row
|
1287
1320
|
assert_nil oo.first_column
|
1288
1321
|
assert_nil oo.last_column
|
1289
|
-
end
|
1322
|
+
end
|
1290
1323
|
end
|
1291
1324
|
|
1292
1325
|
|
1293
1326
|
def test_bug_time_nil
|
1294
|
-
with_each_spreadsheet(:name=>'time-test'
|
1327
|
+
with_each_spreadsheet(:name=>'time-test') do |oo|
|
1295
1328
|
assert_equal 12*3600+13*60+14, oo.cell('B',1) # 12:13:14 (secs since midnight)
|
1296
1329
|
assert_equal :time, oo.celltype('B',1)
|
1297
1330
|
assert_equal 15*3600+16*60, oo.cell('C',1) # 15:16 (secs since midnight)
|
@@ -1302,15 +1335,15 @@ Sheet 3:
|
|
1302
1335
|
end
|
1303
1336
|
|
1304
1337
|
def test_date_time_to_csv
|
1305
|
-
with_each_spreadsheet(:name=>'time-test'
|
1338
|
+
with_each_spreadsheet(:name=>'time-test') do |oo|
|
1306
1339
|
begin
|
1307
1340
|
assert oo.to_csv("/tmp/time-test.csv")
|
1308
1341
|
assert File.exists?("/tmp/time-test.csv")
|
1309
1342
|
assert_equal "", `diff #{TESTDIR}/time-test.csv /tmp/time-test.csv`
|
1310
1343
|
ensure
|
1311
1344
|
File.delete_if_exist("/tmp/time-test.csv")
|
1312
|
-
end
|
1313
|
-
end
|
1345
|
+
end
|
1346
|
+
end
|
1314
1347
|
end
|
1315
1348
|
|
1316
1349
|
def test_date_time_yaml
|
@@ -1366,12 +1399,15 @@ Sheet 3:
|
|
1366
1399
|
end
|
1367
1400
|
|
1368
1401
|
def test_no_remaining_tmp_files_google
|
1369
|
-
|
1370
|
-
|
1371
|
-
|
1372
|
-
|
1373
|
-
|
1374
|
-
|
1402
|
+
after Date.new(2009,11,1) do
|
1403
|
+
# Exception ist irgendwie anders, nochmal ansehen TODO:
|
1404
|
+
if GOOGLE
|
1405
|
+
assert_nothing_raised() {
|
1406
|
+
oo = Google.new(key_of("no_spreadsheet_file.txt"))
|
1407
|
+
}
|
1408
|
+
a=Dir.glob("oo_*")
|
1409
|
+
assert_equal [], a
|
1410
|
+
end
|
1375
1411
|
end
|
1376
1412
|
end
|
1377
1413
|
|
@@ -1395,32 +1431,36 @@ Sheet 3:
|
|
1395
1431
|
end
|
1396
1432
|
|
1397
1433
|
def test_to_xml
|
1398
|
-
|
1399
|
-
|
1400
|
-
|
1401
|
-
|
1402
|
-
|
1403
|
-
|
1404
|
-
|
1405
|
-
|
1406
|
-
|
1407
|
-
|
1408
|
-
|
1409
|
-
|
1410
|
-
all_cells[x][:
|
1411
|
-
|
1412
|
-
|
1413
|
-
|
1414
|
-
|
1415
|
-
|
1416
|
-
|
1417
|
-
|
1418
|
-
|
1419
|
-
|
1420
|
-
|
1421
|
-
|
1422
|
-
|
1423
|
-
|
1434
|
+
after Date.new(2009,10,1) do
|
1435
|
+
with_each_spreadsheet(:name=>'numbers1', :encoding => 'utf8') do |oo|
|
1436
|
+
assert_nothing_raised {oo.to_xml}
|
1437
|
+
sheetname = oo.sheets.first
|
1438
|
+
# doc = XML::Parser.string(oo.to_xml).parse
|
1439
|
+
doc = Nokogiri::XML(oo.to_xml)
|
1440
|
+
# doc.root.each_element {|xml_sheet|
|
1441
|
+
doc.root.each {|xml_sheet|
|
1442
|
+
all_cells = init_all_cells(oo, sheetname)
|
1443
|
+
x = 0
|
1444
|
+
assert_equal sheetname, xml_sheet.attributes['name']
|
1445
|
+
xml_sheet.each_element {|cell|
|
1446
|
+
expected = [all_cells[x][:row],
|
1447
|
+
all_cells[x][:column],
|
1448
|
+
all_cells[x][:content],
|
1449
|
+
all_cells[x][:type],
|
1450
|
+
]
|
1451
|
+
result = [
|
1452
|
+
cell.attributes['row'],
|
1453
|
+
cell.attributes['column'],
|
1454
|
+
cell.content,
|
1455
|
+
cell.attributes['type'],
|
1456
|
+
]
|
1457
|
+
assert_equal expected, result
|
1458
|
+
x += 1
|
1459
|
+
} # end of sheet
|
1460
|
+
sheetname = oo.sheets[oo.sheets.index(sheetname)+1]
|
1461
|
+
}
|
1462
|
+
end
|
1463
|
+
end
|
1424
1464
|
end
|
1425
1465
|
|
1426
1466
|
def test_bug_row_column_fixnum_float
|
@@ -1543,13 +1583,13 @@ Sheet 3:
|
|
1543
1583
|
end
|
1544
1584
|
|
1545
1585
|
def test_bug_last_row_excel
|
1546
|
-
with_each_spreadsheet(:name=>'time-test', :format=>:excel) do |oo|
|
1586
|
+
with_each_spreadsheet(:name=>'time-test', :format=>:excel) do |oo|
|
1547
1587
|
assert_equal 2, oo.last_row
|
1548
1588
|
end
|
1549
1589
|
end
|
1550
1590
|
|
1551
1591
|
def test_bug_to_xml_with_empty_sheets
|
1552
|
-
with_each_spreadsheet(:name=>'emptysheets', :format=>[:openoffice, :excel]) do |oo|
|
1592
|
+
with_each_spreadsheet(:name=>'emptysheets', :format=>[:openoffice, :excel]) do |oo|
|
1553
1593
|
oo.sheets.each { |sheet|
|
1554
1594
|
assert_equal nil, oo.first_row, "first_row not nil in sheet #{sheet}"
|
1555
1595
|
assert_equal nil, oo.last_row, "last_row not nil in sheet #{sheet}"
|
@@ -1567,7 +1607,7 @@ Sheet 3:
|
|
1567
1607
|
def test_bug_simple_spreadsheet_time_bug
|
1568
1608
|
# really a bug? are cells really of type time?
|
1569
1609
|
# No! :float must be the correct type
|
1570
|
-
with_each_spreadsheet(:name=>'simple_spreadsheet', :format=>:excelx) do |oo|
|
1610
|
+
with_each_spreadsheet(:name=>'simple_spreadsheet', :format=>:excelx) do |oo|
|
1571
1611
|
# puts oo.cell('B',5).to_s
|
1572
1612
|
# assert_equal :time, oo.celltype('B',5)
|
1573
1613
|
assert_equal :float, oo.celltype('B',5)
|
@@ -1581,39 +1621,41 @@ Sheet 3:
|
|
1581
1621
|
end
|
1582
1622
|
|
1583
1623
|
def test_simple2_excelx
|
1584
|
-
|
1585
|
-
|
1586
|
-
|
1587
|
-
|
1588
|
-
|
1589
|
-
|
1590
|
-
|
1591
|
-
|
1592
|
-
|
1593
|
-
|
1594
|
-
|
1595
|
-
|
1596
|
-
|
1597
|
-
|
1598
|
-
|
1599
|
-
|
1600
|
-
|
1601
|
-
|
1602
|
-
|
1603
|
-
|
1604
|
-
|
1605
|
-
|
1606
|
-
|
1607
|
-
|
1608
|
-
|
1609
|
-
|
1610
|
-
|
1611
|
-
|
1624
|
+
after Date.new(2009,10,15) do
|
1625
|
+
with_each_spreadsheet(:name=>'simple_spreadsheet', :format=>:excelx) do |oo|
|
1626
|
+
assert_equal [:numeric_or_formula, "yyyy\\-mm\\-dd"], oo.excelx_type('A',4)
|
1627
|
+
assert_equal [:numeric_or_formula, "#,##0.00"], oo.excelx_type('B',4)
|
1628
|
+
assert_equal [:numeric_or_formula, "#,##0.00"], oo.excelx_type('c',4)
|
1629
|
+
assert_equal [:numeric_or_formula, "General"], oo.excelx_type('d',4)
|
1630
|
+
assert_equal [:numeric_or_formula, "General"], oo.excelx_type('e',4)
|
1631
|
+
assert_equal :string, oo.excelx_type('f',4)
|
1632
|
+
|
1633
|
+
assert_equal "39209", oo.excelx_value('a',4)
|
1634
|
+
assert_equal "yyyy\\-mm\\-dd", oo.excelx_format('a',4)
|
1635
|
+
assert_equal "9.25", oo.excelx_value('b',4)
|
1636
|
+
assert_equal "10.25", oo.excelx_value('c',4)
|
1637
|
+
assert_equal "0", oo.excelx_value('d',4)
|
1638
|
+
#... Sum-Spalte
|
1639
|
+
# assert_equal "Task 1", oo.excelx_value('f',4)
|
1640
|
+
assert_equal "Task 1", oo.cell('f',4)
|
1641
|
+
assert_equal Date.new(2007,05,07), oo.cell('a',4)
|
1642
|
+
assert_equal "9.25", oo.excelx_value('b',4)
|
1643
|
+
assert_equal "#,##0.00", oo.excelx_format('b',4)
|
1644
|
+
assert_equal 9.25, oo.cell('b',4)
|
1645
|
+
assert_equal :float, oo.celltype('b',4)
|
1646
|
+
assert_equal :float, oo.celltype('d',4)
|
1647
|
+
assert_equal 0, oo.cell('d',4)
|
1648
|
+
assert_equal :formula, oo.celltype('e',4)
|
1649
|
+
assert_equal 1, oo.cell('e',4)
|
1650
|
+
assert_equal 'C4-B4-D4', oo.formula('e',4)
|
1651
|
+
assert_equal :string, oo.celltype('f',4)
|
1652
|
+
assert_equal "Task 1", oo.cell('f',4)
|
1653
|
+
end
|
1612
1654
|
end
|
1613
1655
|
end
|
1614
1656
|
|
1615
1657
|
def test_datetime
|
1616
|
-
with_each_spreadsheet(:name=>'datetime') do |oo|
|
1658
|
+
with_each_spreadsheet(:name=>'datetime') do |oo|
|
1617
1659
|
val = oo.cell('c',3)
|
1618
1660
|
assert_kind_of DateTime, val
|
1619
1661
|
assert_equal :datetime, oo.celltype('c',3)
|
@@ -1642,38 +1684,43 @@ Sheet 3:
|
|
1642
1684
|
end
|
1643
1685
|
|
1644
1686
|
def test_cell_openoffice_html_escape
|
1645
|
-
with_each_spreadsheet(:name=>'html-escape', :format=>:openoffice) do |oo|
|
1687
|
+
with_each_spreadsheet(:name=>'html-escape', :format=>:openoffice) do |oo|
|
1646
1688
|
assert_equal "'", oo.cell(1,1)
|
1647
1689
|
assert_equal "&", oo.cell(2,1)
|
1648
1690
|
assert_equal ">", oo.cell(3,1)
|
1649
1691
|
assert_equal "<", oo.cell(4,1)
|
1650
1692
|
assert_equal "`", oo.cell(5,1)
|
1651
1693
|
# test_openoffice_zipped will catch issues with "
|
1652
|
-
end
|
1653
|
-
end
|
1694
|
+
end
|
1695
|
+
end
|
1654
1696
|
|
1655
1697
|
def test_cell_boolean
|
1656
|
-
with_each_spreadsheet(:name=>'boolean', :format=>[:openoffice, :excel, :excelx]) do |oo|
|
1657
|
-
if oo.class == Excelx
|
1658
|
-
assert_equal "TRUE", oo.cell(1,1)
|
1659
|
-
assert_equal "FALSE", oo.cell(2,1)
|
1698
|
+
with_each_spreadsheet(:name=>'boolean', :format=>[:openoffice, :excel, :excelx]) do |oo|
|
1699
|
+
if oo.class == Excelx
|
1700
|
+
assert_equal "TRUE", oo.cell(1,1), "failure in "+oo.class.to_s
|
1701
|
+
assert_equal "FALSE", oo.cell(2,1), "failure in "+oo.class.to_s
|
1660
1702
|
else
|
1661
|
-
assert_equal "true", oo.cell(1,1)
|
1662
|
-
assert_equal "false", oo.cell(2,1)
|
1703
|
+
assert_equal "true", oo.cell(1,1), "failure in "+oo.class.to_s
|
1704
|
+
assert_equal "false", oo.cell(2,1), "failure in "+oo.class.to_s
|
1663
1705
|
end
|
1664
1706
|
end
|
1665
1707
|
end
|
1666
1708
|
|
1667
|
-
|
1668
|
-
|
1669
|
-
|
1670
|
-
|
1671
|
-
|
1672
|
-
|
1673
|
-
|
1709
|
+
def test_cell_multiline
|
1710
|
+
with_each_spreadsheet(:name=>'paragraph', :format=>[:openoffice, :excel, :excelx]) do |oo|
|
1711
|
+
assert_equal "This is a test\nof a multiline\nCell", oo.cell(1,1)
|
1712
|
+
assert_equal "This is a test\n¶\nof a multiline\n\nCell", oo.cell(1,2)
|
1713
|
+
assert_equal "first p\n\nsecond p\n\nlast p", oo.cell(2,1)
|
1714
|
+
end
|
1715
|
+
end
|
1674
1716
|
|
1675
1717
|
def test_cell_styles
|
1676
|
-
|
1718
|
+
# styles only valid in excel spreadsheets?
|
1719
|
+
# TODO: what todo with other spreadsheet types
|
1720
|
+
with_each_spreadsheet(:name=>'style', :format=>[# :openoffice,
|
1721
|
+
:excel,
|
1722
|
+
# :excelx
|
1723
|
+
]) do |oo|
|
1677
1724
|
# bold
|
1678
1725
|
assert_equal true, oo.font(1,1).bold?
|
1679
1726
|
assert_equal false, oo.font(1,1).italic?
|
@@ -1728,107 +1775,172 @@ Sheet 3:
|
|
1728
1775
|
assert_equal false, oo.font(11,4).bold?
|
1729
1776
|
assert_equal false, oo.font(11,4).italic?
|
1730
1777
|
assert_equal false, oo.font(11,4).underline?
|
1731
|
-
end
|
1778
|
+
end
|
1732
1779
|
end
|
1733
1780
|
|
1734
|
-
# If a cell has a date-like string but is preceeded by a '
|
1781
|
+
# If a cell has a date-like string but is preceeded by a '
|
1735
1782
|
# to force that date to be treated like a string, we were getting an exception.
|
1736
1783
|
# This test just checks for that exception to make sure it's not raised in this case
|
1737
1784
|
def test_date_to_float_conversion
|
1738
|
-
with_each_spreadsheet(:name=>'datetime_floatconv', :format=>:excel) do |oo|
|
1739
|
-
|
1740
|
-
|
1741
|
-
|
1742
|
-
|
1743
|
-
|
1744
|
-
end
|
1745
|
-
|
1746
|
-
# Need to extend to other formats
|
1785
|
+
with_each_spreadsheet(:name=>'datetime_floatconv', :format=>:excel) do |oo|
|
1786
|
+
assert_nothing_raised(NoMethodError) do
|
1787
|
+
oo.cell('a',1)
|
1788
|
+
oo.cell('a',2)
|
1789
|
+
end
|
1790
|
+
end
|
1791
|
+
end
|
1792
|
+
|
1793
|
+
# Need to extend to other formats
|
1747
1794
|
def test_row_whitespace
|
1748
|
-
|
1749
|
-
|
1750
|
-
|
1751
|
-
|
1752
|
-
|
1753
|
-
|
1754
|
-
|
1755
|
-
|
1756
|
-
|
1757
|
-
|
1758
|
-
|
1759
|
-
|
1795
|
+
# auf dieses Dokument habe ich keinen Zugriff TODO:
|
1796
|
+
after Date.new(2009,11,1) do
|
1797
|
+
with_each_spreadsheet(:name=>'whitespace') do |oo|
|
1798
|
+
oo.default_sheet = "Sheet1"
|
1799
|
+
assert_equal [nil, nil, nil, nil, nil, nil], oo.row(1)
|
1800
|
+
assert_equal [nil, nil, nil, nil, nil, nil], oo.row(2)
|
1801
|
+
assert_equal ["Date", "Start time", "End time", "Pause", "Sum", "Comment"], oo.row(3)
|
1802
|
+
assert_equal [Date.new(2007,5,7), 9.25, 10.25, 0.0, 1.0, "Task 1"], oo.row(4)
|
1803
|
+
assert_equal [nil, nil, nil, nil, nil, nil], oo.row(5)
|
1804
|
+
assert_equal [Date.new(2007,5,7), 10.75, 10.75, 0.0, 0.0, "Task 1"], oo.row(6)
|
1805
|
+
oo.default_sheet = "Sheet2"
|
1806
|
+
assert_equal ["Date", nil, "Start time"], oo.row(1)
|
1807
|
+
assert_equal [Date.new(2007,5,7), nil, 9.25], oo.row(2)
|
1808
|
+
assert_equal [Date.new(2007,5,7), nil, 10.75], oo.row(3)
|
1809
|
+
end
|
1760
1810
|
end
|
1761
1811
|
end
|
1762
1812
|
|
1763
1813
|
def test_col_whitespace
|
1764
|
-
|
1765
|
-
|
1766
|
-
|
1767
|
-
|
1768
|
-
|
1769
|
-
|
1770
|
-
|
1771
|
-
|
1772
|
-
|
1773
|
-
|
1774
|
-
|
1775
|
-
|
1776
|
-
|
1777
|
-
|
1814
|
+
after Date.new(2009,11,20) do
|
1815
|
+
#TODO:
|
1816
|
+
# kein Zugriff auf Dokument whitespace
|
1817
|
+
with_each_spreadsheet(:name=>'whitespace') do |oo|
|
1818
|
+
oo.default_sheet = "Sheet1"
|
1819
|
+
assert_equal ["Date", Date.new(2007,5,7), nil, Date.new(2007,5,7)], oo.column(1)
|
1820
|
+
assert_equal ["Start time", 9.25, nil, 10.75], oo.column(2)
|
1821
|
+
assert_equal ["End time", 10.25, nil, 10.75], oo.column(3)
|
1822
|
+
assert_equal ["Pause", 0.0, nil, 0.0], oo.column(4)
|
1823
|
+
assert_equal ["Sum", 1.0, nil, 0.0], oo.column(5)
|
1824
|
+
assert_equal ["Comment","Task 1", nil, "Task 1"], oo.column(6)
|
1825
|
+
oo.default_sheet = "Sheet2"
|
1826
|
+
assert_equal [nil, nil, nil], oo.column(1)
|
1827
|
+
assert_equal [nil, nil, nil], oo.column(2)
|
1828
|
+
assert_equal ["Date", Date.new(2007,5,7), Date.new(2007,5,7)], oo.column(3)
|
1829
|
+
assert_equal [nil, nil, nil], oo.column(4)
|
1830
|
+
assert_equal [ "Start time", 9.25, 10.75], oo.column(5)
|
1831
|
+
end
|
1778
1832
|
end
|
1779
1833
|
end
|
1780
1834
|
|
1781
|
-
|
1782
|
-
def test_ruby_spreadsheet_formula_bug
|
1783
|
-
with_each_spreadsheet(:name=>'formula_parse_error', :format=>:excel) do |oo|
|
1784
|
-
assert_equal '5026', oo.cell(2,3)
|
1785
|
-
assert_equal '5026', oo.cell(3,3)
|
1786
|
-
end
|
1787
|
-
end
|
1788
|
-
|
1789
|
-
|
1790
|
-
# Excel has two base date formats one from 1900 and the other from 1904.
|
1835
|
+
# Excel has two base date formats one from 1900 and the other from 1904.
|
1791
1836
|
# There's a MS bug that 1900 base dates include an extra day due to erroneously
|
1792
|
-
# including 1900 as a leap yar.
|
1837
|
+
# including 1900 as a leap yar.
|
1793
1838
|
def test_base_dates_in_excel
|
1794
|
-
with_each_spreadsheet(:name=>'1900_base', :format=>:excel) do |oo|
|
1839
|
+
with_each_spreadsheet(:name=>'1900_base', :format=>:excel) do |oo|
|
1795
1840
|
assert_equal Date.new(2009,06,15), oo.cell(1,1)
|
1796
|
-
assert_equal Date.new(
|
1841
|
+
#we don't want to to 'interpret' formulas assert_equal Date.new(Time.now.year,Time.now.month,Time.now.day), oo.cell(2,1) #formula for TODAY()
|
1842
|
+
# if we test TODAY() we have also have to calculate
|
1843
|
+
# other date calculations
|
1844
|
+
#
|
1797
1845
|
assert_equal :date, oo.celltype(1,1)
|
1798
|
-
end
|
1799
|
-
with_each_spreadsheet(:name=>'1904_base', :format=>:excel) do |oo|
|
1846
|
+
end
|
1847
|
+
with_each_spreadsheet(:name=>'1904_base', :format=>:excel) do |oo|
|
1800
1848
|
assert_equal Date.new(2009,06,15), oo.cell(1,1)
|
1801
|
-
|
1849
|
+
# see comment above
|
1850
|
+
# assert_equal Date.new(Time.now.year,Time.now.month,Time.now.day), oo.cell(2,1) #formula for TODAY()
|
1802
1851
|
assert_equal :date, oo.celltype(1,1)
|
1803
|
-
end
|
1852
|
+
end
|
1804
1853
|
end
|
1805
1854
|
|
1806
|
-
|
1807
|
-
|
1808
|
-
with_each_spreadsheet(:name=>'bad_excel_date', :format=>:excel) do |oo|
|
1855
|
+
def test_bad_date
|
1856
|
+
with_each_spreadsheet(:name=>'prova', :format=>:excel) do |oo|
|
1809
1857
|
assert_nothing_raised(ArgumentError) {
|
1810
1858
|
assert_equal DateTime.new(2006,2,2,10,0,0), oo.cell('a',1)
|
1811
1859
|
}
|
1860
|
+
end # each
|
1861
|
+
end
|
1862
|
+
|
1863
|
+
def test_cell_methods
|
1864
|
+
with_each_spreadsheet(:name=>'numbers1') do |oo|
|
1865
|
+
assert_equal 10, oo.a4 # cell(4,'A')
|
1866
|
+
assert_equal 11, oo.b4 # cell(4,'B')
|
1867
|
+
assert_equal 12, oo.c4 # cell(4,'C')
|
1868
|
+
assert_equal 13, oo.d4 # cell(4,'D')
|
1869
|
+
assert_equal 14, oo.e4 # cell(4,'E')
|
1870
|
+
assert_equal 'ABC', oo.c6('Sheet5')
|
1871
|
+
|
1872
|
+
assert_raises(ArgumentError) {
|
1873
|
+
# a42a is not a valid cell name, should raise ArgumentError
|
1874
|
+
assert_equal 9999, oo.a42a
|
1875
|
+
}
|
1812
1876
|
end
|
1877
|
+
|
1813
1878
|
end
|
1814
1879
|
|
1815
|
-
|
1816
|
-
|
1817
|
-
|
1818
|
-
|
1819
|
-
|
1820
|
-
|
1821
|
-
|
1880
|
+
|
1881
|
+
# compare large spreadsheets
|
1882
|
+
def test_compare_large_spreadsheets
|
1883
|
+
after Date.new(2010,11,1) do
|
1884
|
+
# problematisch, weil Formeln in Excel nicht unterstützt werden
|
1885
|
+
if LONG_RUN
|
1886
|
+
qq = Openoffice.new(File.join('test',"Bibelbund.ods"))
|
1887
|
+
with_each_spreadsheet(:name=>'Bibelbund') do |oo|
|
1888
|
+
# p "comparing Bibelbund.ods with #{oo.class}"
|
1889
|
+
oo.sheets.each do |sh|
|
1890
|
+
oo.first_row.upto(oo.last_row) do |row|
|
1891
|
+
oo.first_column.upto(oo.last_column) do |col|
|
1892
|
+
c1 = qq.cell(row,col,sh)
|
1893
|
+
c1.force_encoding("UTF-8") if c1.class == String
|
1894
|
+
c2 = oo.cell(row,col,sh)
|
1895
|
+
c2.force_encoding("UTF-8") if c2.class == String
|
1896
|
+
assert_equal c1, c2, "diff in #{sh}/#{row}/#{col}}"
|
1897
|
+
assert_equal qq.celltype(row,col,sh), oo.celltype(row,col,sh)
|
1898
|
+
assert_equal qq.formula?(row,col,sh), oo.formula?(row,col,sh)
|
1899
|
+
end
|
1900
|
+
end
|
1901
|
+
end
|
1902
|
+
end
|
1903
|
+
end # LONG_RUN
|
1822
1904
|
end
|
1823
|
-
end
|
1905
|
+
end
|
1824
1906
|
|
1825
|
-
def
|
1826
|
-
|
1827
|
-
|
1828
|
-
|
1829
|
-
|
1830
|
-
|
1907
|
+
def test_labeled_cells
|
1908
|
+
# TODO: more spreadsheet types
|
1909
|
+
with_each_spreadsheet(:name=>'named_cells', :format=>:openoffice) do |oo|
|
1910
|
+
oo.default_sheet = oo.sheets.first
|
1911
|
+
begin
|
1912
|
+
row,col = oo.label('anton')
|
1913
|
+
rescue ArgumentError
|
1914
|
+
puts "labels error at #{oo.class}"
|
1915
|
+
raise
|
1916
|
+
end
|
1917
|
+
assert_equal 5, row
|
1918
|
+
assert_equal 3, col
|
1919
|
+
|
1920
|
+
row,col = oo.label('anton')
|
1921
|
+
assert_equal 'Anton', oo.cell(row,col)
|
1922
|
+
|
1923
|
+
row,col = oo.label('berta')
|
1924
|
+
assert_equal 'Bertha', oo.cell(row,col)
|
1925
|
+
|
1926
|
+
row,col = oo.label('caesar')
|
1927
|
+
assert_equal 'Cäsar', oo.cell(row,col)
|
1928
|
+
|
1929
|
+
# a not defined label:
|
1930
|
+
row,col = oo.label('never')
|
1931
|
+
assert_nil row
|
1932
|
+
assert_nil col
|
1933
|
+
|
1934
|
+
row,col,sheet = oo.label('anton')
|
1935
|
+
assert_equal 5, row
|
1936
|
+
assert_equal 3, col
|
1937
|
+
assert_equal "Sheet1", sheet
|
1938
|
+
#
|
1939
|
+
# assert_equal "Anton", oo.label('anton')
|
1940
|
+
after Date.new(2009,12,12) do
|
1941
|
+
assert_equal "Anton", oo.anton
|
1942
|
+
end
|
1831
1943
|
end
|
1832
|
-
end
|
1833
|
-
|
1944
|
+
end
|
1945
|
+
|
1834
1946
|
end # class
|