test_plugin.py 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. from datetime import timedelta
  2. from unittest.mock import Mock, patch
  3. from django.utils import timezone
  4. from sentry.exceptions import HookValidationError
  5. from sentry.models import (
  6. Commit,
  7. Deploy,
  8. Environment,
  9. ProjectOption,
  10. Release,
  11. ReleaseCommit,
  12. ReleaseHeadCommit,
  13. Repository,
  14. User,
  15. )
  16. from sentry.testutils import TestCase
  17. from sentry_plugins.heroku.plugin import HerokuReleaseHook
  18. class SetRefsTest(TestCase):
  19. """
  20. tests that when finish_release is called on a release hook,
  21. we try to get the previous commits based on the version ref
  22. and that we create `ReleaseHeadCommit`s for the version
  23. """
  24. @patch("sentry.tasks.commits.fetch_commits")
  25. def test_minimal(self, mock_fetch_commits):
  26. project = self.create_project()
  27. version = "bbee5b51f84611e4b14834363b8514c2"
  28. data_list = [
  29. {
  30. "id": "c7155651831549cf8a5e47889fce17eb",
  31. "message": "foo",
  32. "author_email": "jane@example.com",
  33. },
  34. {
  35. "id": "62de626b7c7cfb8e77efb4273b1a3df4123e6216",
  36. "message": "hello",
  37. "author_name": "Jess",
  38. },
  39. {
  40. "id": "58de626b7c7cfb8e77efb4273b1a3df4123e6345",
  41. "message": "bar",
  42. "author_name": "Joe^^",
  43. },
  44. {
  45. "id": "bbee5b51f84611e4b14834363b8514c2",
  46. "message": "blah",
  47. "author_email": "katie@example.com",
  48. },
  49. ]
  50. user = User.objects.create(email="stebe@sentry.io")
  51. repo = Repository.objects.create(
  52. organization_id=project.organization_id, name=project.name, provider="dummy"
  53. )
  54. ProjectOption.objects.set_value(key="heroku:repository", project=project, value=repo.name)
  55. for data in data_list:
  56. Commit.objects.create(
  57. key=data["id"], organization_id=self.project.organization_id, repository_id=repo.id
  58. )
  59. old_release = Release.objects.create(
  60. version="a" * 40,
  61. organization_id=project.organization_id,
  62. date_added=timezone.now() - timedelta(minutes=30),
  63. )
  64. old_release.add_project(project)
  65. ReleaseCommit.objects.create(
  66. organization_id=project.organization_id,
  67. project_id=project.id,
  68. release=old_release,
  69. commit=Commit.objects.get(key="c7155651831549cf8a5e47889fce17eb"),
  70. order=0,
  71. )
  72. ReleaseHeadCommit.objects.create(
  73. organization_id=project.organization_id,
  74. repository_id=repo.id,
  75. release=old_release,
  76. commit=Commit.objects.get(key="c7155651831549cf8a5e47889fce17eb"),
  77. )
  78. release_heads = ReleaseHeadCommit.objects.filter(
  79. organization_id=project.organization_id,
  80. repository_id=repo.id,
  81. commit=Commit.objects.get(key="bbee5b51f84611e4b14834363b8514c2"),
  82. )
  83. assert len(release_heads) == 0
  84. hook = HerokuReleaseHook(project)
  85. hook.finish_release(version=version, owner=user)
  86. release = Release.objects.get(projects=project, version=version)
  87. new_release_heads = ReleaseHeadCommit.objects.filter(
  88. organization_id=project.organization_id,
  89. repository_id=repo.id,
  90. release=release,
  91. commit=Commit.objects.get(key="bbee5b51f84611e4b14834363b8514c2"),
  92. )
  93. assert len(new_release_heads) == 1
  94. assert release.version == "bbee5b51f84611e4b14834363b8514c2"
  95. deploy = Deploy.objects.filter(
  96. organization_id=project.organization_id,
  97. release=release,
  98. environment_id=Environment.objects.get(
  99. organization_id=project.organization_id, name="production"
  100. ).id,
  101. )
  102. assert len(deploy) == 1
  103. mock_fetch_commits.apply_async.assert_called_with(
  104. kwargs={
  105. "release_id": release.id,
  106. "user_id": user.id,
  107. "refs": [{"commit": "bbee5b51f84611e4b14834363b8514c2", "repository": repo.name}],
  108. "prev_release_id": old_release.id,
  109. }
  110. )
  111. class HookHandleTest(TestCase):
  112. def test_user_success(self):
  113. user = self.create_user()
  114. organization = self.create_organization(owner=user)
  115. project = self.create_project(organization=organization)
  116. hook = HerokuReleaseHook(project)
  117. hook.set_refs = Mock()
  118. req = Mock()
  119. req.POST = {"head_long": "abcd123", "url": "http://example.com", "user": user.email}
  120. hook.handle(req)
  121. assert Release.objects.filter(version=req.POST["head_long"]).exists()
  122. assert hook.set_refs.call_count == 1
  123. def test_actor_email_success(self):
  124. user = self.create_user()
  125. organization = self.create_organization(owner=user)
  126. project = self.create_project(organization=organization)
  127. hook = HerokuReleaseHook(project)
  128. hook.set_refs = Mock()
  129. req = Mock()
  130. req.POST = {
  131. "head_long": "v999",
  132. "url": "http://example.com",
  133. "actor": {"email": user.email},
  134. }
  135. hook.handle(req)
  136. assert Release.objects.filter(version=req.POST["head_long"]).exists()
  137. assert hook.set_refs.call_count == 1
  138. def test_email_mismatch(self):
  139. user = self.create_user()
  140. organization = self.create_organization(owner=user)
  141. project = self.create_project(organization=organization)
  142. hook = HerokuReleaseHook(project)
  143. req = Mock()
  144. req.POST = {"head_long": "v999", "url": "http://example.com", "user": "wrong@example.com"}
  145. hook.handle(req)
  146. assert Release.objects.filter(version=req.POST["head_long"]).exists()
  147. def test_bad_version(self):
  148. project = self.create_project()
  149. user = self.create_user()
  150. hook = HerokuReleaseHook(project)
  151. req = Mock()
  152. req.POST = {"head_long": "", "url": "http://example.com", "user": user.email}
  153. with self.assertRaises(HookValidationError):
  154. hook.handle(req)