From 22b810edbc16725491d4866276846072192635e5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafa=C5=82=20Pito=C5=84?= Date: Tue, 13 Mar 2018 13:00:39 +0100 Subject: [PATCH 1/2] Improve default= handling on MoneyField --- django_prices/models.py | 7 +++++++ tests/models.py | 7 +++++++ tests/test_prices.py | 25 +++++++++++++++++++++++-- 3 files changed, 37 insertions(+), 2 deletions(-) diff --git a/django_prices/models.py b/django_prices/models.py index 48a2de5..6f90bf1 100644 --- a/django_prices/models.py +++ b/django_prices/models.py @@ -15,6 +15,11 @@ class MoneyField(models.DecimalField): def __init__(self, verbose_name=None, currency=None, **kwargs): self.currency = currency + if (isinstance(kwargs.get('default'), Money) and + kwargs['default'].currency != self.currency): + raise ValueError( + 'Invalid currency for default value: %r (expected %r)' % ( + kwargs['default'].currency, self.currency)) super(MoneyField, self).__init__(verbose_name, **kwargs) def from_db_value(self, value, expression, connection, context): @@ -67,6 +72,8 @@ def validators(self): def deconstruct(self): name, path, args, kwargs = super(MoneyField, self).deconstruct() kwargs['currency'] = self.currency + if isinstance(kwargs.get('default'), Money): + kwargs['default'] = str(kwargs['default'].amount) return name, path, args, kwargs diff --git a/tests/models.py b/tests/models.py index a86fed5..f946dc7 100644 --- a/tests/models.py +++ b/tests/models.py @@ -1,5 +1,6 @@ from django.db import models from django_prices.models import MoneyField, TaxedMoneyField +from prices import Money class Model(models.Model): @@ -10,3 +11,9 @@ class Model(models.Model): 'gross', currency='BTC', default='5', max_digits=9, decimal_places=2) price = TaxedMoneyField(net_field='price_net', gross_field='price_gross') + + +class ModelWithDefault(models.Model): + price = MoneyField( + currency='USD', default=Money('0', 'USD'), max_digits=9, + decimal_places=2) diff --git a/tests/test_prices.py b/tests/test_prices.py index 15bb5a3..c413ee8 100644 --- a/tests/test_prices.py +++ b/tests/test_prices.py @@ -6,7 +6,7 @@ import pytest from django.core.exceptions import ValidationError -from django.db import connection +from django.db import connection, models from django.utils import translation from prices import Money, TaxedMoney, percentage_discount @@ -19,7 +19,7 @@ from .forms import ( ModelForm, OptionalPriceForm, RequiredPriceForm, ValidatedPriceForm) -from .models import Model +from .models import Model, ModelWithDefault @pytest.fixture(scope='module') @@ -197,6 +197,27 @@ def test_combined_field_validation(): instance.full_clean() +def test_money_field_default_money(): + instance = ModelWithDefault() + assert instance.price == Money(0, 'USD') + + +def test_money_field_default_money_deconstruct(): + instance = ModelWithDefault() + _, _, _, kwargs = instance._meta.get_field('price').deconstruct() + assert kwargs == { + 'currency': 'USD', 'default': '0', 'max_digits': 9, + 'decimal_places': 2} + + +def test_money_field_default_money_invalid_currency(): + with pytest.raises(ValueError): + class InvalidModel(models.Model): + price = MoneyField( + currency='USD', default=Money('0', 'BTC'), max_digits=9, + decimal_places=2) + + def test_field_passes_all_validations(): form = RequiredPriceForm(data={'price_net': '20'}) form.full_clean() From ce92d565d5d20da9fa5ca49487ff8ec310703e02 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafa=C5=82=20Pito=C5=84?= Date: Tue, 13 Mar 2018 15:33:24 +0100 Subject: [PATCH 2/2] Deconstruct default=Money to Decimal --- django_prices/models.py | 2 +- tests/test_prices.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/django_prices/models.py b/django_prices/models.py index 6f90bf1..131bc9c 100644 --- a/django_prices/models.py +++ b/django_prices/models.py @@ -73,7 +73,7 @@ def deconstruct(self): name, path, args, kwargs = super(MoneyField, self).deconstruct() kwargs['currency'] = self.currency if isinstance(kwargs.get('default'), Money): - kwargs['default'] = str(kwargs['default'].amount) + kwargs['default'] = kwargs['default'].amount return name, path, args, kwargs diff --git a/tests/test_prices.py b/tests/test_prices.py index c413ee8..7d619f7 100644 --- a/tests/test_prices.py +++ b/tests/test_prices.py @@ -206,7 +206,7 @@ def test_money_field_default_money_deconstruct(): instance = ModelWithDefault() _, _, _, kwargs = instance._meta.get_field('price').deconstruct() assert kwargs == { - 'currency': 'USD', 'default': '0', 'max_digits': 9, + 'currency': 'USD', 'default': Decimal(0), 'max_digits': 9, 'decimal_places': 2}