From e33574cff296b6506e398060bb17173b03b53515 Mon Sep 17 00:00:00 2001 From: Santos Gallegos Date: Wed, 30 Oct 2024 14:24:09 -0500 Subject: [PATCH 1/2] API v3: remove last_build expandable field --- docs/user/api/v3.rst | 9 ++---- readthedocs/api/v3/serializers.py | 3 +- .../v3/tests/responses/projects-detail.json | 29 ------------------- readthedocs/api/v3/tests/test_projects.py | 29 ++++--------------- readthedocs/api/v3/views.py | 6 ---- 5 files changed, 8 insertions(+), 68 deletions(-) diff --git a/docs/user/api/v3.rst b/docs/user/api/v3.rst index 238b0046e6a..e79e4cd3225 100644 --- a/docs/user/api/v3.rst +++ b/docs/user/api/v3.rst @@ -287,8 +287,8 @@ Project details } :query string expand: Add additional fields in the response. - Allowed values are ``active_versions``, ``active_versions.last_build`` and - ``active_versions.last_build.config``. Multiple fields can be passed separated by commas. + Allowed values are: ``active_versions``. + Multiple fields can be passed separated by commas. .. note:: @@ -588,7 +588,6 @@ Version detail "aliases": ["VERSION"], "hidden": false, "type": "tag", - "last_build": "{BUILD}", "privacy_level": "public", "downloads": { "pdf": "https://pip.readthedocs.io/_/downloads/pdf/pip/stable/", @@ -613,10 +612,6 @@ Version detail ``null`` when it's not the stable version. :>json boolean built: the version has at least one successful build. - :query string expand: Add additional fields in the response. - Allowed values are ``last_build`` and ``last_build.config``. - Multiple fields can be passed separated by commas. - Version update ++++++++++++++ diff --git a/readthedocs/api/v3/serializers.py b/readthedocs/api/v3/serializers.py index a5d9c0c0301..a436eeeaec6 100644 --- a/readthedocs/api/v3/serializers.py +++ b/readthedocs/api/v3/serializers.py @@ -357,8 +357,6 @@ class Meta: "privacy_level", ] - expandable_fields = {"last_build": (BuildSerializer,)} - def __init__(self, *args, resolver=None, version_serializer=None, **kwargs): super().__init__(*args, **kwargs) @@ -753,6 +751,7 @@ class ProjectSerializer(FlexFieldsModelSerializer): programming_language = ProgrammingLanguageSerializer() repository = RepositorySerializer(source="*") urls = ProjectURLsSerializer(source="*") + # These should check for permissions! subproject_of = serializers.SerializerMethodField() translation_of = serializers.SerializerMethodField() default_branch = serializers.CharField(source="get_default_branch") diff --git a/readthedocs/api/v3/tests/responses/projects-detail.json b/readthedocs/api/v3/tests/responses/projects-detail.json index a3c9e4046e1..897adf558cd 100644 --- a/readthedocs/api/v3/tests/responses/projects-detail.json +++ b/readthedocs/api/v3/tests/responses/projects-detail.json @@ -12,35 +12,6 @@ }, "id": 2, "identifier": "a1b2c3", - "last_build": { - "commit": "a1b2c3", - "config": { - "property": "test value" - }, - "created": "2019-04-29T10:00:00Z", - "duration": 60, - "error": "", - "finished": "2019-04-29T10:01:00Z", - "id": 1, - "_links": { - "_self": "https://readthedocs.org/api/v3/projects/project/builds/1/", - "notifications": "https://readthedocs.org/api/v3/projects/project/builds/1/notifications/", - "project": "https://readthedocs.org/api/v3/projects/project/", - "version": "https://readthedocs.org/api/v3/projects/project/versions/v1.0/" - }, - "urls": { - "build": "https://readthedocs.org/projects/project/builds/1/", - "project": "https://readthedocs.org/projects/project/", - "version": "https://readthedocs.org/dashboard/project/version/v1.0/edit/" - }, - "project": "project", - "state": { - "code": "finished", - "name": "Finished" - }, - "success": true, - "version": "v1.0" - }, "_links": { "_self": "https://readthedocs.org/api/v3/projects/project/versions/v1.0/", "builds": "https://readthedocs.org/api/v3/projects/project/versions/v1.0/builds/", diff --git a/readthedocs/api/v3/tests/test_projects.py b/readthedocs/api/v3/tests/test_projects.py index 08ba349c687..67e725fca77 100644 --- a/readthedocs/api/v3/tests/test_projects.py +++ b/readthedocs/api/v3/tests/test_projects.py @@ -108,12 +108,7 @@ def test_projects_detail_anonymous_user(self): }, ) data = { - "expand": ( - "active_versions," - "active_versions.last_build," - "active_versions.last_build.config," - "permissions" - ), + "expand": ("active_versions," "permissions"), } expected_response = self._get_response_dict("projects-detail") expected_response["permissions"]["admin"] = False @@ -138,12 +133,7 @@ def test_projects_detail(self): }, ) data = { - "expand": ( - "active_versions," - "active_versions.last_build," - "active_versions.last_build.config," - "permissions" - ), + "expand": ("active_versions," "permissions"), } expected_response = self._get_response_dict("projects-detail") @@ -170,12 +160,7 @@ def test_projects_detail_other_user(self): }, ) data = { - "expand": ( - "active_versions," - "active_versions.last_build," - "active_versions.last_build.config," - "permissions" - ), + "expand": ("active_versions," "permissions"), } expected_response = self._get_response_dict("projects-detail") expected_response["permissions"]["admin"] = False @@ -203,12 +188,7 @@ def test_own_projects_detail_privacy_levels_enabled(self): }, ) query_params = { - "expand": ( - "active_versions," - "active_versions.last_build," - "active_versions.last_build.config," - "permissions" - ), + "expand": ("active_versions," "permissions"), } self.client.credentials(HTTP_AUTHORIZATION=f"Token {self.token.key}") @@ -304,6 +284,7 @@ def test_projects_superproject_other_user(self): response = self.client.get(url) self.assertEqual(response.status_code, 404) + # NOTE: this test is slow def test_projects_sync_versions(self): # Ensure a default version exists to sync self.project.update_latest_version() diff --git a/readthedocs/api/v3/views.py b/readthedocs/api/v3/views.py index 5bdc9f7f52d..b654054ed8e 100644 --- a/readthedocs/api/v3/views.py +++ b/readthedocs/api/v3/views.py @@ -133,8 +133,6 @@ class ProjectsViewSetBase( filterset_class = ProjectFilter permit_list_expands = [ "active_versions", - "active_versions.last_build", - "active_versions.last_build.config", "organization", "permissions", "teams", @@ -356,10 +354,6 @@ class VersionsViewSet( filterset_class = VersionFilter permission_classes = [ReadOnlyPermission | (IsAuthenticated & IsProjectAdmin)] - permit_list_expands = [ - "last_build", - "last_build.config", - ] def get_serializer_class(self): """ From 832d603acd3daf4759677119ba9020c95a2a08c7 Mon Sep 17 00:00:00 2001 From: Santos Gallegos Date: Wed, 30 Oct 2024 15:13:18 -0500 Subject: [PATCH 2/2] Remove internal notes --- readthedocs/api/v3/serializers.py | 1 - readthedocs/api/v3/tests/test_projects.py | 1 - 2 files changed, 2 deletions(-) diff --git a/readthedocs/api/v3/serializers.py b/readthedocs/api/v3/serializers.py index a436eeeaec6..133506f2b6f 100644 --- a/readthedocs/api/v3/serializers.py +++ b/readthedocs/api/v3/serializers.py @@ -751,7 +751,6 @@ class ProjectSerializer(FlexFieldsModelSerializer): programming_language = ProgrammingLanguageSerializer() repository = RepositorySerializer(source="*") urls = ProjectURLsSerializer(source="*") - # These should check for permissions! subproject_of = serializers.SerializerMethodField() translation_of = serializers.SerializerMethodField() default_branch = serializers.CharField(source="get_default_branch") diff --git a/readthedocs/api/v3/tests/test_projects.py b/readthedocs/api/v3/tests/test_projects.py index 67e725fca77..79563470fb0 100644 --- a/readthedocs/api/v3/tests/test_projects.py +++ b/readthedocs/api/v3/tests/test_projects.py @@ -284,7 +284,6 @@ def test_projects_superproject_other_user(self): response = self.client.get(url) self.assertEqual(response.status_code, 404) - # NOTE: this test is slow def test_projects_sync_versions(self): # Ensure a default version exists to sync self.project.update_latest_version()