cli2 3.3.42__tar.gz → 3.3.45__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {cli2-3.3.42/cli2.egg-info → cli2-3.3.45}/PKG-INFO +1 -1
- {cli2-3.3.42 → cli2-3.3.45}/cli2/client.py +9 -15
- {cli2-3.3.42 → cli2-3.3.45}/cli2/command.py +13 -14
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_client.py +6 -9
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_command.py +27 -0
- {cli2-3.3.42 → cli2-3.3.45/cli2.egg-info}/PKG-INFO +1 -1
- {cli2-3.3.42 → cli2-3.3.45}/setup.py +1 -1
- {cli2-3.3.42 → cli2-3.3.45}/MANIFEST.in +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/README.rst +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/classifiers.txt +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/__init__.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/argument.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/asyncio.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/cli.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/colors.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/configuration.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/decorators.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/display.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/entry_point.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/example_client.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/example_client_complex.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/example_nesting.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/example_obj.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/group.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/logging.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/node.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/overrides.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/sphinx.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/table.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_cli.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_configuration.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_decorators.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_display.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_entry_point.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_group.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_inject.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_node.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2/test_table.py +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/SOURCES.txt +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/dependency_links.txt +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/entry_points.txt +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/requires.txt +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/top_level.txt +0 -0
- {cli2-3.3.42 → cli2-3.3.45}/setup.cfg +0 -0
|
@@ -168,7 +168,7 @@ class Paginator:
|
|
|
168
168
|
:param data: Data of the first response
|
|
169
169
|
"""
|
|
170
170
|
|
|
171
|
-
def pagination_parameters(self, page_number):
|
|
171
|
+
def pagination_parameters(self, params, page_number):
|
|
172
172
|
"""
|
|
173
173
|
Return GET parameters for a given page.
|
|
174
174
|
|
|
@@ -180,12 +180,15 @@ class Paginator:
|
|
|
180
180
|
|
|
181
181
|
.. code-block:: python
|
|
182
182
|
|
|
183
|
-
def pagination_parameters(self, page_number):
|
|
183
|
+
def pagination_parameters(self, params, page_number):
|
|
184
184
|
# this is the default implementation
|
|
185
|
-
|
|
185
|
+
params['page'] = page_number
|
|
186
|
+
|
|
187
|
+
:param params: Dict of base GET parameters
|
|
188
|
+
:param page_number: Page number to get
|
|
186
189
|
"""
|
|
187
190
|
if page_number > 1:
|
|
188
|
-
|
|
191
|
+
params['page'] = page_number
|
|
189
192
|
|
|
190
193
|
def response_items(self, response):
|
|
191
194
|
"""
|
|
@@ -228,10 +231,7 @@ class Paginator:
|
|
|
228
231
|
|
|
229
232
|
:param page_number: Page number to get the items from
|
|
230
233
|
"""
|
|
231
|
-
|
|
232
|
-
return self.response_items(await self.page_response(page_number))
|
|
233
|
-
except NotImplementedError:
|
|
234
|
-
return []
|
|
234
|
+
return self.response_items(await self.page_response(page_number))
|
|
235
235
|
|
|
236
236
|
async def page_response(self, page_number):
|
|
237
237
|
"""
|
|
@@ -240,13 +240,7 @@ class Paginator:
|
|
|
240
240
|
:param page_number: Page number to get the items from
|
|
241
241
|
"""
|
|
242
242
|
params = self.params.copy()
|
|
243
|
-
|
|
244
|
-
if pagination_parameters:
|
|
245
|
-
params.update(pagination_parameters)
|
|
246
|
-
elif page_number != 1:
|
|
247
|
-
raise NotImplementedError(
|
|
248
|
-
'pagination_parameters returned None, cannot paginate',
|
|
249
|
-
)
|
|
243
|
+
self.pagination_parameters(params, page_number)
|
|
250
244
|
for expression in self.expressions:
|
|
251
245
|
if expression.parameterable:
|
|
252
246
|
expression.params(params)
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import asyncio
|
|
2
2
|
import inspect
|
|
3
|
-
import sys
|
|
4
3
|
|
|
5
4
|
from docstring_parser import parse
|
|
6
5
|
|
|
@@ -278,7 +277,14 @@ class Command(EntryPoint, dict):
|
|
|
278
277
|
return self.help()
|
|
279
278
|
|
|
280
279
|
if self.async_mode():
|
|
281
|
-
|
|
280
|
+
try:
|
|
281
|
+
return asyncio.run(self.async_call(*argv))
|
|
282
|
+
except KeyboardInterrupt:
|
|
283
|
+
print('exiting cleanly...')
|
|
284
|
+
self.exit_code = 1
|
|
285
|
+
return
|
|
286
|
+
finally:
|
|
287
|
+
self.post_result = asyncio.run(async_resolve(self.post_call()))
|
|
282
288
|
|
|
283
289
|
error = self.parse(*argv)
|
|
284
290
|
if error:
|
|
@@ -296,12 +302,12 @@ class Command(EntryPoint, dict):
|
|
|
296
302
|
for _ in result:
|
|
297
303
|
display.print(_)
|
|
298
304
|
result = None
|
|
305
|
+
return result
|
|
299
306
|
except KeyboardInterrupt:
|
|
300
|
-
print('exiting')
|
|
301
|
-
|
|
307
|
+
print('exiting cleanly...')
|
|
308
|
+
self.exit_code = 1
|
|
302
309
|
finally:
|
|
303
310
|
self.post_result = self.post_call()
|
|
304
|
-
return result
|
|
305
311
|
|
|
306
312
|
async def async_call(self, *argv):
|
|
307
313
|
""" Call with async stuff in single event loop """
|
|
@@ -324,15 +330,8 @@ class Command(EntryPoint, dict):
|
|
|
324
330
|
for _, arg in enumerate(factories):
|
|
325
331
|
arg.value = results[_]
|
|
326
332
|
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
result = await async_resolve(result, output=True)
|
|
330
|
-
except KeyboardInterrupt:
|
|
331
|
-
print('exiting')
|
|
332
|
-
sys.exit(1)
|
|
333
|
-
finally:
|
|
334
|
-
self.post_result = await async_resolve(self.post_call())
|
|
335
|
-
return result
|
|
333
|
+
result = self.call(*self.bound.args, **self.bound.kwargs)
|
|
334
|
+
return await async_resolve(result, output=True)
|
|
336
335
|
|
|
337
336
|
def ordered(self, factories=False):
|
|
338
337
|
"""
|
|
@@ -162,9 +162,6 @@ class Client(cli2.Client):
|
|
|
162
162
|
kwargs.setdefault('base_url', 'http://lol')
|
|
163
163
|
super().__init__(*args, **kwargs)
|
|
164
164
|
|
|
165
|
-
def pagination_parameters(self, paginator, page_number):
|
|
166
|
-
return dict(page=page_number)
|
|
167
|
-
|
|
168
165
|
|
|
169
166
|
raised = False
|
|
170
167
|
|
|
@@ -499,12 +496,10 @@ async def test_pagination_patterns(httpx_mock):
|
|
|
499
496
|
def pagination_initialize(self, data):
|
|
500
497
|
self.total_items = data['total']
|
|
501
498
|
|
|
502
|
-
def pagination_parameters(self, page_number):
|
|
499
|
+
def pagination_parameters(self, params, page_number):
|
|
503
500
|
self.per_page = 1
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
limit=paginator.per_page,
|
|
507
|
-
)
|
|
501
|
+
params['offset'] = (page_number - 1) * self.per_page
|
|
502
|
+
params['limit'] = self.per_page
|
|
508
503
|
|
|
509
504
|
class Offset(Client.Model):
|
|
510
505
|
url_list = '/off'
|
|
@@ -532,7 +527,9 @@ async def test_pagination_patterns(httpx_mock):
|
|
|
532
527
|
await paginator.initialize()
|
|
533
528
|
assert paginator.total_pages == 2
|
|
534
529
|
assert paginator.per_page == 1
|
|
535
|
-
|
|
530
|
+
params = dict()
|
|
531
|
+
paginator.pagination_parameters(params, 2)
|
|
532
|
+
assert params == dict(offset=1, limit=1)
|
|
536
533
|
|
|
537
534
|
|
|
538
535
|
@pytest.mark.asyncio
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import asyncio
|
|
1
2
|
import inspect
|
|
2
3
|
import pytest
|
|
3
4
|
import os
|
|
@@ -684,3 +685,29 @@ def test_cli2():
|
|
|
684
685
|
|
|
685
686
|
cmd = Command(test)
|
|
686
687
|
assert cmd('x') == ('x', cmd)
|
|
688
|
+
|
|
689
|
+
|
|
690
|
+
def test_keyboard_interrupt():
|
|
691
|
+
def func():
|
|
692
|
+
raise KeyboardInterrupt()
|
|
693
|
+
|
|
694
|
+
cmd = Command(func)
|
|
695
|
+
cmd()
|
|
696
|
+
assert cmd.exit_code == 1
|
|
697
|
+
|
|
698
|
+
|
|
699
|
+
def test_keyboard_interrupt_async():
|
|
700
|
+
class YourCommand(Command):
|
|
701
|
+
async def post_call(self):
|
|
702
|
+
return 'foo'
|
|
703
|
+
|
|
704
|
+
async def foo():
|
|
705
|
+
raise KeyboardInterrupt()
|
|
706
|
+
|
|
707
|
+
async def func():
|
|
708
|
+
await asyncio.gather(foo())
|
|
709
|
+
|
|
710
|
+
cmd = YourCommand(func)
|
|
711
|
+
cmd()
|
|
712
|
+
assert cmd.exit_code == 1
|
|
713
|
+
assert cmd.post_result == 'foo'
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|