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.
Files changed (45) hide show
  1. {cli2-3.3.42/cli2.egg-info → cli2-3.3.45}/PKG-INFO +1 -1
  2. {cli2-3.3.42 → cli2-3.3.45}/cli2/client.py +9 -15
  3. {cli2-3.3.42 → cli2-3.3.45}/cli2/command.py +13 -14
  4. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_client.py +6 -9
  5. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_command.py +27 -0
  6. {cli2-3.3.42 → cli2-3.3.45/cli2.egg-info}/PKG-INFO +1 -1
  7. {cli2-3.3.42 → cli2-3.3.45}/setup.py +1 -1
  8. {cli2-3.3.42 → cli2-3.3.45}/MANIFEST.in +0 -0
  9. {cli2-3.3.42 → cli2-3.3.45}/README.rst +0 -0
  10. {cli2-3.3.42 → cli2-3.3.45}/classifiers.txt +0 -0
  11. {cli2-3.3.42 → cli2-3.3.45}/cli2/__init__.py +0 -0
  12. {cli2-3.3.42 → cli2-3.3.45}/cli2/argument.py +0 -0
  13. {cli2-3.3.42 → cli2-3.3.45}/cli2/asyncio.py +0 -0
  14. {cli2-3.3.42 → cli2-3.3.45}/cli2/cli.py +0 -0
  15. {cli2-3.3.42 → cli2-3.3.45}/cli2/colors.py +0 -0
  16. {cli2-3.3.42 → cli2-3.3.45}/cli2/configuration.py +0 -0
  17. {cli2-3.3.42 → cli2-3.3.45}/cli2/decorators.py +0 -0
  18. {cli2-3.3.42 → cli2-3.3.45}/cli2/display.py +0 -0
  19. {cli2-3.3.42 → cli2-3.3.45}/cli2/entry_point.py +0 -0
  20. {cli2-3.3.42 → cli2-3.3.45}/cli2/example_client.py +0 -0
  21. {cli2-3.3.42 → cli2-3.3.45}/cli2/example_client_complex.py +0 -0
  22. {cli2-3.3.42 → cli2-3.3.45}/cli2/example_nesting.py +0 -0
  23. {cli2-3.3.42 → cli2-3.3.45}/cli2/example_obj.py +0 -0
  24. {cli2-3.3.42 → cli2-3.3.45}/cli2/group.py +0 -0
  25. {cli2-3.3.42 → cli2-3.3.45}/cli2/logging.py +0 -0
  26. {cli2-3.3.42 → cli2-3.3.45}/cli2/node.py +0 -0
  27. {cli2-3.3.42 → cli2-3.3.45}/cli2/overrides.py +0 -0
  28. {cli2-3.3.42 → cli2-3.3.45}/cli2/sphinx.py +0 -0
  29. {cli2-3.3.42 → cli2-3.3.45}/cli2/table.py +0 -0
  30. {cli2-3.3.42 → cli2-3.3.45}/cli2/test.py +0 -0
  31. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_cli.py +0 -0
  32. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_configuration.py +0 -0
  33. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_decorators.py +0 -0
  34. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_display.py +0 -0
  35. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_entry_point.py +0 -0
  36. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_group.py +0 -0
  37. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_inject.py +0 -0
  38. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_node.py +0 -0
  39. {cli2-3.3.42 → cli2-3.3.45}/cli2/test_table.py +0 -0
  40. {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/SOURCES.txt +0 -0
  41. {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/dependency_links.txt +0 -0
  42. {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/entry_points.txt +0 -0
  43. {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/requires.txt +0 -0
  44. {cli2-3.3.42 → cli2-3.3.45}/cli2.egg-info/top_level.txt +0 -0
  45. {cli2-3.3.42 → cli2-3.3.45}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: cli2
3
- Version: 3.3.42
3
+ Version: 3.3.45
4
4
  Summary: image:: https://yourlabs.io/oss/cli2/badges/master/pipeline.svg
5
5
  Home-page: https://yourlabs.io/oss/cli2
6
6
  Author: James Pic
@@ -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
- return dict(page=page_number)
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
- return dict(page=page_number)
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
- try:
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
- pagination_parameters = self.pagination_parameters(page_number)
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
- return asyncio.run(self.async_call(*argv))
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
- sys.exit(1)
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
- try:
328
- result = self.call(*self.bound.args, **self.bound.kwargs)
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
- return dict(
505
- offset=(page_number - 1) * paginator.per_page,
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
- assert paginator.pagination_parameters(2) == dict(offset=1, limit=1)
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'
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: cli2
3
- Version: 3.3.42
3
+ Version: 3.3.45
4
4
  Summary: image:: https://yourlabs.io/oss/cli2/badges/master/pipeline.svg
5
5
  Home-page: https://yourlabs.io/oss/cli2
6
6
  Author: James Pic
@@ -3,7 +3,7 @@ from setuptools import setup
3
3
 
4
4
  setup(
5
5
  name='cli2',
6
- version='3.3.42',
6
+ version='3.3.45',
7
7
  setup_requires='setupmeta',
8
8
  install_requires=[
9
9
  'docstring_parser',
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