|
3 | 3 | # SPDX-License-Identifier: Apache-2.0
|
4 | 4 | #
|
5 | 5 | """Test Reporting Common."""
|
| 6 | +from unittest.mock import MagicMock |
6 | 7 | from unittest.mock import patch
|
7 | 8 |
|
8 | 9 | from django.utils import timezone
|
|
19 | 20 | from reporting_common.models import CostUsageReportManifest
|
20 | 21 | from reporting_common.models import CostUsageReportStatus
|
21 | 22 | from reporting_common.models import DelayedCeleryTasks
|
| 23 | +from reporting_common.models import trigger_celery_task |
22 | 24 |
|
23 | 25 |
|
24 | 26 | class TestCostUsageReportStatus(MasuTestCase):
|
@@ -156,3 +158,35 @@ def test_large_customer(self, mock_large_customer):
|
156 | 158 | with schema_context(self.schema):
|
157 | 159 | db_entry = DelayedCeleryTasks.objects.get(provider_uuid=self.aws_provider.uuid)
|
158 | 160 | self.assertEqual(db_entry.queue_name, UPDATE_SUMMARY_TABLES_QUEUE_XL)
|
| 161 | + |
| 162 | + @patch("reporting_common.models.celery_app") |
| 163 | + def test_trigger_celery_task(self, mock_celery_app): |
| 164 | + # Building Mocks |
| 165 | + result = MagicMock() |
| 166 | + result.id = "mocked_result_id" |
| 167 | + mock_celery_app.send_task.return_value = result |
| 168 | + # Building Test data |
| 169 | + expected_task_name = "test_task" |
| 170 | + expected_args = ["arg1", "arg2"] |
| 171 | + expected_task_kwargs = {"tracing_id": "123"} |
| 172 | + expected_queue = "test_queue" |
| 173 | + task_instance = DelayedCeleryTasks.create_or_reset_timeout( |
| 174 | + task_name=expected_task_name, |
| 175 | + task_args=expected_args, |
| 176 | + task_kwargs=expected_task_kwargs, |
| 177 | + provider_uuid=self.aws_provider_uuid, |
| 178 | + queue_name=expected_queue, |
| 179 | + ) |
| 180 | + |
| 181 | + with self.assertLogs("reporting_common.models", level="INFO") as cm: |
| 182 | + trigger_celery_task(sender=None, instance=task_instance) |
| 183 | + |
| 184 | + log_message = "delay period ended starting task" |
| 185 | + self.assertTrue(any(log_message in log for log in cm.output)) |
| 186 | + |
| 187 | + mock_celery_app.send_task.assert_called_once_with( |
| 188 | + task_instance.task_name, |
| 189 | + args=task_instance.task_args, |
| 190 | + kwargs=task_instance.task_kwargs, |
| 191 | + queue=task_instance.queue_name, |
| 192 | + ) |
0 commit comments