From ede88e6602102f755f6e83604de171dac50720e7 Mon Sep 17 00:00:00 2001 From: Whiskey River <@whiskeyriver> Date: Thu, 21 Mar 2024 12:45:35 -0700 Subject: [PATCH] Resolve the currency by symbol on Currency.__init__ When instantiating the Currency class we need to resolve a `str` currency symbol to its definition class to preserve any attribute overrides. Resolves #254 --- stockholm/currency.py | 4 ++++ tests/test_currency.py | 35 +++++++++++++++++++++++++++++++++++ 2 files changed, 39 insertions(+) diff --git a/stockholm/currency.py b/stockholm/currency.py index 6087c72..976fc28 100644 --- a/stockholm/currency.py +++ b/stockholm/currency.py @@ -321,6 +321,10 @@ def __new__( ) -> BaseCurrency: if not cls._meta: raise TypeError("'BaseCurrency' object is not callable") + + if currency and isinstance(currency, str): + currency = getattr(cls, currency, currency) + return cast( BaseCurrency, BaseCurrencyType( diff --git a/tests/test_currency.py b/tests/test_currency.py index 85a540a..f0ff6e4 100644 --- a/tests/test_currency.py +++ b/tests/test_currency.py @@ -185,6 +185,41 @@ class EUR(BaseCurrency): assert str(m) == "100 CarlosCoin" +def test_custom_currency_attributes(): + class _XYZ(BaseCurrency): + ticker = "XYZ" + decimal_digits = 5 + interchangeable_with = ("CNH", "RMB") + preferred_ticker = "ZYX" + + class Currency(BaseCurrency): + XYZ = _XYZ + + c1 = Currency("XYZ") + assert c1 != Money(0, Currency.XYZ) + assert c1.decimal_digits == _XYZ.decimal_digits + assert c1.interchangeable_with == _XYZ.interchangeable_with + assert c1.preferred_ticker == _XYZ.preferred_ticker + + c2 = Currency(c1) + assert c2.ticker == "XYZ" + assert c2 == c1 + assert str(c2) == "XYZ" + assert c2 == "XYZ" + + c3 = Currency() + assert c3.ticker == "" + assert c3 != c1 + assert c3 == "" + assert str(c3) == "" + assert c3 != Money(0, Currency.XYZ) + + c4 = Currency(Currency.XYZ) + assert c4.ticker == "XYZ" + assert c4 == c1 + assert c4 == "XYZ" + + def test_currency_hashable() -> None: class CNY(BaseCurrency): interchangeable_with = ("CNH", "RMB")