本文整理匯總了Python中botocore.exceptions.PaginationError方法的典型用法代碼示例。如果您正苦於以下問題:Python exceptions.PaginationError方法的具體用法?Python exceptions.PaginationError怎麽用?Python exceptions.PaginationError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類botocore.exceptions
的用法示例。
在下文中一共展示了exceptions.PaginationError方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _read_streams
# 需要導入模塊: from botocore import exceptions [as 別名]
# 或者: from botocore.exceptions import PaginationError [as 別名]
def _read_streams(self, stream_name=None):
kwargs = self.paginator_kwargs.copy()
if stream_name is not None:
kwargs['logStreamNames'] = [stream_name]
paginator = self.boto_client.get_paginator('filter_log_events')
response_iterator = paginator.paginate(
logGroupName=self.log_group_name,
startTime=self.start_ms,
endTime=self.end_ms,
interleaved=True,
**kwargs
)
try:
for page in response_iterator:
yield from page['events']
except PaginationError as e:
if e.kwargs['message'].startswith(DUPLICATE_NEXT_TOKEN_MESSAGE):
pass
else:
raise
示例2: test_iteration_error
# 需要導入模塊: from botocore import exceptions [as 別名]
# 或者: from botocore.exceptions import PaginationError [as 別名]
def test_iteration_error(self):
# Simulate the paginator failing
def _get_paginator(*args, **kwargs):
event_0 = {'logStreamName': 'log_0', 'message': V2_RECORDS[0]}
event_1 = {'logStreamName': 'log_0', 'message': V2_RECORDS[1]}
for item in [{'events': [event_0, event_1]}]:
yield item
err_msg = '{}: {}'.format(DUPLICATE_NEXT_TOKEN_MESSAGE, 'token')
raise PaginationError(message=err_msg)
self.mock_client.get_paginator.return_value.paginate.side_effect = (
_get_paginator
)
# Don't fail if botocore's paginator raises a PaginationError
actual = [next(self.inst)] + list(self.inst)
records = V2_RECORDS[:2]
expected = [FlowRecord.from_cwl_event({'message': x}) for x in records]
self.assertEqual(actual, expected)
示例3: _extract_paging_params
# 需要導入模塊: from botocore import exceptions [as 別名]
# 或者: from botocore.exceptions import PaginationError [as 別名]
def _extract_paging_params(self, kwargs):
pagination_config = kwargs.pop('PaginationConfig', {})
max_items = pagination_config.get('MaxItems', None)
if max_items is not None:
max_items = int(max_items)
page_size = pagination_config.get('PageSize', None)
if page_size is not None:
if self._pagination_cfg.get('limit_key', None) is None:
raise PaginationError(
message="PageSize parameter is not supported for the "
"pagination interface for this operation.")
page_size = int(page_size)
return {
'MaxItems': max_items,
'StartingToken': pagination_config.get('StartingToken', None),
'PageSize': page_size,
}
示例4: _extract_paging_params
# 需要導入模塊: from botocore import exceptions [as 別名]
# 或者: from botocore.exceptions import PaginationError [as 別名]
def _extract_paging_params(self, kwargs):
pagination_config = kwargs.pop('PaginationConfig', {})
max_items = pagination_config.get('MaxItems', None)
if max_items is not None:
max_items = int(max_items)
page_size = pagination_config.get('PageSize', None)
if page_size is not None:
if self._limit_key is None:
raise PaginationError(
message="PageSize parameter is not supported for the "
"pagination interface for this operation.")
input_members = self._model.input_shape.members
limit_key_shape = input_members.get(self._limit_key)
if limit_key_shape.type_name == 'string':
if not isinstance(page_size, six.string_types):
page_size = str(page_size)
else:
page_size = int(page_size)
return {
'MaxItems': max_items,
'StartingToken': pagination_config.get('StartingToken', None),
'PageSize': page_size,
}
示例5: test_iteration_unexpecetd_error
# 需要導入模塊: from botocore import exceptions [as 別名]
# 或者: from botocore.exceptions import PaginationError [as 別名]
def test_iteration_unexpecetd_error(self):
# Simulate the paginator failing
def _get_paginator(*args, **kwargs):
event_0 = {'logStreamName': 'log_0', 'message': V2_RECORDS[0]}
yield {'events': [event_0]}
raise PaginationError(message='other error')
self.mock_client.get_paginator.return_value.paginate.side_effect = (
_get_paginator
)
# Fail for unexpected PaginationError
self.assertRaises(PaginationError, lambda: list(self.inst))
示例6: ensure_paging_params_not_set
# 需要導入模塊: from botocore import exceptions [as 別名]
# 或者: from botocore.exceptions import PaginationError [as 別名]
def ensure_paging_params_not_set(parsed_args, shadowed_args):
paging_params = ['starting_token', 'page_size', 'max_items']
shadowed_params = [p.replace('-', '_') for p in shadowed_args.keys()]
params_used = [p for p in paging_params if
p not in shadowed_params and getattr(parsed_args, p, None)]
if len(params_used) > 0:
converted_params = ', '.join(
["--" + p.replace('_', '-') for p in params_used])
raise PaginationError(
message="Cannot specify --no-paginate along with pagination "
"arguments: %s" % converted_params)
示例7: __iter__
# 需要導入模塊: from botocore import exceptions [as 別名]
# 或者: from botocore.exceptions import PaginationError [as 別名]
def __iter__(self):
current_kwargs = self._op_kwargs
previous_next_token = None
next_token = dict((key, None) for key in self._input_token)
# The number of items from result_key we've seen so far.
total_items = 0
first_request = True
primary_result_key = self.result_keys[0]
starting_truncation = 0
self._inject_starting_params(current_kwargs)
while True:
response = self._make_request(current_kwargs)
parsed = self._extract_parsed_response(response)
if first_request:
# The first request is handled differently. We could
# possibly have a resume/starting token that tells us where
# to index into the retrieved page.
if self._starting_token is not None:
starting_truncation = self._handle_first_request(
parsed, primary_result_key, starting_truncation)
first_request = False
self._record_non_aggregate_key_values(parsed)
current_response = primary_result_key.search(parsed)
if current_response is None:
current_response = []
num_current_response = len(current_response)
truncate_amount = 0
if self._max_items is not None:
truncate_amount = (total_items + num_current_response) \
- self._max_items
if truncate_amount > 0:
self._truncate_response(parsed, primary_result_key,
truncate_amount, starting_truncation,
next_token)
yield response
break
else:
yield response
total_items += num_current_response
next_token = self._get_next_token(parsed)
if all(t is None for t in next_token.values()):
break
if self._max_items is not None and \
total_items == self._max_items:
# We're on a page boundary so we can set the current
# next token to be the resume token.
self.resume_token = next_token
break
if previous_next_token is not None and \
previous_next_token == next_token:
message = ("The same next token was received "
"twice: %s" % next_token)
raise PaginationError(message=message)
self._inject_token_into_kwargs(current_kwargs, next_token)
previous_next_token = next_token
示例8: next_page
# 需要導入模塊: from botocore import exceptions [as 別名]
# 或者: from botocore.exceptions import PaginationError [as 別名]
def next_page(self):
if self._is_stop:
return None
response = yield from self._make_request(self._current_kwargs)
parsed = self._extract_parsed_response(response)
if self._first_request:
# The first request is handled differently. We could
# possibly have a resume/starting token that tells us where
# to index into the retrieved page.
if self._starting_token is not None:
self._starting_truncation = self._handle_first_request(
parsed, self._primary_result_key,
self._starting_truncation)
self._first_request = False
self._record_non_aggregate_key_values(parsed)
else:
# If this isn't the first request, we have already sliced into
# the first request and had to make additional requests after.
# We no longer need to add this to truncation.
self._starting_truncation = 0
current_response = self._primary_result_key.search(parsed)
if current_response is None:
current_response = []
num_current_response = len(current_response)
truncate_amount = 0
if self._max_items is not None:
truncate_amount = (self._total_items + num_current_response) \
- self._max_items
if truncate_amount > 0:
self._truncate_response(parsed, self._primary_result_key,
truncate_amount, self._starting_truncation,
self._next_token)
self._is_stop = True
return response
else:
self._total_items += num_current_response
self._next_token = self._get_next_token(parsed)
if all(t is None for t in self._next_token.values()):
self._is_stop = True
return response
if self._max_items is not None and \
self._total_items == self._max_items:
# We're on a page boundary so we can set the current
# next token to be the resume token.
self.resume_token = self._next_token
self._is_stop = True
return response
if self._previous_next_token is not None and \
self._previous_next_token == self._next_token:
message = ("The same next token was received "
"twice: %s" % self._next_token)
raise PaginationError(message=message)
self._inject_token_into_kwargs(self._current_kwargs,
self._next_token)
self._previous_next_token = self._next_token
return response