summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-time/test
diff options
context:
space:
mode:
authorksss <[email protected]>2017-03-28 10:58:18 +0900
committerksss <[email protected]>2017-03-28 10:58:18 +0900
commit397f1fc94631072b76c750c1be3b809ad6dbc060 (patch)
treeb914ec5a662a862f9017678610217f1c2eda1b34 /mrbgems/mruby-time/test
parent66980493ae2f4d587a4a45b6b1061f46c01e34be (diff)
downloadmruby-397f1fc94631072b76c750c1be3b809ad6dbc060.tar.gz
mruby-397f1fc94631072b76c750c1be3b809ad6dbc060.zip
Fix infinity loop
And some cases should raise FloatDomainError
Diffstat (limited to 'mrbgems/mruby-time/test')
-rw-r--r--mrbgems/mruby-time/test/time.rb21
1 files changed, 18 insertions, 3 deletions
diff --git a/mrbgems/mruby-time/test/time.rb b/mrbgems/mruby-time/test/time.rb
index 759e2881d..52b931177 100644
--- a/mrbgems/mruby-time/test/time.rb
+++ b/mrbgems/mruby-time/test/time.rb
@@ -10,7 +10,14 @@ assert('Time', '15.2.19') do
end
assert('Time.at', '15.2.19.6.1') do
- Time.at(1300000000.0)
+ assert_kind_of(Time, Time.at(1300000000.0))
+
+ assert_raise(FloatDomainError) { Time.at(Float::NAN) }
+ assert_raise(FloatDomainError) { Time.at(Float::INFINITY) }
+ assert_raise(FloatDomainError) { Time.at(-Float::INFINITY) }
+ assert_raise(FloatDomainError) { Time.at(0, Float::NAN) }
+ assert_raise(FloatDomainError) { Time.at(0, Float::INFINITY) }
+ assert_raise(FloatDomainError) { Time.at(0, -Float::INFINITY) }
end
assert('Time.gm', '15.2.19.6.2') do
@@ -37,14 +44,22 @@ assert('Time#+', '15.2.19.7.1') do
t1 = Time.at(1300000000.0)
t2 = t1.+(60)
- t2.utc.asctime == "Sun Mar 13 07:07:40 UTC 2011"
+ assert_equal(t2.utc.asctime, "Sun Mar 13 07:07:40 UTC 2011")
+
+ assert_raise(FloatDomainError) { Time.at(0) + Float::NAN }
+ assert_raise(FloatDomainError) { Time.at(0) + Float::INFINITY }
+ assert_raise(FloatDomainError) { Time.at(0) + -Float::INFINITY }
end
assert('Time#-', '15.2.19.7.2') do
t1 = Time.at(1300000000.0)
t2 = t1.-(60)
- t2.utc.asctime == "Sun Mar 13 07:05:40 UTC 2011"
+ assert_equal(t2.utc.asctime, "Sun Mar 13 07:05:40 UTC 2011")
+
+ assert_raise(FloatDomainError) { Time.at(0) - Float::NAN }
+ assert_raise(FloatDomainError) { Time.at(0) - Float::INFINITY }
+ assert_raise(FloatDomainError) { Time.at(0) - -Float::INFINITY }
end
assert('Time#<=>', '15.2.19.7.3') do