8

Use a form to clean the instance

This commit is contained in:
Todd Dembrey
2017-10-23 15:00:31 +01:00
parent c6ff2801c5
commit 44cc95617e
3 changed files with 54 additions and 19 deletions

View File

@@ -5,7 +5,9 @@ import datetime
import pytest
from django.core.exceptions import ValidationError
from django.forms.models import model_to_dict
from tests.factories.segment import SegmentFactory
from wagtail_personalisation.forms import SegmentAdminForm
from wagtail_personalisation.models import Segment
from wagtail_personalisation.rules import TimeRule, VisitCountRule
@@ -125,37 +127,54 @@ def test_does_not_calculate_the_segment_again(rf, site, client, mocker):
assert mock_test_rule.call_count == 0
def form_with_data(segment, rule):
model_fields = ['type', 'status', 'count', 'name']
class TestSegmentAdminForm(SegmentAdminForm):
class Meta:
model = Segment
fields = model_fields
data = model_to_dict(segment, model_fields)
for formset in TestSegmentAdminForm().formsets.values():
rule_data = {}
if isinstance(rule, formset.model):
rule_data = model_to_dict(rule)
for key, value in rule_data.items():
data['{}-0-{}'.format(formset.prefix, key)] = value
data['{}-INITIAL_FORMS'.format(formset.prefix)] = 0
data['{}-TOTAL_FORMS'.format(formset.prefix)] = 1 if rule_data else 0
return TestSegmentAdminForm(data)
@pytest.mark.django_db
def test_non_static_rules_have_a_count():
segment = SegmentFactory(type=Segment.TYPE_STATIC, count=0)
TimeRule.objects.create(
rule = TimeRule.objects.create(
start_time=datetime.time(0, 0, 0),
end_time=datetime.time(23, 59, 59),
segment=segment,
)
with pytest.raises(ValidationError):
segment.clean()
form = form_with_data(segment, rule)
assert not form.is_valid()
@pytest.mark.django_db
def test_static_segment_with_static_rules_needs_no_count(site):
segment = SegmentFactory(type=Segment.TYPE_STATIC, count=0)
VisitCountRule.objects.create(counted_page=site.root_page, segment=segment)
try:
segment.clean()
except ValidationError:
pytest.fail('Should not raise ValidationError.')
rule = VisitCountRule.objects.create(counted_page=site.root_page, segment=segment)
form = form_with_data(segment, rule)
assert form.is_valid()
@pytest.mark.django_db
def test_dynamic_segment_with_non_static_rules_have_a_count():
segment = SegmentFactory(type=Segment.TYPE_DYNAMIC, count=0)
TimeRule.objects.create(
rule = TimeRule.objects.create(
start_time=datetime.time(0, 0, 0),
end_time=datetime.time(23, 59, 59),
segment=segment,
)
try:
segment.clean()
except ValidationError:
pytest.fail('Should not raise ValidationError.')
form = form_with_data(segment, rule)
assert form.is_valid(), form.errors