diff options
| author | 2022-12-04 13:19:08 +0300 | |
|---|---|---|
| committer | 2022-12-04 13:19:08 +0300 | |
| commit | 92a9669ee06ea6341082aaceb6f2d2ad5585d007 (patch) | |
| tree | f45b37e10e0e59822a795d5a9a2e0bc403501a23 /pydis_site/apps/api/tests | |
| parent | Update pydis_site/apps/content/resources/guides/python-guides/docker-hosting-... (diff) | |
| parent | Rename vps_services.md to vps-services.md (#808) (diff) | |
Merge branch 'python-discord:main' into main
Diffstat (limited to 'pydis_site/apps/api/tests')
| -rw-r--r-- | pydis_site/apps/api/tests/test_github_utils.py | 7 | ||||
| -rw-r--r-- | pydis_site/apps/api/tests/test_users.py | 84 | 
2 files changed, 88 insertions, 3 deletions
| diff --git a/pydis_site/apps/api/tests/test_github_utils.py b/pydis_site/apps/api/tests/test_github_utils.py index 2eaf48d9..95bafec0 100644 --- a/pydis_site/apps/api/tests/test_github_utils.py +++ b/pydis_site/apps/api/tests/test_github_utils.py @@ -11,6 +11,7 @@ import rest_framework.response  import rest_framework.test  from django.urls import reverse +from pydis_site import settings  from .. import github_utils @@ -49,7 +50,7 @@ class CheckRunTests(unittest.TestCase):          "head_sha": "sha",          "status": "completed",          "conclusion": "success", -        "created_at": datetime.datetime.utcnow().strftime(github_utils.ISO_FORMAT_STRING), +        "created_at": datetime.datetime.utcnow().strftime(settings.GITHUB_TIMESTAMP_FORMAT),          "artifacts_url": "url",      } @@ -74,7 +75,7 @@ class CheckRunTests(unittest.TestCase):          # to guarantee the right conclusion          kwargs["created_at"] = (              datetime.datetime.utcnow() - github_utils.MAX_RUN_TIME - datetime.timedelta(minutes=10) -        ).strftime(github_utils.ISO_FORMAT_STRING) +        ).strftime(settings.GITHUB_TIMESTAMP_FORMAT)          with self.assertRaises(github_utils.RunTimeoutError):              github_utils.check_run_status(github_utils.WorkflowRun(**kwargs)) @@ -178,7 +179,7 @@ class ArtifactFetcherTests(unittest.TestCase):                  run = github_utils.WorkflowRun(                      name="action_name",                      head_sha="action_sha", -                    created_at=datetime.datetime.now().strftime(github_utils.ISO_FORMAT_STRING), +                    created_at=datetime.datetime.now().strftime(settings.GITHUB_TIMESTAMP_FORMAT),                      status="completed",                      conclusion="success",                      artifacts_url="artifacts_url" diff --git a/pydis_site/apps/api/tests/test_users.py b/pydis_site/apps/api/tests/test_users.py index 5d10069d..d86e80bb 100644 --- a/pydis_site/apps/api/tests/test_users.py +++ b/pydis_site/apps/api/tests/test_users.py @@ -502,6 +502,90 @@ class UserMetricityTests(AuthenticatedAPITestCase):              "total_messages": total_messages          }) +    def test_metricity_activity_data(self): +        # Given +        self.mock_no_metricity_user()  # Other functions shouldn't be used. +        self.metricity.total_messages_in_past_n_days.return_value = [(0, 10)] + +        # When +        url = reverse("api:bot:user-metricity-activity-data") +        response = self.client.post( +            url, +            data=[0, 1], +            QUERY_STRING="days=10", +        ) + +        # Then +        self.assertEqual(response.status_code, 200) +        self.metricity.total_messages_in_past_n_days.assert_called_once_with(["0", "1"], 10) +        self.assertEqual(response.json(), {"0": 10, "1": 0}) + +    def test_metricity_activity_data_invalid_days(self): +        # Given +        self.mock_no_metricity_user()  # Other functions shouldn't be used. + +        # When +        url = reverse("api:bot:user-metricity-activity-data") +        response = self.client.post( +            url, +            data=[0, 1], +            QUERY_STRING="days=fifty", +        ) + +        # Then +        self.assertEqual(response.status_code, 400) +        self.metricity.total_messages_in_past_n_days.assert_not_called() +        self.assertEqual(response.json(), {"days": ["This query parameter must be an integer."]}) + +    def test_metricity_activity_data_no_days(self): +        # Given +        self.mock_no_metricity_user()  # Other functions shouldn't be used. + +        # When +        url = reverse('api:bot:user-metricity-activity-data') +        response = self.client.post( +            url, +            data=[0, 1], +        ) + +        # Then +        self.assertEqual(response.status_code, 400) +        self.metricity.total_messages_in_past_n_days.assert_not_called() +        self.assertEqual(response.json(), {'days': ["This query parameter is required."]}) + +    def test_metricity_activity_data_no_users(self): +        # Given +        self.mock_no_metricity_user()  # Other functions shouldn't be used. + +        # When +        url = reverse('api:bot:user-metricity-activity-data') +        response = self.client.post( +            url, +            QUERY_STRING="days=10", +        ) + +        # Then +        self.assertEqual(response.status_code, 400) +        self.metricity.total_messages_in_past_n_days.assert_not_called() +        self.assertEqual(response.json(), ['Expected a list of items but got type "dict".']) + +    def test_metricity_activity_data_invalid_users(self): +        # Given +        self.mock_no_metricity_user()  # Other functions shouldn't be used. + +        # When +        url = reverse('api:bot:user-metricity-activity-data') +        response = self.client.post( +            url, +            data=[123, 'username'], +            QUERY_STRING="days=10", +        ) + +        # Then +        self.assertEqual(response.status_code, 400) +        self.metricity.total_messages_in_past_n_days.assert_not_called() +        self.assertEqual(response.json(), {'1': ['A valid integer is required.']}) +      def mock_metricity_user(self, joined_at, total_messages, total_blocks, top_channel_activity):          patcher = patch("pydis_site.apps.api.viewsets.bot.user.Metricity")          self.metricity = patcher.start() | 
