From 65c7e1d17c0f0e63e3038096a895a55a5224c7f1 Mon Sep 17 00:00:00 2001 From: Alexander VanTol Date: Thu, 3 Oct 2019 11:35:15 -0500 Subject: [PATCH] =?UTF-8?q?fix(group-list):=20fix=20issue=20with=20paginat?= =?UTF-8?q?ion=20logic=20for=20listing=20google=20g=E2=80=A6=20(#75)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * fix(group-list): fix issue with pagination logic for listing google groups * fix(groups): regression test, fix pagination logic * chore(refactor): use .get instead of explicit check --- cirrus/google_cloud/manager.py | 45 +++++++++++++++----------------- test/test_google_cloud_manage.py | 2 +- 2 files changed, 22 insertions(+), 25 deletions(-) diff --git a/cirrus/google_cloud/manager.py b/cirrus/google_cloud/manager.py index 747f4c6d..660afce9 100644 --- a/cirrus/google_cloud/manager.py +++ b/cirrus/google_cloud/manager.py @@ -747,12 +747,11 @@ def get_all_service_accounts(self): response = self._authed_request("GET", api_url).json() all_service_accounts.extend(response["accounts"]) - if "nextPageToken" in response: - while response["nextPageToken"]: - response = self._authed_request( - "GET", api_url + "&pageToken=" + response["nextPageToken"] - ).json() - all_service_accounts.extend(response["accounts"]) + while response.get("nextPageToken"): + response = self._authed_request( + "GET", api_url + "&pageToken=" + response["nextPageToken"] + ).json() + all_service_accounts.extend(response["accounts"]) return all_service_accounts @@ -1306,17 +1305,16 @@ def get_all_groups(self): ) all_groups.extend(response["groups"]) - if "nextPageToken" in response: - while response["nextPageToken"]: - response = ( - self._admin_service.groups() - .list( - pageToken=response["nextPageToken"], - domain=config.GOOGLE_IDENTITY_DOMAIN, - ) - .execute() + while response.get("nextPageToken"): + response = ( + self._admin_service.groups() + .list( + pageToken=response["nextPageToken"], + domain=config.GOOGLE_IDENTITY_DOMAIN, ) - all_groups.extend(response["groups"]) + .execute() + ) + all_groups.extend(response["groups"]) return all_groups @@ -1596,14 +1594,13 @@ def get_group_members(self, group_id): response = self._admin_service.members().list(groupKey=group_id).execute() all_members.extend(response.get("members", [])) - if "nextPageToken" in response: - while response["nextPageToken"]: - response = ( - self._admin_service.members() - .list(pageToken=response["nextPageToken"], groupKey=group_id) - .execute() - ) - all_members.extend(response.get("members", [])) + while response.get("nextPageToken"): + response = ( + self._admin_service.members() + .list(pageToken=response["nextPageToken"], groupKey=group_id) + .execute() + ) + all_members.extend(response.get("members", [])) return all_members diff --git a/test/test_google_cloud_manage.py b/test/test_google_cloud_manage.py index 697a5fa6..682ad5ed 100644 --- a/test/test_google_cloud_manage.py +++ b/test/test_google_cloud_manage.py @@ -742,7 +742,7 @@ def test_get_group_members_pagination(test_cloud_manager): response_2 = copy.deepcopy(full_response) response_2["members"][0]["id"] = member_3_id response_2["members"][1]["id"] = member_4_id - response_2["nextPageToken"] = "" + del response_2["nextPageToken"] two_pages = [full_response, response_2]