2015-12-16 00:07:31 -05:00
|
|
|
# frozen_string_literal: false
|
2013-09-06 08:07:08 -04:00
|
|
|
require 'test/unit'
|
|
|
|
require "-test-/rational"
|
|
|
|
|
|
|
|
class TestRational < Test::Unit::TestCase
|
|
|
|
class TestGCD < Test::Unit::TestCase
|
|
|
|
|
|
|
|
def test_gcd_normal
|
|
|
|
x = 2*2*3*3*3
|
|
|
|
y = 2*2*2*3*3
|
|
|
|
gcd = 2*2*3*3
|
2021-01-08 05:07:16 -05:00
|
|
|
assert_equal(gcd, Bug::Rational.gcd_normal(x, y))
|
2013-09-06 08:07:08 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_gcd_gmp
|
|
|
|
x = 2*2*3*3*3
|
|
|
|
y = 2*2*2*3*3
|
|
|
|
gcd = 2*2*3*3
|
2021-01-08 05:07:16 -05:00
|
|
|
assert_equal(gcd, Bug::Rational.gcd_gmp(x, y))
|
2013-09-06 08:07:08 -04:00
|
|
|
rescue NotImplementedError
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_gcd_gmp_brute_force
|
|
|
|
-13.upto(13) {|x|
|
|
|
|
-13.upto(13) {|y|
|
2021-01-08 05:07:16 -05:00
|
|
|
assert_equal(Bug::Rational.gcd_normal(x, y), Bug::Rational.gcd_gmp(x, y))
|
2013-09-06 08:07:08 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
rescue NotImplementedError
|
|
|
|
end
|
|
|
|
end
|
2020-01-16 20:41:03 -05:00
|
|
|
|
|
|
|
def test_rb_rational_raw
|
2021-01-08 05:07:16 -05:00
|
|
|
rat = Bug::Rational.raw(1, 2)
|
2020-01-16 20:41:03 -05:00
|
|
|
assert_equal(1, rat.numerator)
|
|
|
|
assert_equal(2, rat.denominator)
|
|
|
|
|
2021-01-08 05:07:16 -05:00
|
|
|
rat = Bug::Rational.raw(-1, 2)
|
2020-01-16 20:41:03 -05:00
|
|
|
assert_equal(-1, rat.numerator)
|
|
|
|
assert_equal(2, rat.denominator)
|
|
|
|
|
2021-01-08 05:07:16 -05:00
|
|
|
rat = Bug::Rational.raw(1, -2)
|
2020-01-16 20:41:03 -05:00
|
|
|
assert_equal(-1, rat.numerator)
|
|
|
|
assert_equal(2, rat.denominator)
|
2020-01-16 20:47:20 -05:00
|
|
|
|
2021-01-08 05:07:16 -05:00
|
|
|
assert_equal(1/2r, Bug::Rational.raw(1.0, 2.0))
|
2020-01-16 20:47:20 -05:00
|
|
|
|
2021-01-08 05:07:16 -05:00
|
|
|
assert_raise(TypeError) { Bug::Rational.raw("1", 2) }
|
|
|
|
assert_raise(TypeError) { Bug::Rational.raw(1, "2") }
|
2020-01-16 20:47:20 -05:00
|
|
|
|
|
|
|
class << (o = Object.new)
|
|
|
|
def to_i; 42; end
|
|
|
|
end
|
|
|
|
|
2021-01-08 05:07:16 -05:00
|
|
|
assert_raise(TypeError) { Bug::Rational.raw(o, 2) }
|
|
|
|
assert_raise(TypeError) { Bug::Rational.raw(1, o) }
|
2020-01-16 20:47:20 -05:00
|
|
|
|
|
|
|
class << (o = Object.new)
|
|
|
|
def to_int; 42; end
|
|
|
|
end
|
|
|
|
|
2021-01-08 05:07:16 -05:00
|
|
|
rat = Bug::Rational.raw(o, 2)
|
2020-01-16 20:47:20 -05:00
|
|
|
assert_equal(42, rat.numerator)
|
|
|
|
assert_equal(2, rat.denominator)
|
|
|
|
|
2021-01-08 05:07:16 -05:00
|
|
|
rat = Bug::Rational.raw(2, o)
|
2020-01-16 20:47:20 -05:00
|
|
|
assert_equal(2, rat.numerator)
|
|
|
|
assert_equal(42, rat.denominator)
|
2020-01-16 20:41:03 -05:00
|
|
|
end
|
2013-09-06 08:07:08 -04:00
|
|
|
end
|