当前位置: 首页>>代码示例>>Python>>正文


Python exceptions.MaxRetriesExceededError方法代码示例

本文整理汇总了Python中celery.exceptions.MaxRetriesExceededError方法的典型用法代码示例。如果您正苦于以下问题:Python exceptions.MaxRetriesExceededError方法的具体用法?Python exceptions.MaxRetriesExceededError怎么用?Python exceptions.MaxRetriesExceededError使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在celery.exceptions的用法示例。


在下文中一共展示了exceptions.MaxRetriesExceededError方法的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: check_transaction_status_in_pool

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def check_transaction_status_in_pool(self, check_sent_to_pool_result):

    transaction_hash, blockchain_transaction_ids = check_sent_to_pool_result

    try:
        success = blockchain_processor.check_transaction_status_in_pool(transaction_hash, blockchain_transaction_ids)

        if not success:
            self.retry(countdown=BITCOIN_CHECK_TRANSACTION_BASE_TIME * 2 ** self.request.retries)

    except MaxRetriesExceededError:

        submitted_date = datetime.utcnow()

        for transaction_id in blockchain_transaction_ids:
            response = blockchain_processor.put_blockchain_result_to_app({
                'transaction_id': transaction_id,
                'status': 'FAILED',
                'message': 'Timeout in pool',
                'transaction_type': 'transfer',
                'submitted_date': submitted_date.isoformat()
            })
    return True 
开发者ID:teamsempo,项目名称:SempoBlockchain,代码行数:25,代码来源:celery_tasks.py

示例2: test_get_pdf_for_templated_letter_sets_technical_failure_max_retries

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def test_get_pdf_for_templated_letter_sets_technical_failure_max_retries(mocker, sample_letter_notification):
    mock_celery = mocker.patch('app.celery.letters_pdf_tasks.notify_celery.send_task', side_effect=Exception())
    mocker.patch('app.celery.letters_pdf_tasks.get_letter_pdf_filename', return_value='LETTER.PDF')
    mock_retry = mocker.patch(
        'app.celery.letters_pdf_tasks.get_pdf_for_templated_letter.retry', side_effect=MaxRetriesExceededError)
    mock_update_noti = mocker.patch('app.celery.letters_pdf_tasks.update_notification_status_by_id')

    with pytest.raises(NotificationTechnicalFailureException) as e:
        get_pdf_for_templated_letter(sample_letter_notification.id)

    assert e.value.args[0] == f"RETRY FAILED: Max retries reached. " \
        f"The task create-letter-pdf failed for notification id {sample_letter_notification.id}. " \
        f"Notification has been updated to technical-failure"
    assert mock_celery.called
    assert mock_retry.called
    mock_update_noti.assert_called_once_with(sample_letter_notification.id, 'technical-failure') 
开发者ID:alphagov,项目名称:notifications-api,代码行数:18,代码来源:test_letters_pdf_tasks.py

示例3: test_process_sanitised_letter_puts_letter_into_technical_failure_if_max_retries_exceeded

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def test_process_sanitised_letter_puts_letter_into_technical_failure_if_max_retries_exceeded(
    mocker,
    sample_letter_notification,
):
    mocker.patch('app.celery.letters_pdf_tasks.update_letter_pdf_status', side_effect=Exception())
    mocker.patch('app.celery.letters_pdf_tasks.process_sanitised_letter.retry', side_effect=MaxRetriesExceededError())

    sample_letter_notification.status = NOTIFICATION_PENDING_VIRUS_CHECK
    encrypted_data = encryption.encrypt({
        'page_count': 2,
        'message': None,
        'invalid_pages': None,
        'validation_status': 'passed',
        'filename': 'NOTIFY.{}'.format(sample_letter_notification.reference),
        'notification_id': str(sample_letter_notification.id),
        'address': None
    })

    with pytest.raises(NotificationTechnicalFailureException):
        process_sanitised_letter(encrypted_data)

    assert sample_letter_notification.status == NOTIFICATION_TECHNICAL_FAILURE 
开发者ID:alphagov,项目名称:notifications-api,代码行数:24,代码来源:test_letters_pdf_tasks.py

示例4: check_whether_transaction_sent_to_pool

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def check_whether_transaction_sent_to_pool(self, submit_result):
    transaction_hash, credit_transfer_ids = submit_result

    try:
        check_sent_to_pool_result = (
            blockchain_processor.check_whether_transaction_sent_to_pool(transaction_hash, credit_transfer_ids)
        )

        if not check_sent_to_pool_result:
            raise Exception("Not found in pool")
        else:
            return check_sent_to_pool_result

    except Exception as e:
        # This is so we can log the underlying error rather than just getting a MaxRetriesExceededError
        if self.request.retries < self.max_retries - 1:
            self.retry(countdown=2 * 2 ** self.request.retries)
        else:
            submitted_date = datetime.utcnow()

            for credit_transfer_id in credit_transfer_ids:
                response = blockchain_processor.post_blockchain_result_to_app({
                    'credit_transfer_id': credit_transfer_id,
                    'status': 'FAILED',
                    'message': 'Failed to add to pool: ' + str(e),
                    'transaction_type': 'transfer',
                    'submitted_date': submitted_date.isoformat(),
                    'force_transaction_creation': True
                })

            raise e
    return True 
开发者ID:teamsempo,项目名称:SempoBlockchain,代码行数:34,代码来源:celery_tasks.py

示例5: test_should_go_into_technical_error_if_exceeds_retries_on_deliver_sms_task

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def test_should_go_into_technical_error_if_exceeds_retries_on_deliver_sms_task(sample_notification, mocker):
    mocker.patch('app.delivery.send_to_providers.send_sms_to_provider', side_effect=Exception("EXPECTED"))
    mocker.patch('app.celery.provider_tasks.deliver_sms.retry', side_effect=MaxRetriesExceededError())

    with pytest.raises(NotificationTechnicalFailureException) as e:
        deliver_sms(sample_notification.id)
    assert str(sample_notification.id) in str(e.value)

    provider_tasks.deliver_sms.retry.assert_called_with(queue="retry-tasks", countdown=0)

    assert sample_notification.status == 'technical-failure' 
开发者ID:alphagov,项目名称:notifications-api,代码行数:13,代码来源:test_provider_tasks.py

示例6: test_should_go_into_technical_error_if_exceeds_retries_on_deliver_email_task

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def test_should_go_into_technical_error_if_exceeds_retries_on_deliver_email_task(sample_notification, mocker):
    mocker.patch('app.delivery.send_to_providers.send_email_to_provider', side_effect=Exception("EXPECTED"))
    mocker.patch('app.celery.provider_tasks.deliver_email.retry', side_effect=MaxRetriesExceededError())

    with pytest.raises(NotificationTechnicalFailureException) as e:
        deliver_email(sample_notification.id)
    assert str(sample_notification.id) in str(e.value)

    provider_tasks.deliver_email.retry.assert_called_with(queue="retry-tasks")
    assert sample_notification.status == 'technical-failure' 
开发者ID:alphagov,项目名称:notifications-api,代码行数:12,代码来源:test_provider_tasks.py

示例7: test_sanitise_letter_puts_letter_into_technical_failure_if_max_retries_exceeded

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def test_sanitise_letter_puts_letter_into_technical_failure_if_max_retries_exceeded(sample_letter_notification, mocker):
    mocker.patch('app.celery.letters_pdf_tasks.notify_celery.send_task', side_effect=Exception())
    mocker.patch('app.celery.letters_pdf_tasks.sanitise_letter.retry', side_effect=MaxRetriesExceededError())

    filename = 'NOTIFY.{}'.format(sample_letter_notification.reference)
    sample_letter_notification.status = NOTIFICATION_PENDING_VIRUS_CHECK

    with pytest.raises(NotificationTechnicalFailureException):
        sanitise_letter(filename)

    assert sample_letter_notification.status == NOTIFICATION_TECHNICAL_FAILURE 
开发者ID:alphagov,项目名称:notifications-api,代码行数:13,代码来源:test_letters_pdf_tasks.py

示例8: process_map_updates

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def process_map_updates(self):
    if self.request.called_directly:
        logger.info('Processing map updates by direct command...')
    else:
        logger.info('Processing map updates...')

    from c3nav.mapdata.models import MapUpdate
    try:
        try:
            updates = MapUpdate.process_updates()
        except MapUpdate.ProcessUpdatesAlreadyRunning:
            if self.request.called_directly:
                raise
            logger.info('Processing is already running, retrying in 30 seconds.')
            raise self.retry(countdown=30)
        except Exception:
            cache.set('mapdata:last_process_updates_run', (int(time.time()), False), None)
            raise
        else:
            cache.set('mapdata:last_process_updates_run', (int(time.time()), True), None)
    except MaxRetriesExceededError:
        logger.info('Cannot retry, retries exceeded. Exiting.')
        return

    if updates:
        print()

    logger.info(ungettext_lazy('%d map update processed.', '%d map updates processed.', len(updates)) % len(updates))

    if updates:
        logger.info(_('Last processed update: %(date)s (#%(id)d)') % {
            'date': date_format(updates[-1].datetime, 'DATETIME_FORMAT'),
            'id': updates[-1].pk,
        }) 
开发者ID:c3nav,项目名称:c3nav,代码行数:36,代码来源:tasks.py

示例9: create_transaction_response

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def create_transaction_response(self, previous_result, credit_transfer_id):

    def transaction_response_countdown():
        t = lambda retries: ETH_CHECK_TRANSACTION_BASE_TIME*2**retries

        # If the system has been longer than the max retry period
        if previous_result:
            submitted_at = datetime.strptime(previous_result['submitted_date'], "%Y-%m-%d %H:%M:%S.%f")
            if (datetime.utcnow() - submitted_at).total_seconds() > ETH_CHECK_TRANSACTION_RETRIES_TIME_LIMIT:
                if self.request.retries != self.max_retries:
                    self.request.retries = self.max_retries - 1

                return 0

        return t(self.request.retries)

    try:
        try:
            result = blockchain_processor.create_transaction_response(previous_result['transaction_hash'])

        except Exception as e:
            print(e)
            self.retry(countdown=transaction_response_countdown())

        else:
            result = {**previous_result, **result, 'credit_transfer_id': credit_transfer_id}

            blockchain_processor.send_blockchain_result_to_app(result)

            if result['status'] == 'PENDING':
                self.retry(countdown=transaction_response_countdown())

            return result

    except MaxRetriesExceededError as e:

        result = {**previous_result,
                  'status': 'FAILED',
                  'message': 'timeout',
                  'credit_transfer_id': credit_transfer_id}

        blockchain_processor.send_blockchain_result_to_app(result)

        raise e
    return True 
开发者ID:teamsempo,项目名称:SempoBlockchain,代码行数:47,代码来源:celery_tasks.py

示例10: sync_data_to_customer

# 需要导入模块: from celery import exceptions [as 别名]
# 或者: from celery.exceptions import MaxRetriesExceededError [as 别名]
def sync_data_to_customer(dump_request_uuid):
    """
    Scheduled task to sync normalized data to our customers S3 bucket.

    If the sync request raises SyncedFileInColdStorageError, this task
    will automatically retry in a set amount of time. This time is to give
    the storage solution time to retrieve a file from cold storage.
    This task will retry 5 times, and then fail.

    """
    dump_request = DataExportRequest.objects.get(uuid=dump_request_uuid)
    dump_request.status = DataExportRequest.PROCESSING
    dump_request.save()

    try:
        syncer = AwsS3Syncer(settings.S3_BUCKET_NAME)
        syncer.sync_bucket(
            dump_request.created_by.customer.schema_name,
            dump_request.bucket_name,
            (dump_request.start_date, dump_request.end_date),
        )
    except ClientError:
        LOG.exception(
            f"Encountered an error while processing DataExportRequest "
            f"{dump_request.uuid}, for {dump_request.created_by}."
        )
        dump_request.status = DataExportRequest.ERROR
        dump_request.save()
        return
    except SyncedFileInColdStorageError:
        LOG.info(
            f"One of the requested files is currently in cold storage for "
            f"DataExportRequest {dump_request.uuid}. This task will automatically retry."
        )
        dump_request.status = DataExportRequest.WAITING
        dump_request.save()
        try:
            raise sync_data_to_customer.retry(countdown=10, max_retries=5)
        except MaxRetriesExceededError:
            LOG.exception(
                f"Max retires exceeded for restoring a file in cold storage for "
                f"DataExportRequest {dump_request.uuid}, for {dump_request.created_by}."
            )
            dump_request.status = DataExportRequest.ERROR
            dump_request.save()
            return
    dump_request.status = DataExportRequest.COMPLETE
    dump_request.save() 
开发者ID:project-koku,项目名称:koku,代码行数:50,代码来源:tasks.py


注:本文中的celery.exceptions.MaxRetriesExceededError方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。