From 59b9633d6c28109687a6dbb86ea047fbd955cce8 Mon Sep 17 00:00:00 2001 From: Benjamin Gill Date: Tue, 14 Dec 2021 13:38:50 +0000 Subject: [PATCH 1/2] Add support for listing active users It's something we often do in scripts. I've just added support for it in the API. And update tests accordingly --- dmapiclient/data.py | 3 +++ tests/test_data_api_client.py | 24 +++++++++++++++++++++++- 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/dmapiclient/data.py b/dmapiclient/data.py index a5e5528..c07769d 100644 --- a/dmapiclient/data.py +++ b/dmapiclient/data.py @@ -390,6 +390,7 @@ def find_users( personal_data_removed=None, *, user_research_opted_in=None, + active=None, ): warnings.warn( "The output of 'find_users' is paginated. Use 'find_users_iter' instead.", @@ -410,6 +411,8 @@ def find_users( params['personal_data_removed'] = personal_data_removed if user_research_opted_in is not None: params['user_research_opted_in'] = user_research_opted_in + if active is not None: + params['active'] = active return self._get("/users", params=params) find_users_iter = make_iter_method('find_users', 'users') diff --git a/tests/test_data_api_client.py b/tests/test_data_api_client.py index f96a3b0..696f860 100644 --- a/tests/test_data_api_client.py +++ b/tests/test_data_api_client.py @@ -208,7 +208,7 @@ def user(): 'email_address': 'email_address', 'name': 'name', 'role': 'supplier', - 'active': 'active', + 'active': True, 'locked': False, 'created_at': "2015-05-05T05:05:05", 'updated_at': "2015-05-05T05:05:05", @@ -297,6 +297,28 @@ def test_find_users_by_user_research_opted_in_true(self, data_client, rmock): assert user == expected_data + def test_find_users_by_active_false(self, data_client, rmock): + rmock.get( + "http://baseurl/users?active=false", + json=self.user(), + status_code=200) + user = data_client.find_users(active=False) + + assert user == self.user() + + def test_find_users_by_active_true(self, data_client, rmock): + user = self.user() + user['users'].update({'active': True}) + expected_data = user.copy() + + rmock.get( + "http://baseurl/users?active=true", + json=user, + status_code=200) + user = data_client.find_users(active=True) + + assert user == expected_data + def test_get_user_by_id(self, data_client, rmock): rmock.get( "http://baseurl/users/1234", From d3bc0c7c8d24f80edf2e63911ab6d06b84c97773 Mon Sep 17 00:00:00 2001 From: Benjamin Gill Date: Tue, 14 Dec 2021 14:01:05 +0000 Subject: [PATCH 2/2] Bump version --- dmapiclient/__init__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/dmapiclient/__init__.py b/dmapiclient/__init__.py index b523a49..4650b04 100644 --- a/dmapiclient/__init__.py +++ b/dmapiclient/__init__.py @@ -1,4 +1,4 @@ -__version__ = '23.0.0' +__version__ = '23.1.0' from .errors import APIError, HTTPError, InvalidResponse # noqa from .errors import REQUEST_ERROR_STATUS_CODE, REQUEST_ERROR_MESSAGE # noqa