|
12 | 12 | DestructionListAssigneeFactory,
|
13 | 13 | DestructionListCoReviewFactory,
|
14 | 14 | DestructionListFactory,
|
| 15 | + ReviewResponseFactory, |
15 | 16 | )
|
16 | 17 |
|
17 | 18 |
|
@@ -52,6 +53,85 @@ def test_list_filter_destruction_list__uuid(self):
|
52 | 53 | self.assertEqual(len(response.data), 1)
|
53 | 54 | self.assertEqual(response.data[0]["pk"], co_review_related.pk)
|
54 | 55 |
|
| 56 | + def test_list_after_review_response(self): |
| 57 | + destruction_list = DestructionListFactory.create( |
| 58 | + status=ListStatus.ready_to_review |
| 59 | + ) |
| 60 | + # Co review response created on date 1 chronologically |
| 61 | + co_review_date_1 = DestructionListCoReviewFactory.create( |
| 62 | + destruction_list=destruction_list |
| 63 | + ) |
| 64 | + co_review_date_1.created = "1988-08-02T08:30:00+01:00" |
| 65 | + co_review_date_1.save() |
| 66 | + |
| 67 | + # Review response created on date 2 chronologically |
| 68 | + review_response_date_2 = ReviewResponseFactory.create( |
| 69 | + review__destruction_list=destruction_list, |
| 70 | + ) |
| 71 | + review_response_date_2.created = "1990-10-31T00:00:00+01:00" |
| 72 | + review_response_date_2.save() |
| 73 | + |
| 74 | + # Co review created on date 3 chronologically |
| 75 | + co_review_date_3 = DestructionListCoReviewFactory.create( |
| 76 | + destruction_list=destruction_list |
| 77 | + ) |
| 78 | + co_review_date_3.created = "2023-09-15T21:36:00+01:00" |
| 79 | + co_review_date_3.save() |
| 80 | + |
| 81 | + # Unrelated review response created now (date 4 chronologically, should not exclude co_review_date_3) |
| 82 | + ReviewResponseFactory.create() |
| 83 | + |
| 84 | + user = UserFactory() |
| 85 | + |
| 86 | + self.client.force_login(user) |
| 87 | + url = reverse("api:destruction-list-co-reviews-list") |
| 88 | + response = self.client.get( |
| 89 | + furl(url, args={"destruction_list__uuid": destruction_list.uuid}).url |
| 90 | + ) |
| 91 | + self.assertEqual(response.status_code, status.HTTP_200_OK) |
| 92 | + self.assertEqual(len(response.data), 1) |
| 93 | + self.assertEqual(response.data[0]["pk"], co_review_date_3.pk) |
| 94 | + |
| 95 | + def test_list_after_review_response_multiple(self): |
| 96 | + destruction_list = DestructionListFactory.create( |
| 97 | + status=ListStatus.ready_to_review |
| 98 | + ) |
| 99 | + # Co review response created on date 1 chronologically |
| 100 | + co_review_date_1 = DestructionListCoReviewFactory.create( |
| 101 | + destruction_list=destruction_list |
| 102 | + ) |
| 103 | + co_review_date_1.created = "1988-08-02T08:30:00+01:00" |
| 104 | + co_review_date_1.save() |
| 105 | + |
| 106 | + # Review response created now (date 4 chronologically, should exclude co_review_date_3) |
| 107 | + ReviewResponseFactory.create( |
| 108 | + review__destruction_list=destruction_list, |
| 109 | + ) |
| 110 | + |
| 111 | + # Review response created on date 2 chronologically |
| 112 | + review_response_date_2 = ReviewResponseFactory.create( |
| 113 | + review__destruction_list=destruction_list, |
| 114 | + ) |
| 115 | + review_response_date_2.created = "1990-10-31T00:00:00+01:00" |
| 116 | + review_response_date_2.save() |
| 117 | + |
| 118 | + # Co review created on date 3 chronologically |
| 119 | + co_review_date_3 = DestructionListCoReviewFactory.create( |
| 120 | + destruction_list=destruction_list |
| 121 | + ) |
| 122 | + co_review_date_3.created = "2023-09-15T21:36:00+01:00" |
| 123 | + co_review_date_3.save() |
| 124 | + |
| 125 | + user = UserFactory() |
| 126 | + |
| 127 | + self.client.force_login(user) |
| 128 | + url = reverse("api:destruction-list-co-reviews-list") |
| 129 | + response = self.client.get( |
| 130 | + furl(url, args={"destruction_list__uuid": destruction_list.uuid}).url |
| 131 | + ) |
| 132 | + self.assertEqual(response.status_code, status.HTTP_200_OK) |
| 133 | + self.assertEqual(len(response.data), 0) |
| 134 | + |
55 | 135 | def test_create_not_logged_in(self):
|
56 | 136 | co_reviewer = DestructionListAssigneeFactory.create(role=ListRole.co_reviewer)
|
57 | 137 | destruction_list = DestructionListFactory.create(
|
|
0 commit comments