123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- import pytest
- from django.urls import reverse
- from sentry.api.serializers import serialize
- from sentry.discover.models import DiscoverSavedQuery, DiscoverSavedQueryTypes
- from sentry.testutils.cases import BaseMetricsTestCase
- from sentry.testutils.helpers.datetime import before_now
- from tests.snuba.api.endpoints.test_discover_saved_queries import DiscoverSavedQueryBase
- FEATURES = ("organizations:discover-query", "organizations:performance-use-metrics")
- pytestmark = pytest.mark.sentry_metrics
- class DiscoverHomepageQueryTest(DiscoverSavedQueryBase):
- def setUp(self):
- super().setUp()
- self.url = reverse("sentry-api-0-discover-homepage-query", args=[self.org.slug])
- self.query = {"fields": ["test"], "conditions": [], "limit": 10}
- self.project_ids = [
- self.create_project(organization=self.org).id,
- self.create_project(organization=self.org).id,
- ]
- def test_returns_no_response_if_no_homepage_query_for_user(self):
- with self.feature(FEATURES):
- response = self.client.get(self.url)
- assert response.status_code == 204, response.content
- assert response.data is None
- def test_returns_serialized_saved_query_if_homepage_is_set(self):
- saved_query = DiscoverSavedQuery.objects.create(
- organization=self.org,
- created_by_id=self.user.id,
- name="Test query",
- query=self.query,
- is_homepage=True,
- )
- with self.feature(FEATURES):
- response = self.client.get(self.url)
- assert response.status_code == 200, response.content
- assert response.data == serialize(saved_query)
- def test_put_updates_existing_homepage_query_to_reflect_new_data(self):
- saved_query = DiscoverSavedQuery.objects.create(
- organization=self.org,
- created_by_id=self.user.id,
- name="Test query",
- query=self.query,
- dataset=DiscoverSavedQueryTypes.DISCOVER,
- is_homepage=True,
- )
- with self.feature(FEATURES):
- response = self.client.put(
- self.url,
- {
- "name": "A new homepage query update",
- "projects": self.project_ids,
- "fields": ["field1", "field2"],
- "queryDataset": DiscoverSavedQueryTypes.get_type_name(
- DiscoverSavedQueryTypes.TRANSACTION_LIKE
- ),
- },
- )
- assert response.status_code == 200, response.content
- saved_query.refresh_from_db()
- assert response.data == serialize(saved_query)
- assert saved_query.query["fields"] == ["field1", "field2"]
- assert saved_query.dataset == DiscoverSavedQueryTypes.TRANSACTION_LIKE
- assert set(saved_query.projects.values_list("id", flat=True)) == set(self.project_ids)
- def test_put_creates_new_discover_saved_query_if_none_exists(self):
- homepage_query_payload = {
- "version": 2,
- "name": "New Homepage Query",
- "projects": self.project_ids,
- "environment": ["alpha"],
- "fields": ["environment", "platform.name"],
- "orderby": "-timestamp",
- "range": None,
- }
- with self.feature(FEATURES):
- response = self.client.put(self.url, data=homepage_query_payload)
- assert response.status_code == 201, response.content
- new_query = DiscoverSavedQuery.objects.get(
- created_by_id=self.user.id, organization=self.org, is_homepage=True
- )
- assert response.data == serialize(new_query)
- assert new_query.query["fields"] == homepage_query_payload["fields"]
- assert new_query.query["environment"] == homepage_query_payload["environment"]
- assert new_query.dataset == DiscoverSavedQueryTypes.get_id_for_type_name("error-events")
- assert set(new_query.projects.values_list("id", flat=True)) == set(self.project_ids)
- def test_put_responds_with_saved_empty_name_field(self):
- homepage_query_payload = {
- "version": 2,
- "name": "New Homepage Query",
- "projects": self.project_ids,
- "environment": ["alpha"],
- "fields": ["environment", "platform.name"],
- "orderby": "-timestamp",
- "range": None,
- }
- with self.feature(FEATURES):
- response = self.client.put(self.url, data=homepage_query_payload)
- assert response.status_code == 201, response.content
- new_query = DiscoverSavedQuery.objects.get(
- created_by_id=self.user.id, organization=self.org, is_homepage=True
- )
- assert new_query.name == ""
- assert response.data["name"] == ""
- def test_put_with_no_name(self):
- homepage_query_payload = {
- "version": 2,
- "name": "",
- "projects": self.project_ids,
- "environment": ["alpha"],
- "fields": ["environment", "platform.name"],
- "orderby": "-timestamp",
- "range": None,
- }
- with self.feature(FEATURES):
- response = self.client.put(self.url, data=homepage_query_payload)
- assert response.status_code == 201, response.content
- new_query = DiscoverSavedQuery.objects.get(
- created_by_id=self.user.id, organization=self.org, is_homepage=True
- )
- assert new_query.name == ""
- assert response.data["name"] == ""
- def test_post_not_allowed(self):
- homepage_query_payload = {
- "version": 2,
- "name": "New Homepage Query",
- "projects": ["-1"],
- "environment": ["alpha"],
- "fields": ["environment", "platform.name"],
- "orderby": "-timestamp",
- "range": None,
- }
- with self.feature(FEATURES):
- response = self.client.post(self.url, data=homepage_query_payload)
- assert response.status_code == 405, response.content
- def test_delete_resets_saved_query(self):
- DiscoverSavedQuery.objects.create(
- organization=self.org,
- created_by_id=self.user.id,
- name="Test query",
- query=self.query,
- is_homepage=True,
- )
- with self.feature(FEATURES):
- response = self.client.delete(self.url)
- assert response.status_code == 204
- assert not DiscoverSavedQuery.objects.filter(
- created_by_id=self.user.id, organization=self.org, is_homepage=True
- ).exists()
- def test_put_allows_custom_measurements_in_equations_with_query(self):
- # Having a custom measurement stored implies that a transaction with this measurement has been stored
- BaseMetricsTestCase.store_metric(
- self.org.id,
- self.project_ids[0],
- "d:transactions/measurements.custom_duration@millisecond",
- {},
- int(before_now(days=1).timestamp()),
- 1,
- )
- homepage_query_payload = {
- "version": 2,
- "name": "New Homepage Query",
- "projects": [self.project_ids[0]],
- "environment": ["alpha"],
- "fields": [
- "transaction.duration",
- "measurements.custom_duration",
- "equation|measurements.custom_duration / transaction.duration",
- ],
- "orderby": "-transaction.duration",
- "query": "test",
- "range": None,
- }
- with self.feature(FEATURES):
- response = self.client.put(self.url, data=homepage_query_payload)
- assert response.status_code == 201, response.content
- new_query = DiscoverSavedQuery.objects.get(
- created_by_id=self.user.id, organization=self.org, is_homepage=True
- )
- assert response.data == serialize(new_query)
- assert list(new_query.projects.values_list("id", flat=True)) == [self.project_ids[0]]
|