test_performance_trends.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. from __future__ import absolute_import
  2. import pytz
  3. from six.moves.urllib.parse import urlencode
  4. from mock import patch
  5. from django.db.models import F
  6. from sentry.models import Project
  7. from sentry.testutils import AcceptanceTestCase, SnubaTestCase
  8. from sentry.testutils.helpers.datetime import before_now, iso_format
  9. from sentry.utils.samples import load_data
  10. from .page_objects.base import BasePage
  11. FEATURE_NAMES = (
  12. "organizations:trends",
  13. "organizations:performance-view",
  14. )
  15. class PerformanceTrendsTest(AcceptanceTestCase, SnubaTestCase):
  16. def make_trend(
  17. self, name, durations, period_mins=60,
  18. ):
  19. for index, duration in enumerate(durations):
  20. time_between = period_mins / len(durations)
  21. # distirbute events over the period
  22. minutes = period_mins - ((index + 1) * time_between) + (time_between / 2)
  23. event = load_data("transaction")
  24. event.update(
  25. {
  26. "transaction": name,
  27. "event_id": "{:02x}".format(index).rjust(32, "0"),
  28. "start_timestamp": iso_format(before_now(minutes=minutes, seconds=duration)),
  29. "timestamp": iso_format(before_now(minutes=minutes)),
  30. }
  31. )
  32. self.store_event(data=event, project_id=self.project.id)
  33. def setUp(self):
  34. super(PerformanceTrendsTest, self).setUp()
  35. self.org = self.create_organization(owner=self.user, name="Rowdy Tiger")
  36. self.team = self.create_team(
  37. organization=self.org, name="Mariachi Band", members=[self.user]
  38. )
  39. self.project = self.create_project(organization=self.org, teams=[self.team], name="Bengal")
  40. self.group = self.create_group(project=self.project)
  41. self.login_as(self.user)
  42. self.path = u"/organizations/{}/performance/?{}".format(
  43. self.org.slug,
  44. urlencode(
  45. {
  46. "view": "TRENDS",
  47. "query": "transaction.duration:>0",
  48. "statsPeriod": "1h",
  49. "project": self.project.id,
  50. }
  51. ),
  52. )
  53. self.page = BasePage(self.browser)
  54. @patch("django.utils.timezone.now")
  55. def test_with_data(self, mock_now):
  56. mock_now.return_value = before_now().replace(tzinfo=pytz.utc)
  57. values = range(1, 100, 5)
  58. self.make_trend("improvement", [v for v in reversed(values)])
  59. self.make_trend("regression", values)
  60. self.project.update(flags=F("flags").bitor(Project.flags.has_transactions))
  61. with self.feature(FEATURE_NAMES):
  62. self.browser.get(self.path)
  63. self.page.wait_until_loaded()
  64. trend_item = '[data-test-id="trends-list-item-regression"]'
  65. self.browser.wait_until(trend_item)
  66. self.browser.snapshot("performance trends - with data")