From 35d8f38dbd04a51d9a8aa7995404c7e029c6f519 Mon Sep 17 00:00:00 2001 From: gorsutlame Date: Fri, 22 Mar 2024 17:36:56 +0700 Subject: [PATCH 1/4] THEME-KIT #20 | add retry when rate limit --- ntk/gateway.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/ntk/gateway.py b/ntk/gateway.py index a883d09..2edfdd3 100644 --- a/ntk/gateway.py +++ b/ntk/gateway.py @@ -14,7 +14,10 @@ def _request(self, request_type, url, apikey=None, payload={}, files={}): if apikey: headers = {'Authorization': f'Bearer {apikey}'} - return requests.request(request_type, url, headers=headers, data=payload, files=files) + response = requests.request(request_type, url, headers=headers, data=payload, files=files) + if response.status_code == 429 and "throttled" in response.content.decode(): + return self._request(request_type, url, apikey, payload, files) + return response @check_error(error_format='Missing Themes in {store}') def get_themes(self): From a50692f5a2b49f0576a20a1a4367debfdc639f94 Mon Sep 17 00:00:00 2001 From: gorsutlame Date: Fri, 22 Mar 2024 17:37:13 +0700 Subject: [PATCH 2/4] THEME-KIT #20 | change version --- setup.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/setup.py b/setup.py index 0bbc64c..43104d9 100644 --- a/setup.py +++ b/setup.py @@ -1,6 +1,6 @@ from setuptools import find_packages, setup -__version__ = '1.0.3' +__version__ = '1.0.4' tests_require = [ "flake8==3.9.2", From 6f7f5df1ceaec6b7f6349aeba48e201d281ccbae Mon Sep 17 00:00:00 2001 From: gorsutlame Date: Fri, 22 Mar 2024 17:37:35 +0700 Subject: [PATCH 3/4] THEME-KIT #20 | update test --- tests/test_command.py | 5 +--- tests/test_gateway.py | 55 ++++++++++++++++++++++++++++++++++++++----- 2 files changed, 50 insertions(+), 10 deletions(-) diff --git a/tests/test_command.py b/tests/test_command.py index 23006fc..6d828c4 100644 --- a/tests/test_command.py +++ b/tests/test_command.py @@ -345,11 +345,10 @@ def test_watch_command_should_call_gateway_with_correct_arguments_belong_to_file theme_id=1234, template_name='layout/base.html') self.assertIn(expected_call_deleted, self.mock_gateway.mock_calls) - @patch("ntk.command.time", autospec=True) @patch("ntk.command.Command._get_accept_files", autospec=True) @patch("builtins.open", autospec=True) def test_watch_command_with_create_image_file_should_call_gateway_with_correct_arguments( - self, mock_open_file, mock_get_accept_file, mock_time + self, mock_open_file, mock_get_accept_file ): mock_get_accept_file.return_value = [ f'{os.getcwd()}/assets/image.jpg', @@ -372,8 +371,6 @@ def test_watch_command_with_create_image_file_should_call_gateway_with_correct_a ) self.assertIn(expected_call_added, self.mock_gateway.mock_calls) - mock_time.sleep.assert_called_once_with(0.07) - @patch("ntk.command.Command._get_accept_files", autospec=True) @patch("ntk.command.Command._compile_sass", autospec=True) def test_watch_command_with_sass_directory_should_call_compile_sass( diff --git a/tests/test_gateway.py b/tests/test_gateway.py index 6e00fae..bfc04a8 100644 --- a/tests/test_gateway.py +++ b/tests/test_gateway.py @@ -27,13 +27,56 @@ def test_request(self, mock_request): self.gateway._request(request_type, url, apikey=self.apikey, payload=payload, files=files) - expected_calls = [call( - 'POST', 'http://simple.com/api/admin/themes/5/templates/', - headers={'Authorization': 'Bearer apikey'}, - data={'name': 'assets/base.html', 'content': '{% load i18n %}\n\n
My home page
'}, - files=files) + expected_calls = [ + call( + 'POST', 'http://simple.com/api/admin/themes/5/templates/', + headers={'Authorization': 'Bearer apikey'}, + data={ + 'name': 'assets/base.html', 'content': '{% load i18n %}\n\n
My home page
'}, + files=files), + call().status_code.__eq__(429) ] - self.assertEqual(mock_request.mock_calls, expected_calls) + assert mock_request.mock_calls == expected_calls + + @patch('ntk.gateway.requests.request', autospec=True) + def test_request_with_rate_limit_should_retry(self, mock_request): + mock_response_429 = MagicMock() + mock_response_429.status_code = 429 + mock_response_429.content.decode.return_value = "throttled" + + # Mock the response for the second call with status code 200 + mock_response_200 = MagicMock() + mock_response_200.status_code = 200 + + mock_request.side_effect = [mock_response_429, mock_response_200] + + request_type = 'POST' + url = 'http://simple.com/api/admin/themes/5/templates/' + payload = { + 'name': 'assets/base.html', + 'content': '{% load i18n %}\n\n
My home page
' + } + files = {'file': ('assets/image.jpg', self.mock_img_file)} + + self.gateway._request(request_type, url, apikey=self.apikey, payload=payload, files=files) + + assert mock_request.call_count == 2 + + expected_calls = [ + call( + 'POST', 'http://simple.com/api/admin/themes/5/templates/', + headers={'Authorization': 'Bearer apikey'}, + data={ + 'name': 'assets/base.html', 'content': '{% load i18n %}\n\n
My home page
' + }, files=files), + call( + 'POST', 'http://simple.com/api/admin/themes/5/templates/', + headers={'Authorization': 'Bearer apikey'}, + data={ + 'name': 'assets/base.html', 'content': '{% load i18n %}\n\n
My home page
' + }, files=files) + ] + assert mock_request.mock_calls == expected_calls ##### # get_themes From 52c6be0e2be0b0e0154f80ef89543c9b4822a36d Mon Sep 17 00:00:00 2001 From: gorsutlame Date: Fri, 22 Mar 2024 17:40:20 +0700 Subject: [PATCH 4/4] THEME-KIT #20 | update test --- tests/test_gateway.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/tests/test_gateway.py b/tests/test_gateway.py index bfc04a8..5ea866c 100644 --- a/tests/test_gateway.py +++ b/tests/test_gateway.py @@ -17,6 +17,11 @@ def setUp(self): ##### @patch('ntk.gateway.requests.request', autospec=True) def test_request(self, mock_request): + mock_response_200 = MagicMock() + mock_response_200.status_code = 200 + + mock_request.return_value = mock_response_200 + request_type = 'POST' url = 'http://simple.com/api/admin/themes/5/templates/' payload = { @@ -33,8 +38,7 @@ def test_request(self, mock_request): headers={'Authorization': 'Bearer apikey'}, data={ 'name': 'assets/base.html', 'content': '{% load i18n %}\n\n
My home page
'}, - files=files), - call().status_code.__eq__(429) + files=files) ] assert mock_request.mock_calls == expected_calls