blob: 1541fa71ea6839db248ab19054d6098640bf5ac6 (
plain)
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
|
require 'test/unit'
$KCODE = 'none'
class TestFloat < Test::Unit::TestCase
def test_float
assert(2.6.floor == 2)
assert((-2.6).floor == -3)
assert(2.6.ceil == 3)
assert((-2.6).ceil == -2)
assert(2.6.truncate == 2)
assert((-2.6).truncate == -2)
assert(2.6.round == 3)
assert((-2.4).truncate == -2)
assert((13.4 % 1 - 0.4).abs < 0.0001)
nan = 0.0/0
def nan.test(v)
extend Test::Unit::Assertions
assert(self != v)
assert((self < v) == false)
assert((self > v) == false)
assert((self <= v) == false)
assert((self >= v) == false)
end
nan.test(nan)
nan.test(0)
nan.test(1)
nan.test(-1)
nan.test(1000)
nan.test(-1000)
nan.test(1_000_000_000_000)
nan.test(-1_000_000_000_000)
nan.test(100.0);
nan.test(-100.0);
nan.test(0.001);
nan.test(-0.001);
nan.test(1.0/0);
nan.test(-1.0/0);
#s = "3.7517675036461267e+17"
#assert(s == sprintf("%.16e", s.to_f))
f = 3.7517675036461267e+17
assert(f == sprintf("%.16e", f).to_f)
end
end
|