Fix rounding of custom-formatted negative amounts

closes #39349
This commit is contained in:
Jannosch Müller 2020-05-19 13:33:28 +02:00
parent 1ab0e6b6d8
commit 31575b39ca
2 changed files with 9 additions and 7 deletions

@ -9,15 +9,11 @@ class NumberToCurrencyConverter < NumberConverter # :nodoc:
def convert
number = self.number.to_s.strip
number_f = number.to_f
format = options[:format]
if number_f.negative?
number = number_f.abs
unless options[:precision] == 0 && number < 0.5
format = options[:negative_format]
end
if number.sub!(/^-/, "") &&
(options[:precision] != 0 || number.to_f > 0.5)
format = options[:negative_format]
end
rounded_number = NumberToRoundedConverter.convert(number, options)

@ -79,6 +79,12 @@ def test_number_to_currency
assert_equal("1,234,567,890.50 - K&#269;", number_helper.number_to_currency("-1234567890.50", unit: "K&#269;", format: "%n %u", negative_format: "%n - %u"))
assert_equal("0.00", number_helper.number_to_currency(+0.0, unit: "", negative_format: "(%n)"))
assert_equal("$0", number_helper.number_to_currency(-0.456789, precision: 0))
assert_equal("$1,11", number_helper.number_to_currency("1,11"))
assert_equal("$0,11", number_helper.number_to_currency("0,11"))
assert_equal("$,11", number_helper.number_to_currency(",11"))
assert_equal("-$1,11", number_helper.number_to_currency("-1,11"))
assert_equal("-$0,11", number_helper.number_to_currency("-0,11"))
assert_equal("-$,11", number_helper.number_to_currency("-,11"))
end
end