本文整理匯總了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)
示例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)
示例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
示例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"]}
示例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"
示例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
示例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)
示例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
示例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
示例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
示例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)
示例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
示例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"]
示例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))
示例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)