當前位置: 首頁>>代碼示例>>Python>>正文


Python sentry_sdk.capture_exception方法代碼示例

本文整理匯總了Python中sentry_sdk.capture_exception方法的典型用法代碼示例。如果您正苦於以下問題:Python sentry_sdk.capture_exception方法的具體用法?Python sentry_sdk.capture_exception怎麽用?Python sentry_sdk.capture_exception使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sentry_sdk的用法示例。


在下文中一共展示了sentry_sdk.capture_exception方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: log_exception

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def log_exception(exception=None, context: commands.Context = None):
        if config.SENTRY_DSN is None:
            return

        with sentry_sdk.push_scope() as scope:
            if context:
                # noinspection PyDunderSlots,PyUnresolvedReferences
                # for some reason pycharm doesn't pick up the attribute setter here
                scope.user = {"id": context.author.id, "username": str(context.author)}
                scope.set_tag("message.content", context.message.content)
                scope.set_tag("is_private_message", context.guild is None)
                scope.set_tag("channel.id", context.channel.id)
                scope.set_tag("channel.name", str(context.channel))
                if context.guild is not None:
                    scope.set_tag("guild.id", context.guild.id)
                    scope.set_tag("guild.name", str(context.guild))
            sentry_sdk.capture_exception(exception) 
開發者ID:avrae,項目名稱:avrae,代碼行數:19,代碼來源:dbot.py

示例2: push_admin_credit_transfer

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def push_admin_credit_transfer(transfers):
    # If we only get one transfer, make it a list
    if not isinstance(transfers, list):
        transfers = [transfers]

    # Build prepared list of transfers we want to send
    pusher_batch_payload = []
    for transfer in transfers:
        for org in transfer.organisations:
            pusher_transfer_payload = {}
            pusher_transfer_payload['data'] = {}
            pusher_transfer_payload['data']['credit_transfer'] = credit_transfer_schema.dump(transfer).data
            pusher_transfer_payload['name'] = 'credit_transfer'
            pusher_transfer_payload['channel'] = current_app.config['PUSHER_ENV_CHANNEL'] + '-' + str(org.id)
            pusher_batch_payload.append(pusher_transfer_payload)

    # Break the list of prepared transfers into MAX_BATCH_SIZE chunks and send each batch to the API
    for pusher_payload_chunk in misc.chunk_list(pusher_batch_payload, PUSHER_MAX_BATCH_SIZE):
        try:
            async_pusher_trigger_batch.submit(pusher_payload_chunk)
        except Exception as e:
            print(e)
            sentry_sdk.capture_exception(e) 
開發者ID:teamsempo,項目名稱:SempoBlockchain,代碼行數:25,代碼來源:pusher.py

示例3: get_usd_to_satoshi_rate

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def get_usd_to_satoshi_rate():

    blockchain_task = celery_app.signature('worker.celery_tasks.get_usd_to_satoshi_rate')
    # TODO: Convert to task_runner
    result = blockchain_task.apply_async()

    try:
        conversion_rate = result.wait(timeout=3, propagate=True, interval=0.5)

    except Exception as e:
        print(e)
        sentry_sdk.capture_exception(e)
        raise BlockchainError("Blockchain Error")

    finally:
        result.forget()

    return conversion_rate 
開發者ID:teamsempo,項目名稱:SempoBlockchain,代碼行數:20,代碼來源:blockchain_transaction.py

示例4: test_500

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def test_500(sentry_init, capture_events):
    sentry_init(integrations=[FalconIntegration()])

    app = falcon.API()

    class Resource:
        def on_get(self, req, resp):
            1 / 0

    app.add_route("/", Resource())

    def http500_handler(ex, req, resp, params):
        sentry_sdk.capture_exception(ex)
        resp.media = {"message": "Sentry error: %s" % sentry_sdk.last_event_id()}

    app.add_error_handler(Exception, http500_handler)

    events = capture_events()

    client = falcon.testing.TestClient(app)
    response = client.simulate_get("/")

    (event,) = events
    assert response.json == {"message": "Sentry error: %s" % event["event_id"]} 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:26,代碼來源:test_falcon.py

示例5: test_initialization_order

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def test_initialization_order(run_lambda_function):
    """Zappa lazily imports our code, so by the time we monkeypatch the handler
    as seen by AWS already runs. At this point at least draining the queue
    should work."""

    events, _response = run_lambda_function(
        LAMBDA_PRELUDE
        + dedent(
            """
            def test_handler(event, context):
                init_sdk()
                sentry_sdk.capture_exception(Exception("something went wrong"))
        """
        ),
        b'{"foo": "bar"}',
    )

    (event,) = events
    assert event["level"] == "error"
    (exception,) = event["exception"]["values"]
    assert exception["type"] == "Exception"
    assert exception["value"] == "something went wrong" 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:24,代碼來源:test_aws.py

示例6: _handle_sentry

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def _handle_sentry(self):
        """Handle exceptions using Sentry."""
        from sentry_sdk import capture_exception, configure_scope
        from sentry_sdk.utils import capture_internal_exceptions

        with configure_scope() as scope:
            with capture_internal_exceptions():
                from git import Repo
                from renku.core.commands import get_git_home
                from renku.core.models.provenance.agents import Person

                repo = Repo(get_git_home())
                user = Person.from_git(repo)

                scope.user = {'name': user.name, 'email': user.email}

            event_id = capture_exception()
            click.echo(
                _BUG + 'Recorded in Sentry with ID: {0}\n'.format(event_id),
                err=True,
            )
            raise 
開發者ID:SwissDataScienceCenter,項目名稱:renku-python,代碼行數:24,代碼來源:exception_handler.py

示例7: log_exception

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def log_exception(request, exception, tb):
    if sentry_sdk is not None:
        sentry_sdk.capture_exception(exception)
        return

    # Send email to admins with details about exception
    ip_type = (
        request.META.get("REMOTE_ADDR") in settings.INTERNAL_IPS
        and "internal"
        or "EXTERNAL"
    )
    msg_args = {
        "ip_type": ip_type,
        "path": request.path,
    }
    subject = "Error (%(ip_type)s IP): %(path)s" % msg_args

    try:
        request_repr = repr(request)
    except:
        request_repr = "Request repr() unavailable"

    msg_args = (str(exception.args[0]), tb, request_repr)
    message = "%s\n\n%s\n\n%s" % msg_args
    mail_admins(subject, message, fail_silently=True) 
開發者ID:evernote,項目名稱:zing,代碼行數:27,代碼來源:errorpages.py

示例8: custom_exception_handler

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def custom_exception_handler(exc, context):
    """
    Custom exception handler for rest api views
    """
    # Call REST framework's default exception handler first,
    # to get the standard error response.
    log.exception("An exception was intercepted by custom_exception_handler")
    response = exception_handler(exc, context)

    # if it is handled, just return the response
    if response is not None:
        return response

    # Otherwise format the exception only in specific cases
    if isinstance(exc, ImproperlyConfigured):
        # send the exception to Sentry anyway
        client.capture_exception()

        formatted_exception_string = "{0}: {1}".format(type(exc).__name__, str(exc))
        return Response(
            status=status.HTTP_500_INTERNAL_SERVER_ERROR,
            data=[formatted_exception_string]
        )
    return None 
開發者ID:mitodl,項目名稱:micromasters,代碼行數:26,代碼來源:utils.py

示例9: handle_kyc_documents

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def handle_kyc_documents(data=None,document_country=None,document_type=None,kyc_details=None):
    for (key, value) in data.items():
        if set([key]).intersection(set(['document_front_base64', 'document_back_base64', 'selfie_base64'])) and value is not None:
            try:
                new_filename = generate_new_filename(original_filename="{}-{}.jpg".format(key, document_country), file_type='jpg')
                save_to_s3_from_image_base64(image_base64=value, new_filename=new_filename)
                uploaded_document = UploadedResource(filename=new_filename, reference=document_type,
                                                     user_filename=key)
                db.session.add(uploaded_document)
                # tie document to kyc application
                uploaded_document.kyc_application_id = kyc_details.id
            except Exception as e:
                print(e)
                sentry_sdk.capture_exception(e)
                pass 
開發者ID:teamsempo,項目名稱:SempoBlockchain,代碼行數:17,代碼來源:kyc_application_api.py

示例10: save_photo_and_check_for_duplicate

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def save_photo_and_check_for_duplicate(url, new_filename, image_id):
    save_to_s3_from_url(url, new_filename)

    try:
        rekognition_task = celery_app.signature('worker.celery_tasks.check_for_duplicate_person',
                                                args=(new_filename, image_id))
        # TODO: Standardize this task (pipe through execute_synchronous_celery)
        rekognition_task.delay()
    except Exception as e:
        print(e)
        sentry_sdk.capture_exception(e)
        pass 
開發者ID:teamsempo,項目名稱:SempoBlockchain,代碼行數:14,代碼來源:user.py

示例11: push_user_transfer_confirmation

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def push_user_transfer_confirmation(receive_user, transfer_random_key):
    try:
        async_pusher_trigger.submit(
            'private-user-{}-{}'.format(current_app.config['DEPLOYMENT_NAME'], receive_user.id),
            'payment_confirmed',
            {'transfer_random_key': transfer_random_key}
        )
    except Exception as e:
        print(e)
        sentry_sdk.capture_exception(e) 
開發者ID:teamsempo,項目名稱:SempoBlockchain,代碼行數:12,代碼來源:pusher.py

示例12: ip

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def ip(self, ip):

        self._ip = ip

        if ip is not None:

            try:
                mt.set_ip_location(self.id, ip)
            except Exception as e:
                print(e)
                sentry_sdk.capture_exception(e)
                pass 
開發者ID:teamsempo,項目名稱:SempoBlockchain,代碼行數:14,代碼來源:ip_address.py

示例13: test_basic

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def test_basic(sentry_init, capture_events):
    sentry_init(integrations=[ModulesIntegration()])
    events = capture_events()

    sentry_sdk.capture_exception(ValueError())

    (event,) = events
    assert "sentry-sdk" in event["modules"]
    assert "pytest" in event["modules"] 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:11,代碼來源:test_modules.py

示例14: handle

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def handle(self, exc_type, exc_value, enriched_tb):
        if self._rate_limiter.please():
            sentry_sdk.capture_exception((exc_type, exc_value, enriched_tb)) 
開發者ID:mherrmann,項目名稱:fbs,代碼行數:5,代碼來源:sentry.py

示例15: send_to_sentry

# 需要導入模塊: import sentry_sdk [as 別名]
# 或者: from sentry_sdk import capture_exception [as 別名]
def send_to_sentry(ex):
    # so that we don't have to have sentry sdk installed locally
    import sentry_sdk

    sentry_sdk.capture_exception(ex) 
開發者ID:packit-service,項目名稱:packit-service,代碼行數:7,代碼來源:sentry_integration.py


注:本文中的sentry_sdk.capture_exception方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。