123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- import datetime
- from django.urls import reverse
- from django.utils import timezone
- from freezegun import freeze_time
- from model_bakery import baker
- from glitchtip.test_utils.test_case import GlitchTipTestCase
- class TransactionAPITestCase(GlitchTipTestCase):
- def setUp(self):
- self.create_user_and_project()
- self.list_url = reverse(
- "organization-transactions-list",
- kwargs={"organization_slug": self.organization.slug},
- )
- def test_list(self):
- transaction = baker.make(
- "performance.TransactionEvent", group__project=self.project
- )
- res = self.client.get(self.list_url)
- self.assertContains(res, transaction.event_id)
- class TransactionGroupAPITestCase(GlitchTipTestCase):
- def setUp(self):
- self.create_user_and_project()
- self.list_url = reverse(
- "organization-transaction-groups-list",
- kwargs={"organization_slug": self.organization.slug},
- )
- def test_list(self):
- group = baker.make("performance.TransactionGroup", project=self.project)
- res = self.client.get(self.list_url)
- self.assertContains(res, group.transaction)
- def test_list_relative_datetime_filter(self):
- group = baker.make("performance.TransactionGroup", project=self.project)
- now = timezone.now()
- last_minute = now - datetime.timedelta(minutes=1)
- with freeze_time(last_minute):
- baker.make(
- "performance.TransactionEvent",
- group=group,
- start_timestamp=last_minute,
- timestamp=last_minute + datetime.timedelta(seconds=5),
- duration=5000,
- )
- two_minutes_ago = now - datetime.timedelta(minutes=2)
- with freeze_time(two_minutes_ago):
- baker.make(
- "performance.TransactionEvent",
- group=group,
- start_timestamp=two_minutes_ago,
- timestamp=two_minutes_ago + datetime.timedelta(seconds=1),
- duration=1000,
- )
- yesterday = now - datetime.timedelta(days=1)
- with freeze_time(yesterday):
- baker.make(
- "performance.TransactionEvent",
- group=group,
- start_timestamp=yesterday,
- timestamp=yesterday + datetime.timedelta(seconds=1),
- duration=1000,
- )
- with freeze_time(now):
- res = self.client.get(self.list_url, {"start": last_minute})
- self.assertEqual(res.status_code, 200)
- self.assertEqual(res.data[0]["transactionCount"], 1)
- with freeze_time(now):
- res = self.client.get(self.list_url, {"start": "now-1m", "end": "now"})
- self.assertEqual(res.status_code, 200)
- self.assertEqual(res.data[0]["transactionCount"], 1)
- with freeze_time(now):
- res = self.client.get(self.list_url, {"start": "now-2m"})
- self.assertEqual(res.status_code, 200)
- self.assertEqual(res.data[0]["transactionCount"], 2)
- with freeze_time(now):
- res = self.client.get(self.list_url, {"end": "now-1d"})
- self.assertEqual(res.status_code, 200)
- self.assertEqual(res.data[0]["transactionCount"], 1)
- with freeze_time(now):
- res = self.client.get(self.list_url, {"end": "now-24h"})
- self.assertEqual(res.status_code, 200)
- self.assertEqual(res.data[0]["transactionCount"], 1)
- with freeze_time(now):
- res = self.client.get(self.list_url, {"end": "now"})
- self.assertEqual(res.status_code, 200)
- self.assertEqual(res.data[0]["transactionCount"], 3)
- def test_list_relative_parsing(self):
- res = self.client.get(self.list_url, {"start": "now-1h "})
- self.assertEqual(res.status_code, 200)
- res = self.client.get(self.list_url, {"start": "now - 1h"})
- self.assertEqual(res.status_code, 200)
- res = self.client.get(self.list_url, {"start": "now-1"})
- self.assertEqual(res.status_code, 400)
- res = self.client.get(self.list_url, {"start": "now-1minute"})
- self.assertEqual(res.status_code, 400)
- res = self.client.get(self.list_url, {"start": "won-1m"})
- self.assertEqual(res.status_code, 400)
- res = self.client.get(self.list_url, {"start": "now+1m"})
- self.assertEqual(res.status_code, 400)
- res = self.client.get(self.list_url, {"start": "now 1m"})
- self.assertEqual(res.status_code, 400)
- def test_list_environment_filter(self):
- environment_project = baker.make(
- "environments.EnvironmentProject",
- environment__organization=self.organization,
- )
- environment = environment_project.environment
- environment.projects.add(self.project)
- group1 = baker.make(
- "performance.TransactionGroup",
- project=self.project,
- tags={"environment": [environment.name]},
- )
- group2 = baker.make("performance.TransactionGroup", project=self.project)
- res = self.client.get(self.list_url, {"environment": environment.name})
- self.assertContains(res, group1.transaction)
- self.assertNotContains(res, group2.transaction)
- def test_filter_then_average(self):
- group = baker.make("performance.TransactionGroup", project=self.project)
- now = timezone.now()
- last_minute = now - datetime.timedelta(minutes=1)
- with freeze_time(last_minute):
- baker.make(
- "performance.TransactionEvent",
- group=group,
- start_timestamp=last_minute,
- timestamp=last_minute + datetime.timedelta(seconds=5),
- duration=5000,
- )
- transaction2 = baker.make(
- "performance.TransactionEvent",
- group=group,
- start_timestamp=now,
- timestamp=now + datetime.timedelta(seconds=1),
- duration=1000,
- )
- res = self.client.get(self.list_url)
- self.assertEqual(res.data[0]["avgDuration"], 3000)
- res = self.client.get(
- self.list_url
- + "?start="
- + transaction2.created.replace(microsecond=0)
- .replace(tzinfo=None)
- .isoformat()
- + "Z"
- )
- self.assertEqual(res.data[0]["avgDuration"], 1000)
- class SpanAPITestCase(GlitchTipTestCase):
- def setUp(self):
- self.create_user_and_project()
- self.list_url = reverse(
- "organization-spans-list",
- kwargs={"organization_slug": self.organization.slug},
- )
- def test_list(self):
- span = baker.make("performance.Span", transaction__group__project=self.project)
- res = self.client.get(self.list_url)
- self.assertContains(res, span.op)
|