summaryrefslogtreecommitdiff
path: root/test/bigdecimal
diff options
context:
space:
mode:
authorKenta Murata <mrkn@mrkn.jp>2021-11-25 14:51:13 +0900
committerKenta Murata <mrkn@mrkn.jp>2021-12-24 02:28:58 +0900
commitaca96f7ec7899da98df7ece5831730bcf013a76f (patch)
treeda9f4f4c8607066a1c9e8b4b48d891ea15a290ff /test/bigdecimal
parent0c63aa11bcbe1d865f9a6ca5e89dfc742bb42f27 (diff)
[ruby/bigdecimal] Add BigDecimal#scale
Fixes GH-198. https://github.com/ruby/bigdecimal/commit/4fbec55680
Diffstat (limited to 'test/bigdecimal')
-rw-r--r--test/bigdecimal/test_bigdecimal.rb53
1 files changed, 53 insertions, 0 deletions
diff --git a/test/bigdecimal/test_bigdecimal.rb b/test/bigdecimal/test_bigdecimal.rb
index 5a4108c603..f2162cafbe 100644
--- a/test/bigdecimal/test_bigdecimal.rb
+++ b/test/bigdecimal/test_bigdecimal.rb
@@ -2070,6 +2070,59 @@ class TestBigDecimal < Test::Unit::TestCase
end
end
+ def test_scale_only_integer
+ assert_equal(0, BigDecimal(0).scale)
+ assert_equal(0, BigDecimal(1).scale)
+ assert_equal(0, BigDecimal(-1).scale)
+ assert_equal(0, BigDecimal(10).scale)
+ assert_equal(0, BigDecimal(-10).scale)
+ assert_equal(0, BigDecimal(100_000_000).scale)
+ assert_equal(0, BigDecimal(-100_000_000).scale)
+ assert_equal(0, BigDecimal(100_000_000_000).scale)
+ assert_equal(0, BigDecimal(-100_000_000_000).scale)
+ assert_equal(0, BigDecimal(100_000_000_000_000_000_000).scale)
+ assert_equal(0, BigDecimal(-100_000_000_000_000_000_000).scale)
+ assert_equal(0, BigDecimal("111e100").scale)
+ assert_equal(0, BigDecimal("-111e100").scale)
+ end
+
+ def test_scale_only_fraction
+ assert_equal(1, BigDecimal("0.1").scale)
+ assert_equal(1, BigDecimal("-0.1").scale)
+ assert_equal(2, BigDecimal("0.01").scale)
+ assert_equal(2, BigDecimal("-0.01").scale)
+ assert_equal(2, BigDecimal("0.11").scale)
+ assert_equal(2, BigDecimal("-0.11").scale)
+ assert_equal(21, BigDecimal("0.000_000_000_000_000_000_001").scale)
+ assert_equal(21, BigDecimal("-0.000_000_000_000_000_000_001").scale)
+ assert_equal(100, BigDecimal("111e-100").scale)
+ assert_equal(100, BigDecimal("-111e-100").scale)
+ end
+
+ def test_scale_full
+ assert_equal(1, BigDecimal("0.1").scale)
+ assert_equal(1, BigDecimal("-0.1").scale)
+ assert_equal(2, BigDecimal("0.01").scale)
+ assert_equal(2, BigDecimal("-0.01").scale)
+ assert_equal(2, BigDecimal("0.11").scale)
+ assert_equal(2, BigDecimal("-0.11").scale)
+ assert_equal(2, BigDecimal("11111e-2").scale)
+ assert_equal(2, BigDecimal("-11111e-2").scale)
+ assert_equal(18, BigDecimal("100.000_000_000_000_000_001").scale)
+ assert_equal(18, BigDecimal("-100.000_000_000_000_000_001").scale)
+ end
+
+ def test_scale_special
+ BigDecimal.save_exception_mode do
+ BigDecimal.mode(BigDecimal::EXCEPTION_OVERFLOW, false)
+ BigDecimal.mode(BigDecimal::EXCEPTION_NaN, false)
+
+ assert_equal(0, BigDecimal("Infinity").scale)
+ assert_equal(0, BigDecimal("-Infinity").scale)
+ assert_equal(0, BigDecimal("NaN").scale)
+ end
+ end
+
def test_n_significant_digits_only_integer
assert_equal(0, BigDecimal(0).n_significant_digits)
assert_equal(1, BigDecimal(1).n_significant_digits)