diff --git a/backoffice/backoffice/workflows/api/serializers.py b/backoffice/backoffice/workflows/api/serializers.py index 4883d0b2..bf7bf9f5 100644 --- a/backoffice/backoffice/workflows/api/serializers.py +++ b/backoffice/backoffice/workflows/api/serializers.py @@ -24,19 +24,20 @@ def get_ticket_url(self, obj): ) -class WorkflowSerializer(serializers.ModelSerializer): - tickets = WorkflowTicketSerializer(many=True, read_only=True) +class DecisionSerializer(serializers.ModelSerializer): + workflow = serializers.PrimaryKeyRelatedField(queryset=Workflow.objects.all()) class Meta: - model = Workflow + model = Decision fields = "__all__" -class DecisionSerializer(serializers.ModelSerializer): - workflow = serializers.PrimaryKeyRelatedField(queryset=Workflow.objects.all()) +class WorkflowSerializer(serializers.ModelSerializer): + tickets = WorkflowTicketSerializer(many=True, read_only=True) + decisions = DecisionSerializer(many=True, read_only=True) class Meta: - model = Decision + model = Workflow fields = "__all__" diff --git a/backoffice/backoffice/workflows/migrations/0010_alter_decision_workflow_and_more.py b/backoffice/backoffice/workflows/migrations/0010_alter_decision_workflow_and_more.py new file mode 100644 index 00000000..a9cefea0 --- /dev/null +++ b/backoffice/backoffice/workflows/migrations/0010_alter_decision_workflow_and_more.py @@ -0,0 +1,31 @@ +# Generated by Django 4.2.6 on 2024-08-23 13:02 + +import django.db.models.deletion +from django.db import migrations, models + + +class Migration(migrations.Migration): + dependencies = [ + ("workflows", "0009_decision"), + ] + + operations = [ + migrations.AlterField( + model_name="decision", + name="workflow", + field=models.ForeignKey( + on_delete=django.db.models.deletion.CASCADE, + related_name="decisions", + to="workflows.workflow", + ), + ), + migrations.AlterField( + model_name="workflowticket", + name="workflow_id", + field=models.ForeignKey( + on_delete=django.db.models.deletion.CASCADE, + related_name="tickets", + to="workflows.workflow", + ), + ), + ] diff --git a/backoffice/backoffice/workflows/models.py b/backoffice/backoffice/workflows/models.py index 590c831d..d4fb3704 100644 --- a/backoffice/backoffice/workflows/models.py +++ b/backoffice/backoffice/workflows/models.py @@ -49,9 +49,14 @@ class WorkflowTicket(models.Model): class Decision(models.Model): user = models.ForeignKey( - User, to_field="email", db_column="email", on_delete=models.CASCADE + User, + to_field="email", + db_column="email", + on_delete=models.CASCADE, + ) + workflow = models.ForeignKey( + Workflow, related_name="decisions", on_delete=models.CASCADE ) - workflow = models.ForeignKey(Workflow, on_delete=models.CASCADE) action = models.CharField(max_length=30, choices=DECISION_CHOICES) _created_at = models.DateTimeField(auto_now_add=True) diff --git a/backoffice/backoffice/workflows/tests/test_views.py b/backoffice/backoffice/workflows/tests/test_views.py index a0ac4aab..d9395e95 100644 --- a/backoffice/backoffice/workflows/tests/test_views.py +++ b/backoffice/backoffice/workflows/tests/test_views.py @@ -22,6 +22,7 @@ from backoffice.workflows.constants import ( WORKFLOW_DAGS, AuthorCreateDags, + ResolutionDags, StatusChoices, WorkflowType, ) @@ -100,6 +101,15 @@ def test_tickets(self): assert "ticket_id" in workflow_data["tickets"][0] assert "ticket_type" in workflow_data["tickets"][0] + def test_decisions(self): + Decision.objects.create( + workflow=self.workflow, user=self.user, action=ResolutionDags.accept + ) + workflow_data = WorkflowSerializer(self.workflow).data + assert "decisions" in workflow_data + assert "action" in workflow_data["decisions"][0] + assert "user" in workflow_data["decisions"][0] + @pytest.mark.vcr() def test_delete(self): self.api_client.force_authenticate(user=self.curator)