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


Python flask.FlaskIntegration方法代碼示例

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


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

示例1: test_transaction_style

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_transaction_style(
    sentry_init, app, capture_events, transaction_style, expected_transaction
):
    sentry_init(
        integrations=[
            flask_sentry.FlaskIntegration(transaction_style=transaction_style)
        ]
    )
    events = capture_events()

    client = app.test_client()
    response = client.get("/message")
    assert response.status_code == 200

    (event,) = events
    assert event["transaction"] == expected_transaction 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:18,代碼來源:test_flask.py

示例2: test_flask_large_json_request

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_flask_large_json_request(sentry_init, capture_events, app):
    sentry_init(integrations=[flask_sentry.FlaskIntegration()])

    data = {"foo": {"bar": "a" * 2000}}

    @app.route("/", methods=["POST"])
    def index():
        assert request.get_json() == data
        assert request.get_data() == json.dumps(data).encode("ascii")
        assert not request.form
        capture_message("hi")
        return "ok"

    events = capture_events()

    client = app.test_client()
    response = client.post("/", content_type="application/json", data=json.dumps(data))
    assert response.status_code == 200

    (event,) = events
    assert event["_meta"]["request"]["data"]["foo"]["bar"] == {
        "": {"len": 2000, "rem": [["!limit", "x", 509, 512]]}
    }
    assert len(event["request"]["data"]["foo"]["bar"]) == 512 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:26,代碼來源:test_flask.py

示例3: test_flask_medium_formdata_request

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_flask_medium_formdata_request(sentry_init, capture_events, app):
    sentry_init(integrations=[flask_sentry.FlaskIntegration()])

    data = {"foo": "a" * 2000}

    @app.route("/", methods=["POST"])
    def index():
        assert request.form["foo"] == data["foo"]
        assert not request.get_data()
        assert not request.get_json()
        capture_message("hi")
        return "ok"

    events = capture_events()

    client = app.test_client()
    response = client.post("/", data=data)
    assert response.status_code == 200

    (event,) = events
    assert event["_meta"]["request"]["data"]["foo"] == {
        "": {"len": 2000, "rem": [["!limit", "x", 509, 512]]}
    }
    assert len(event["request"]["data"]["foo"]) == 512 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:26,代碼來源:test_flask.py

示例4: test_logging

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_logging(sentry_init, capture_events, app):
    # ensure that Flask's logger magic doesn't break ours
    sentry_init(
        integrations=[
            flask_sentry.FlaskIntegration(),
            LoggingIntegration(event_level="ERROR"),
        ]
    )

    @app.route("/")
    def index():
        app.logger.error("hi")
        return "ok"

    events = capture_events()

    client = app.test_client()
    client.get("/")

    (event,) = events
    assert event["level"] == "error" 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:23,代碼來源:test_flask.py

示例5: test_500

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_500(sentry_init, capture_events, app):
    sentry_init(integrations=[flask_sentry.FlaskIntegration()])

    app.debug = False
    app.testing = False

    @app.route("/")
    def index():
        1 / 0

    @app.errorhandler(500)
    def error_handler(err):
        return "Sentry error: %s" % last_event_id()

    events = capture_events()

    client = app.test_client()
    response = client.get("/")

    (event,) = events
    assert response.data.decode("utf-8") == "Sentry error: %s" % event["event_id"] 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:23,代碼來源:test_flask.py

示例6: test_tracing_success

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_tracing_success(sentry_init, capture_events, app):
    sentry_init(traces_sample_rate=1.0, integrations=[flask_sentry.FlaskIntegration()])

    events = capture_events()

    with app.test_client() as client:
        response = client.get("/message")
        assert response.status_code == 200

    message_event, transaction_event = events

    assert transaction_event["type"] == "transaction"
    assert transaction_event["transaction"] == "hi"
    assert transaction_event["contexts"]["trace"]["status"] == "ok"

    assert message_event["message"] == "hi"
    assert message_event["transaction"] == "hi" 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:19,代碼來源:test_flask.py

示例7: test_tracing_error

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_tracing_error(sentry_init, capture_events, app):
    sentry_init(traces_sample_rate=1.0, integrations=[flask_sentry.FlaskIntegration()])

    events = capture_events()

    @app.route("/error")
    def error():
        1 / 0

    with pytest.raises(ZeroDivisionError):
        with app.test_client() as client:
            response = client.get("/error")
            assert response.status_code == 500

    error_event, transaction_event = events

    assert transaction_event["type"] == "transaction"
    assert transaction_event["transaction"] == "error"
    assert transaction_event["contexts"]["trace"]["status"] == "internal_error"

    assert error_event["transaction"] == "error"
    (exception,) = error_event["exception"]["values"]
    assert exception["type"] == "ZeroDivisionError" 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:25,代碼來源:test_flask.py

示例8: test_class_based_views

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_class_based_views(sentry_init, app, capture_events):
    sentry_init(integrations=[flask_sentry.FlaskIntegration()])
    events = capture_events()

    @app.route("/")
    class HelloClass(View):
        def dispatch_request(self):
            capture_message("hi")
            return "ok"

    app.add_url_rule("/hello-class/", view_func=HelloClass.as_view("hello_class"))

    with app.test_client() as client:
        response = client.get("/hello-class/")
        assert response.status_code == 200

    (event,) = events

    assert event["message"] == "hi"
    assert event["transaction"] == "hello_class" 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:22,代碼來源:test_flask.py

示例9: init_sentry

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def init_sentry(app):
    """Init sentry if DSN *and* environment are provided."""
    dsn = app.config['SENTRY_DSN']
    env = app.config['SENTRY_ENVIRONMENT']

    if dsn is None and env is None:
        return

    if None in (dsn, env):
        raise ValueError("You need to specify both DSN and environment "
                         "to use Sentry.")

    sentry_sdk.init(
        dsn=dsn,
        integrations=[FlaskIntegration()],
        environment=env,
    ) 
開發者ID:amiv-eth,項目名稱:amivapi,代碼行數:19,代碼來源:bootstrap.py

示例10: create_app

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def create_app(config_name):
    """Factory of Creating app
    @param:
        config_name - all configurations of app
    """
    sentry_sdk.init(
        dsn="",
        integrations=[FlaskIntegration()])
    application = Flask(__name__)
    application.config.from_object(config[config_name])
    config[config_name].init_app(application)

    csrf = CSRFProtect()

    from .image.model import image_db
    from .image.views import image as image_blueprint
    from .image.apis import blueprint as image_api_blueprint

    csrf.init_app(application)
    image_db.init_app(application)
    application.register_blueprint(image_blueprint)
    application.register_blueprint(image_api_blueprint, url_prefix='/api/v1')

    return application 
開發者ID:leollon,項目名稱:yet-another-image-bed,代碼行數:26,代碼來源:__init__.py

示例11: register_extensions

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def register_extensions(app):
    db.init_app(app)
    executor.init_app(app)
    basic_auth.init_app(app)

    @app.before_request
    def enable_form_raw_cache():
        # Workaround to allow unparsed request body to be be read from cache
        # This is required to validate a signature on webhooks
        # This MUST go before Sentry integration as sentry triggers form parsing
        if not config.IS_TEST and (
                request.path.startswith('/api/v1/slack/') or request.path.startswith('/api/v1/poli_payments_webhook/')):
            if request.content_length > 1024 * 1024:  # 1mb
                # Payload too large
                return make_response(jsonify({'message': 'Payload too large'})), 413
            request.get_data(parse_form_data=False, cache=True)

    # limiter.init_app(app)

    CORS(app, resources={r"/api/*": {"origins": "*"}})

    celery_app.conf.update(app.config)
    if not config.IS_TEST:
        sentry_sdk.init(app.config['SENTRY_SERVER_DSN'], integrations=[FlaskIntegration()], release=config.VERSION)

    print('celery joined on {} at {}'.format(
        app.config['REDIS_URL'], datetime.utcnow())) 
開發者ID:teamsempo,項目名稱:SempoBlockchain,代碼行數:29,代碼來源:__init__.py

示例12: integration_enabled_params

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def integration_enabled_params(request):
    if request.param == "auto":
        return {"_experiments": {"auto_enabling_integrations": True}}
    elif request.param == "manual":
        return {"integrations": [flask_sentry.FlaskIntegration()]}
    else:
        raise ValueError(request.param) 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:9,代碼來源:test_flask.py

示例13: test_has_context

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_has_context(sentry_init, app, capture_events):
    sentry_init(integrations=[flask_sentry.FlaskIntegration()])
    events = capture_events()

    client = app.test_client()
    response = client.get("/message")
    assert response.status_code == 200

    (event,) = events
    assert event["transaction"] == "hi"
    assert "data" not in event["request"]
    assert event["request"]["url"] == "http://localhost/message" 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:14,代碼來源:test_flask.py

示例14: test_flask_session_tracking

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_flask_session_tracking(sentry_init, capture_envelopes, app):
    sentry_init(
        integrations=[flask_sentry.FlaskIntegration()],
        release="demo-release",
        _experiments=dict(auto_session_tracking=True,),
    )

    @app.route("/")
    def index():
        with configure_scope() as scope:
            scope.set_user({"ip_address": "1.2.3.4", "id": 42})
        try:
            raise ValueError("stuff")
        except Exception:
            logging.exception("stuff happened")
        1 / 0

    envelopes = capture_envelopes()

    with app.test_client() as client:
        try:
            client.get("/", headers={"User-Agent": "blafasel/1.0"})
        except ZeroDivisionError:
            pass

    Hub.current.client.flush()

    (first_event, error_event, session) = envelopes
    first_event = first_event.get_event()
    error_event = error_event.get_event()
    session = session.items[0].payload.json

    assert first_event["exception"]["values"][0]["type"] == "ValueError"
    assert error_event["exception"]["values"][0]["type"] == "ZeroDivisionError"
    assert session["status"] == "crashed"
    assert session["did"] == "42"
    assert session["errors"] == 2
    assert session["init"]
    assert session["attrs"]["release"] == "demo-release"
    assert session["attrs"]["ip_address"] == "1.2.3.4"
    assert session["attrs"]["user_agent"] == "blafasel/1.0" 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:43,代碼來源:test_flask.py

示例15: test_flask_too_large_raw_request

# 需要導入模塊: from sentry_sdk.integrations import flask [as 別名]
# 或者: from sentry_sdk.integrations.flask import FlaskIntegration [as 別名]
def test_flask_too_large_raw_request(sentry_init, input_char, capture_events, app):
    sentry_init(integrations=[flask_sentry.FlaskIntegration()], request_bodies="small")

    data = input_char * 2000

    @app.route("/", methods=["POST"])
    def index():
        assert not request.form
        if isinstance(data, bytes):
            assert request.get_data() == data
        else:
            assert request.get_data() == data.encode("ascii")
        assert not request.get_json()
        capture_message("hi")
        return "ok"

    events = capture_events()

    client = app.test_client()
    response = client.post("/", data=data)
    assert response.status_code == 200

    (event,) = events
    assert event["_meta"]["request"]["data"] == {
        "": {"len": 2000, "rem": [["!config", "x", 0, 2000]]}
    }
    assert not event["request"]["data"] 
開發者ID:getsentry,項目名稱:sentry-python,代碼行數:29,代碼來源:test_flask.py


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