Skip to content

Commit

Permalink
test(integration): Add tests for crashpad (#311)
Browse files Browse the repository at this point in the history
  • Loading branch information
jan-auer authored Jun 22, 2020
1 parent 85594b7 commit 9061050
Showing 1 changed file with 61 additions and 5 deletions.
66 changes: 61 additions & 5 deletions tests/test_integration_crashpad.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
import pytest
from .conditions import has_crashpad
import os
import time
from . import make_dsn, run, Envelope
from .conditions import has_crashpad, has_http
from .assertions import assert_session

# TODO:
# * with crashpad backend:
Expand All @@ -8,8 +12,60 @@
# - expect report via http


@pytest.mark.skipif(not has_crashpad, reason="test needs crashpad backend")
def test_crashpad_build(cmake):
cmake(
["sentry_example"], {"SENTRY_BACKEND": "crashpad", "SENTRY_TRANSPORT": "none"},
@pytest.mark.skipif(
not has_http or not has_crashpad, reason="test needs crashpad backend"
)
def test_crashpad_capture(cmake, httpserver):
tmp_path = cmake(["sentry_example"], {"SENTRY_BACKEND": "crashpad"})

httpserver.expect_request("/api/123456/envelope/").respond_with_data("OK")

run(
tmp_path,
"sentry_example",
["log", "start-session", "capture-event"],
check=True,
env=dict(os.environ, SENTRY_DSN=make_dsn(httpserver)),
)

assert len(httpserver.log) == 2


@pytest.mark.skipif(
not has_http or not has_crashpad, reason="test needs crashpad backend"
)
def test_crashpad_crash(cmake, httpserver):
tmp_path = cmake(["sentry_example"], {"SENTRY_BACKEND": "crashpad"})

httpserver.expect_request("/api/123456/minidump/").respond_with_data("OK")
httpserver.expect_request("/api/123456/envelope/").respond_with_data("OK")

child = run(
tmp_path,
"sentry_example",
["log", "start-session", "attachment", "overflow-breadcrumbs", "crash"],
)
assert child.returncode # well, its a crash after all

run(
tmp_path,
"sentry_example",
["log", "no-setup"],
check=True,
env=dict(os.environ, SENTRY_DSN=make_dsn(httpserver)),
)

time.sleep(2) # lets wait a bit for crashpad sending in the background

assert len(httpserver.log) == 2
outputs = (httpserver.log[0][0].get_data(), httpserver.log[1][0].get_data())
session, multipart = (
outputs if b'"type":"session"' in outputs[0] else (outputs[1], outputs[0])
)

envelope = Envelope.deserialize(session)
assert_session(envelope, {"status": "abnormal", "errors": 0})

# TODO: crashpad actually sends a compressed multipart request,
# which we don’t parse / assert right now.
# Ideally, we would pull in a real relay to do all the http tests against.

0 comments on commit 9061050

Please sign in to comment.