test_performance_summary.py 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. from __future__ import absolute_import
  2. import pytz
  3. from six.moves.urllib.parse import urlencode
  4. from mock import patch
  5. from sentry.testutils import AcceptanceTestCase, SnubaTestCase
  6. from sentry.testutils.helpers.datetime import before_now, iso_format
  7. from sentry.utils.samples import load_data
  8. from .page_objects.transaction_summary import TransactionSummaryPage
  9. FEATURE_NAMES = (
  10. "organizations:performance-view",
  11. "organizations:measurements",
  12. )
  13. def make_event(event_data):
  14. event_data["event_id"] = "c" * 32
  15. return event_data
  16. class PerformanceSummaryTest(AcceptanceTestCase, SnubaTestCase):
  17. def setUp(self):
  18. super(PerformanceSummaryTest, self).setUp()
  19. self.org = self.create_organization(owner=self.user, name="Rowdy Tiger")
  20. self.team = self.create_team(
  21. organization=self.org, name="Mariachi Band", members=[self.user]
  22. )
  23. self.project = self.create_project(organization=self.org, teams=[self.team], name="Bengal")
  24. self.group = self.create_group(project=self.project)
  25. self.login_as(self.user)
  26. self.path = u"/organizations/{}/performance/summary/?{}".format(
  27. self.org.slug,
  28. urlencode({"transaction": "/country_by_code/", "project": self.project.id}),
  29. )
  30. self.page = TransactionSummaryPage(self.browser)
  31. @patch("django.utils.timezone.now")
  32. def test_with_data(self, mock_now):
  33. mock_now.return_value = before_now().replace(tzinfo=pytz.utc)
  34. # Create a transaction
  35. event = make_event(load_data("transaction", timestamp=before_now(minutes=1)))
  36. self.store_event(data=event, project_id=self.project.id)
  37. self.wait_for_event_count(self.project.id, 1)
  38. self.store_event(
  39. data={
  40. "transaction": "/country_by_code/",
  41. "message": "This is bad",
  42. "event_id": "b" * 32,
  43. "timestamp": iso_format(before_now(minutes=1)),
  44. },
  45. project_id=self.project.id,
  46. )
  47. with self.feature(FEATURE_NAMES):
  48. self.browser.get(self.path)
  49. self.page.wait_until_loaded()
  50. self.browser.snapshot("performance summary - with data")
  51. @patch("django.utils.timezone.now")
  52. def test_view_details_from_summary(self, mock_now):
  53. mock_now.return_value = before_now().replace(tzinfo=pytz.utc)
  54. event = make_event(
  55. load_data("transaction", timestamp=before_now(minutes=1), trace="a" * 32, span="ab" * 8)
  56. )
  57. self.store_event(data=event, project_id=self.project.id)
  58. with self.feature(FEATURE_NAMES):
  59. self.browser.get(self.path)
  60. self.page.wait_until_loaded()
  61. # View the first event details.
  62. self.browser.element('[data-test-id="view-details"]').click()
  63. self.page.wait_until_loaded()
  64. self.browser.snapshot("performance event details")
  65. @patch("django.utils.timezone.now")
  66. def test_transaction_vitals(self, mock_now):
  67. mock_now.return_value = before_now().replace(tzinfo=pytz.utc)
  68. vitals_path = u"/organizations/{}/performance/summary/vitals/?{}".format(
  69. self.org.slug,
  70. urlencode({"transaction": "/country_by_code/", "project": self.project.id}),
  71. )
  72. # Create a transaction
  73. event_data = load_data("transaction", timestamp=before_now(minutes=1))
  74. # only frontend pageload transactions can be shown on the vitals tab
  75. event_data["contexts"]["trace"]["op"] = "pageload"
  76. event_data["measurements"]["fp"]["value"] = 5000
  77. event = make_event(event_data)
  78. self.store_event(data=event, project_id=self.project.id)
  79. self.wait_for_event_count(self.project.id, 1)
  80. with self.feature(FEATURE_NAMES):
  81. self.browser.get(vitals_path)
  82. self.page.wait_until_loaded()
  83. self.browser.wait_until_not('[data-test-id="stats-loading"]')
  84. self.browser.snapshot("real user monitoring")
  85. @patch("django.utils.timezone.now")
  86. def test_transaction_vitals_filtering(self, mock_now):
  87. mock_now.return_value = before_now().replace(tzinfo=pytz.utc)
  88. vitals_path = u"/organizations/{}/performance/summary/vitals/?{}".format(
  89. self.org.slug,
  90. urlencode({"transaction": "/country_by_code/", "project": self.project.id}),
  91. )
  92. # Create transactions
  93. for seconds in range(3):
  94. event_data = load_data("transaction", timestamp=before_now(minutes=2))
  95. event_data["contexts"]["trace"]["op"] = "pageload"
  96. event_data["event_id"] = ("c" * 31) + hex(seconds)[2:]
  97. event_data["measurements"]["fp"]["value"] = seconds * 10
  98. event_data["measurements"]["fcp"]["value"] = seconds * 10
  99. event_data["measurements"]["lcp"]["value"] = seconds * 10
  100. event_data["measurements"]["fid"]["value"] = seconds * 10
  101. event_data["measurements"]["cls"]["value"] = seconds / 10.0
  102. self.store_event(data=event_data, project_id=self.project.id)
  103. # add anchor point
  104. event_data = load_data("transaction", timestamp=before_now(minutes=1))
  105. event_data["contexts"]["trace"]["op"] = "pageload"
  106. event_data["event_id"] = "a" * 32
  107. event_data["measurements"]["fp"]["value"] = 3000
  108. event_data["measurements"]["fcp"]["value"] = 3000
  109. event_data["measurements"]["lcp"]["value"] = 3000
  110. event_data["measurements"]["fid"]["value"] = 3000
  111. event_data["measurements"]["cls"]["value"] = 0.3
  112. self.store_event(data=event_data, project_id=self.project.id)
  113. # add outlier
  114. event_data = load_data("transaction", timestamp=before_now(minutes=1))
  115. event_data["contexts"]["trace"]["op"] = "pageload"
  116. event_data["event_id"] = "b" * 32
  117. event_data["measurements"]["fp"]["value"] = 3000000000
  118. event_data["measurements"]["fcp"]["value"] = 3000000000
  119. event_data["measurements"]["lcp"]["value"] = 3000000000
  120. event_data["measurements"]["fid"]["value"] = 3000000000
  121. event_data["measurements"]["cls"]["value"] = 3000000000
  122. self.store_event(data=event_data, project_id=self.project.id)
  123. self.wait_for_event_count(self.project.id, 5)
  124. with self.feature(FEATURE_NAMES):
  125. self.browser.get(vitals_path)
  126. self.page.wait_until_loaded()
  127. self.browser.wait_until_not('[data-test-id="stats-loading"]')
  128. self.browser.snapshot("real user monitoring - exclude outliers")
  129. self.browser.element(
  130. xpath="//button//span[contains(text(), 'Exclude Outliers')]"
  131. ).click()
  132. self.browser.element(xpath="//li//span[contains(text(), 'View All')]").click()
  133. self.browser.snapshot("real user monitoring - view all data")