1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
require 'test_helper'
class TestRooExcelxCellNumber < Minitest::Test
def number
Roo::Excelx::Cell::Number
end
def test_float
cell = Roo::Excelx::Cell::Number.new '42.1', nil, ['General'], nil, nil, nil
assert_kind_of(Float, cell.value)
end
def test_integer
cell = Roo::Excelx::Cell::Number.new '42', nil, ['0'], nil, nil, nil
assert_kind_of(Integer, cell.value)
end
def test_scientific_notation
cell = Roo::Excelx::Cell::Number.new '1.2E-3', nil, ['0'], nil, nil, nil
assert_kind_of(Float, cell.value)
end
def test_simple_scientific_notation
cell = Roo::Excelx::Cell::Number.new '1E-3', nil, ['0'], nil, nil, nil
assert_kind_of(Float, cell.value)
end
def test_percent
cell = Roo::Excelx::Cell::Number.new '42.1', nil, ['0.00%'], nil, nil, nil
assert_kind_of(Float, cell.value)
end
def test_formats_with_negative_numbers
[
['#,##0 ;(#,##0)', '(1,042)'],
['#,##0 ;[Red](#,##0)', '[Red](1,042)'],
['#,##0.00;(#,##0.00)', '(1,042.00)'],
['#,##0.00;[Red](#,##0.00)', '[Red](1,042.00)']
].each do |style_format, result|
cell = Roo::Excelx::Cell::Number.new '-1042', nil, [style_format], nil, nil, nil
assert_equal result, cell.formatted_value, "Style=#{style_format}"
end
end
def test_numbers_with_cell_errors
Roo::Excelx::ERROR_VALUES.each do |error|
cell = Roo::Excelx::Cell::Number.new error, nil, ['General'], nil, nil, nil
assert_equal error, cell.value
assert_equal error, cell.formatted_value
end
end
def test_formats
[
['General', '1042'],
['0', '1042'],
['0.00', '1042.00'],
['#,##0', '1,042'],
['#,##0.00', '1,042.00'],
['0%', '104200%'],
['0.00%', '104200.00%'],
['0.00E+00', '1.04E+03'],
['#,##0 ;(#,##0)', '1,042'],
['#,##0 ;[Red](#,##0)', '1,042'],
['#,##0.00;(#,##0.00)', '1,042.00'],
['#,##0.00;[Red](#,##0.00)', '1,042.00'],
['##0.0E+0', '1.0E+03'],
['@', '1042']
].each do |style_format, result|
cell = Roo::Excelx::Cell::Number.new '1042', nil, [style_format], nil, nil, nil
assert_equal result, cell.formatted_value, "Style=#{style_format}"
end
end
end
|