Skip to content

Commit

Permalink
Move task creation into form_valid
Browse files Browse the repository at this point in the history
  • Loading branch information
SebastianKapunkt authored and codingjoe committed Oct 22, 2020
1 parent fbec668 commit 8d6d016
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 8 deletions.
19 changes: 11 additions & 8 deletions joeflow/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -56,19 +56,22 @@ def get_task(self):
except KeyError:
return models.Task(name=self.name, type=models.Task.HUMAN)

def get_object(self, queryset=None):
task = self.get_task()
return task.workflow

@transaction.atomic
def post(self, request, *args, **kwargs):
response = super().post(request, *args, **kwargs)
def next_task(self):
task = self.get_task()
task.workflow = self.model._base_manager.get(
pk=self.model._base_manager.get(pk=self.object.pk)
)
task.finish(request.user)
task.finish(self.request.user)
task.start_next_tasks()

def get_object(self, queryset=None):
task = self.get_task()
return task.workflow

@transaction.atomic
def form_valid(self, form):
response = super().form_valid(form)
self.next_task()
return response


Expand Down
17 changes: 17 additions & 0 deletions tests/test_views.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
from django.urls import reverse

from .testapp import models


class TestTaskViewMixin:
def test_create_task__form_errors(self, db, admin_client, admin_user):
url = reverse("shippingworkflow:checkout")
response = admin_client.post(
url, data={"shipping_address": 123, "email": "not a email"}
)
assert response.status_code == 200
assert response.context_data["form"].errors == {
"email": ["Enter a valid email address."]
}

assert models.Shipment.objects.count() == 0

0 comments on commit 8d6d016

Please sign in to comment.