test_project_events.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. from __future__ import absolute_import
  2. from django.core.urlresolvers import reverse
  3. from sentry.testutils import APITestCase, SnubaTestCase
  4. from sentry.testutils.helpers.datetime import before_now, iso_format
  5. from sentry.utils.compat import map
  6. class ProjectEventsTest(APITestCase, SnubaTestCase):
  7. def test_simple(self):
  8. self.login_as(user=self.user)
  9. project = self.create_project()
  10. event_1 = self.store_event(
  11. data={"timestamp": iso_format(before_now(minutes=1))}, project_id=project.id
  12. )
  13. event_2 = self.store_event(
  14. data={"timestamp": iso_format(before_now(minutes=1))}, project_id=project.id
  15. )
  16. url = reverse(
  17. "sentry-api-0-project-events",
  18. kwargs={"organization_slug": project.organization.slug, "project_slug": project.slug},
  19. )
  20. response = self.client.get(url, format="json")
  21. assert response.status_code == 200, response.content
  22. assert len(response.data) == 2
  23. assert sorted(map(lambda x: x["eventID"], response.data)) == sorted(
  24. [event_1.event_id, event_2.event_id]
  25. )
  26. def test_message_search(self):
  27. self.login_as(user=self.user)
  28. project = self.create_project()
  29. self.store_event(
  30. data={"message": "how to make fast", "timestamp": iso_format(before_now(minutes=1))},
  31. project_id=project.id,
  32. )
  33. event_2 = self.store_event(
  34. data={"message": "Delet the Data", "timestamp": iso_format(before_now(minutes=1))},
  35. project_id=project.id,
  36. )
  37. url = reverse(
  38. "sentry-api-0-project-events",
  39. kwargs={"organization_slug": project.organization.slug, "project_slug": project.slug},
  40. )
  41. response = self.client.get(url, {"query": "delet"}, format="json")
  42. assert response.status_code == 200, response.content
  43. assert len(response.data) == 1
  44. assert response.data[0]["eventID"] == event_2.event_id
  45. assert response.data[0]["message"] == "Delet the Data"
  46. def test_filters_based_on_retention(self):
  47. self.login_as(user=self.user)
  48. project = self.create_project()
  49. self.store_event(data={"timestamp": iso_format(before_now(days=2))}, project_id=project.id)
  50. event_2 = self.store_event(
  51. data={"timestamp": iso_format(before_now(minutes=1))}, project_id=project.id
  52. )
  53. with self.options({"system.event-retention-days": 1}):
  54. url = reverse(
  55. "sentry-api-0-project-events",
  56. kwargs={
  57. "organization_slug": project.organization.slug,
  58. "project_slug": project.slug,
  59. },
  60. )
  61. response = self.client.get(url, format="json")
  62. assert response.status_code == 200, response.content
  63. assert len(response.data) == 1
  64. assert response.data[0]["eventID"] == event_2.event_id