mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-23 04:52:12 +00:00 
			
		
		
		
	Previously, closing a pull request by someone other than its creator could result in Zulip notifications attributing the action to the wrong user. This change adds a focused test and a fixture capturing the case where the webhook sender differs from pull_request.user, ensuring the correct actor is mentioned for pull_request close events. Follow-up to #36184.
		
			
				
	
	
		
			116 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from unittest.mock import MagicMock, patch
 | |
| 
 | |
| from zerver.lib.test_classes import WebhookTestCase
 | |
| 
 | |
| 
 | |
| class GiteaHookTests(WebhookTestCase):
 | |
|     CHANNEL_NAME = "commits"
 | |
|     URL_TEMPLATE = "/api/v1/external/gitea?&api_key={api_key}&stream={stream}"
 | |
|     WEBHOOK_DIR_NAME = "gitea"
 | |
| 
 | |
|     def test_multiple_commits(self) -> None:
 | |
|         expected_topic_name = "test / d"
 | |
|         expected_message = """kostekIV [pushed](https://try.gitea.io/kostekIV/test/compare/21138d2ca0ce18f8e037696fdbe1b3f0c211f630...2ec0c971d04723523aa20f2b378f8b419b47d4ec) 5 commits to branch d.
 | |
| 
 | |
| * commit ([2ec0c971d04](https://try.gitea.io/kostekIV/test/commit/2ec0c971d04723523aa20f2b378f8b419b47d4ec))
 | |
| * commit ([6cb1701c8b0](https://try.gitea.io/kostekIV/test/commit/6cb1701c8b0114ad716f4cd49153076e7109cb85))
 | |
| * commit ([6773eabc077](https://try.gitea.io/kostekIV/test/commit/6773eabc0778a3e38997c06a13f5f0c48b67e5dc))
 | |
| * commit ([337402cf675](https://try.gitea.io/kostekIV/test/commit/337402cf675ce7082ddcd23d06a116c85241825a))
 | |
| * commit ([0a38cad3fac](https://try.gitea.io/kostekIV/test/commit/0a38cad3fac3a13bb78b738d13f15ce9cc3343fa))"""
 | |
|         self.check_webhook("push__5_commits", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_new_branch(self) -> None:
 | |
|         expected_topic_name = "test / test-branch"
 | |
|         expected_message = "kostekIV created [test-branch](https://try.gitea.io/kostekIV/test/src/test-branch) branch."
 | |
|         self.check_webhook("create__branch", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_pull_request_opened(self) -> None:
 | |
|         expected_topic_name = "test / PR #1905 New pr"
 | |
|         expected_message = """kostekIV opened [PR #4](https://try.gitea.io/kostekIV/test/pulls/4) from `test-branch` to `master`."""
 | |
|         self.check_webhook("pull_request__opened", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_pull_request_merged(self) -> None:
 | |
|         expected_topic_name = "zulip-terminal / PR #1905 Fix remove-op on reaction event"
 | |
|         expected_message = """kostekIV merged [PR #1905](https://try.gitea.io/kostekIV/test/pulls/4) from `reaction-metadata` to `main`."""
 | |
|         self.check_webhook("pull_request__merged", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_pull_request_edited(self) -> None:
 | |
|         expected_topic_name = "test / PR #1906 test 2"
 | |
|         expected_message = (
 | |
|             """kostekIV edited [PR #5](https://try.gitea.io/kostekIV/test/pulls/5)."""
 | |
|         )
 | |
|         self.check_webhook("pull_request__edited", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_pull_request_reopened(self) -> None:
 | |
|         expected_topic_name = "test / PR #1906 test 2"
 | |
|         expected_message = """kostekIV reopened [PR #5](https://try.gitea.io/kostekIV/test/pulls/5) from `d` to `master`."""
 | |
|         self.check_webhook("pull_request__reopened", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_pull_request_closed(self) -> None:
 | |
|         expected_topic_name = "test / PR #1906 test 2"
 | |
|         expected_message = """kostekIV closed [PR #5](https://try.gitea.io/kostekIV/test/pulls/5) from `d` to `master`."""
 | |
|         self.check_webhook("pull_request__closed", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_pull_request_closed_different_user(self) -> None:
 | |
|         expected_topic_name = "test / PR #126085 PR closed"
 | |
|         expected_message = """Aneesh-Hegde closed [PR #1](https://gitea.com/Aneesh-Hegde/test-repo/pulls/1) from `main` to `main`."""
 | |
|         self.check_webhook("pull_request__closed_diff_user", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_pull_request_assigned(self) -> None:
 | |
|         expected_topic_name = "test / PR #1906 test 2"
 | |
|         expected_message = """kostekIV assigned kostekIV to [PR #5](https://try.gitea.io/kostekIV/test/pulls/5) from `d` to `master` (assigned to kostekIV)."""
 | |
|         self.check_webhook("pull_request__assigned", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_issues_opened(self) -> None:
 | |
|         expected_topic_name = "test / issue #3 Test issue"
 | |
|         expected_message = """kostekIV opened [issue #3](https://try.gitea.io/kostekIV/test/issues/3):\n\n~~~ quote\nTest body\n~~~"""
 | |
|         self.check_webhook("issues__opened", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_issues_edited(self) -> None:
 | |
|         expected_topic_name = "test / issue #3 Test issue 2"
 | |
|         expected_message = """kostekIV edited [issue #3](https://try.gitea.io/kostekIV/test/issues/3) (assigned to kostekIV):\n\n~~~ quote\nTest body\n~~~"""
 | |
|         self.check_webhook("issues__edited", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_issues_closed(self) -> None:
 | |
|         expected_topic_name = "test / issue #3 Test issue 2"
 | |
|         expected_message = """kostekIV closed [issue #3](https://try.gitea.io/kostekIV/test/issues/3) (assigned to kostekIV):\n\n~~~ quote\nTest body\n~~~"""
 | |
|         self.check_webhook("issues__closed", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_issues_assigned(self) -> None:
 | |
|         expected_topic_name = "test / issue #3 Test issue"
 | |
|         expected_message = """kostekIV assigned kostekIV to [issue #3](https://try.gitea.io/kostekIV/test/issues/3) (assigned to kostekIV):\n\n~~~ quote\nTest body\n~~~"""
 | |
|         self.check_webhook("issues__assigned", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_issues_reopened(self) -> None:
 | |
|         expected_topic_name = "test / issue #3 Test issue 2"
 | |
|         expected_message = """kostekIV reopened [issue #3](https://try.gitea.io/kostekIV/test/issues/3) (assigned to kostekIV):\n\n~~~ quote\nTest body\n~~~"""
 | |
|         self.check_webhook("issues__reopened", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_issue_comment_new(self) -> None:
 | |
|         expected_topic_name = "test / issue #3 Test issue"
 | |
|         expected_message = """kostekIV [commented](https://try.gitea.io/kostekIV/test/issues/3#issuecomment-24400) on [issue #3](https://try.gitea.io/kostekIV/test/issues/3):\n\n~~~ quote\ntest comment\n~~~"""
 | |
|         self.check_webhook("issue_comment__new", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_issue_comment_in_pr(self) -> None:
 | |
|         expected_topic_name = "test / issue #1 dummy"
 | |
|         expected_message = """kostekIV [commented](https://try.gitea.io/kostekIV/test/pulls/1/files#issuecomment-24399) on [issue #1](https://try.gitea.io/kostekIV/test/issues/1):\n\n~~~ quote\ntest comment\n~~~"""
 | |
|         self.check_webhook("issue_comment__in_pr", expected_topic_name, expected_message)
 | |
| 
 | |
|     def test_issue_comment_edited(self) -> None:
 | |
|         expected_topic_name = "test / issue #3 Test issue 2"
 | |
|         expected_message = """kostekIV edited a [comment](https://try.gitea.io/kostekIV/test/issues/3#issuecomment-24400) on [issue #3](https://try.gitea.io/kostekIV/test/issues/3):\n\n~~~ quote\nedit test comment\n~~~"""
 | |
| 
 | |
|         self.check_webhook("issue_comment__edited", expected_topic_name, expected_message)
 | |
| 
 | |
|     @patch("zerver.webhooks.gogs.view.check_send_webhook_message")
 | |
|     def test_push_filtered_by_branches_ignore(
 | |
|         self, check_send_webhook_message_mock: MagicMock
 | |
|     ) -> None:
 | |
|         self.url = self.build_webhook_url(branches="changes,development")
 | |
|         payload = self.get_body("push__5_commits")
 | |
|         result = self.client_post(
 | |
|             self.url, payload, HTTP_X_GITEA_EVENT="push", content_type="application/json"
 | |
|         )
 | |
|         self.assertFalse(check_send_webhook_message_mock.called)
 | |
|         self.assert_json_success(result)
 |