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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
##
# Float ISO Test
assert('Float', '15.2.9') do
Float.class == Class
end
assert('Float#+', '15.2.9.3.1') do
a = 3.123456788 + 0.000000001
b = 3.123456789 + 1
check_float(a, 3.123456789) and
check_float(b, 4.123456789)
end
assert('Float#-', '15.2.9.3.2') do
a = 3.123456790 - 0.000000001
b = 5.123456789 - 1
check_float(a, 3.123456789) and
check_float(b, 4.123456789)
end
assert('Float#*', '15.2.9.3.3') do
a = 3.123456789 * 3.123456789
b = 3.123456789 * 1
check_float(a, 9.75598231275019) and
check_float(b, 3.123456789)
end
assert('Float#/', '15.2.9.3.4') do
a = 3.123456789 / 3.123456789
b = 3.123456789 / 1
check_float(a, 1.0) and
check_float(b, 3.123456789)
end
assert('Float#%', '15.2.9.3.5') do
a = 3.123456789 % 3.123456789
b = 3.123456789 % 1
check_float(a, 0.0) and
check_float(b, 0.123456789)
end
assert('Float#<=>', '15.2.9.3.6') do
a = 3.123456789 <=> 3.123456788
b = 3.123456789 <=> 3.123456789
c = 3.123456789 <=> 3.123456790
a2 = 3.123456789 <=> 3
c2 = 3.123456789 <=> 4
a == 1 and b == 0 and c == -1 and
a2 == 1 and c2 == -1
end
assert('Float#==', '15.2.9.3.7') do
3.1 == 3.1 and not 3.1 == 3.2
end
assert('Float#ceil', '15.2.9.3.8') do
3.123456789.ceil == 4
end
assert('Float#finite?', '15.2.9.3.9') do
3.123456789.finite? and
not (1.0 / 0.0).finite?
end
assert('Float#floor', '15.2.9.3.10') do
3.123456789.floor == 3
end
assert('Float#infinite?', '15.2.9.3.11') do
not 3.123456789.infinite? and
(1.0 / 0.0).infinite?
end
assert('Float#round', '15.2.9.3.12') do
a = 3.123456789.round
b = 3.5.round
c = 3.499999999.round
a == 3 and b == 4 and c == 3
end
assert('Float#to_f', '15.2.9.3.13') do
a = 3.123456789
check_float(a.to_f, a)
end
assert('Float#to_i', '15.2.9.3.14') do
3.123456789.to_i == 3
end
assert('Float#truncate', '15.2.9.3.15') do
3.123456789.truncate == 3
end
|