From 16a6619746e57501da84c54b89fa3066d718e891 Mon Sep 17 00:00:00 2001 From: julian Date: Thu, 6 Apr 2023 17:30:33 -0600 Subject: [PATCH] remove fromDouble constructor from amount due to possible precision errors --- lib/utilities/amount/amount.dart | 17 ---------- test/utilities/{ => amount}/amount_test.dart | 35 +------------------- 2 files changed, 1 insertion(+), 51 deletions(-) rename test/utilities/{ => amount}/amount_test.dart (85%) diff --git a/lib/utilities/amount/amount.dart b/lib/utilities/amount/amount.dart index 9688e2b79..30619bb0d 100644 --- a/lib/utilities/amount/amount.dart +++ b/lib/utilities/amount/amount.dart @@ -4,8 +4,6 @@ import 'package:decimal/decimal.dart'; import 'package:intl/number_symbols.dart'; import 'package:intl/number_symbols_data.dart'; -final _ten = BigInt.from(10); - class Amount { Amount({ required BigInt rawValue, @@ -19,12 +17,6 @@ class Amount { fractionDigits: 0, ); - /// truncate double value to [fractionDigits] places - Amount.fromDouble(double amount, {required this.fractionDigits}) - : assert(fractionDigits >= 0), - _value = - Decimal.parse(amount.toString()).shift(fractionDigits).toBigInt(); - /// truncate decimal value to [fractionDigits] places Amount.fromDecimal(Decimal amount, {required this.fractionDigits}) : assert(fractionDigits >= 0), @@ -170,15 +162,6 @@ extension DecimalAmountExt on Decimal { } } -extension DoubleAmountExt on double { - Amount toAmount({required int fractionDigits}) { - return Amount.fromDouble( - this, - fractionDigits: fractionDigits, - ); - } -} - extension IntAmountExtension on int { Amount toAmountAsRaw({required int fractionDigits}) { return Amount( diff --git a/test/utilities/amount_test.dart b/test/utilities/amount/amount_test.dart similarity index 85% rename from test/utilities/amount_test.dart rename to test/utilities/amount/amount_test.dart index 65e9b463d..c909ff122 100644 --- a/test/utilities/amount_test.dart +++ b/test/utilities/amount/amount_test.dart @@ -28,31 +28,6 @@ void main() { expect(didThrow, true); }); - test("Named fromDouble Amount Constructor tests", () { - Amount amount = Amount.fromDouble(2.0, fractionDigits: 0); - expect(amount.fractionDigits, 0); - expect(amount.raw, BigInt.two); - expect(amount.decimal, Decimal.fromInt(2)); - - amount = Amount.fromDouble(2.0, fractionDigits: 2); - expect(amount.fractionDigits, 2); - expect(amount.raw, BigInt.from(200)); - expect(amount.decimal, Decimal.fromInt(2)); - - amount = Amount.fromDouble(0.0123456789, fractionDigits: 7); - expect(amount.fractionDigits, 7); - expect(amount.raw, BigInt.from(123456)); - expect(amount.decimal, Decimal.parse("0.0123456")); - - bool didThrow = false; - try { - amount = Amount.fromDouble(2.0, fractionDigits: -1); - } catch (_) { - didThrow = true; - } - expect(didThrow, true); - }); - test("Named fromDecimal Amount Constructor tests", () { Amount amount = Amount.fromDecimal(Decimal.fromInt(2), fractionDigits: 0); expect(amount.fractionDigits, 0); @@ -89,10 +64,6 @@ void main() { Amount.fromDecimal(Decimal.fromInt(2), fractionDigits: 8).toMap(), {"raw": "200000000", "fractionDigits": 8}, ); - expect( - Amount.fromDouble(2, fractionDigits: 8).toMap(), - {"raw": "200000000", "fractionDigits": 8}, - ); }); test("toJsonString", () { @@ -105,10 +76,6 @@ void main() { .toJsonString(), '{"raw":"200000000","fractionDigits":8}', ); - expect( - Amount.fromDouble(2, fractionDigits: 8).toJsonString(), - '{"raw":"200000000","fractionDigits":8}', - ); }); test("localizedStringAsFixed", () { @@ -145,7 +112,7 @@ void main() { expect( Amount.fromSerializedJsonString( '{"raw":"200000000","fractionDigits":8}'), - Amount.fromDouble(2, fractionDigits: 8), + Amount.fromDecimal(Decimal.parse("2"), fractionDigits: 8), ); }); });