mirror of
https://github.com/zulip/zulip.git
synced 2025-11-06 23:13:25 +00:00
webhooks: Migrate to check_send_stream_message.
This commit migrates all webhooks to use check_send_stream_message instead of check_send_message. The only two webhooks that still use check_send_message are our yo and teamcity webhooks. They both use check_send_message for private messages.
This commit is contained in:
@@ -248,70 +248,70 @@ class GithubWebhookTest(WebhookTestCase):
|
||||
HTTP_X_GITHUB_EVENT='pull_request'
|
||||
)
|
||||
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_message')
|
||||
def test_pull_request_labeled_ignore(self, check_send_message_mock):
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_stream_message')
|
||||
def test_pull_request_labeled_ignore(self, check_send_stream_message_mock):
|
||||
# type: (MagicMock) -> None
|
||||
payload = self.get_body('labeled_pull_request')
|
||||
result = self.client_post(self.url, payload, HTTP_X_GITHUB_EVENT='pull_request', content_type="application/json")
|
||||
self.assertFalse(check_send_message_mock.called)
|
||||
self.assertFalse(check_send_stream_message_mock.called)
|
||||
self.assert_json_success(result)
|
||||
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_message')
|
||||
def test_pull_request_unlabeled_ignore(self, check_send_message_mock):
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_stream_message')
|
||||
def test_pull_request_unlabeled_ignore(self, check_send_stream_message_mock):
|
||||
# type: (MagicMock) -> None
|
||||
payload = self.get_body('unlabeled_pull_request')
|
||||
result = self.client_post(self.url, payload, HTTP_X_GITHUB_EVENT='pull_request', content_type="application/json")
|
||||
self.assertFalse(check_send_message_mock.called)
|
||||
self.assertFalse(check_send_stream_message_mock.called)
|
||||
self.assert_json_success(result)
|
||||
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_message')
|
||||
def test_pull_request_request_review_ignore(self, check_send_message_mock):
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_stream_message')
|
||||
def test_pull_request_request_review_ignore(self, check_send_stream_message_mock):
|
||||
# type: (MagicMock) -> None
|
||||
payload = self.get_body('request_review_pull_request')
|
||||
result = self.client_post(self.url, payload, HTTP_X_GITHUB_EVENT='pull_request', content_type="application/json")
|
||||
self.assertFalse(check_send_message_mock.called)
|
||||
self.assertFalse(check_send_stream_message_mock.called)
|
||||
self.assert_json_success(result)
|
||||
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_message')
|
||||
def test_pull_request_request_review_remove_ignore(self, check_send_message_mock):
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_stream_message')
|
||||
def test_pull_request_request_review_remove_ignore(self, check_send_stream_message_mock):
|
||||
# type: (MagicMock) -> None
|
||||
payload = self.get_body('request_review_removed_pull_request')
|
||||
result = self.client_post(self.url, payload, HTTP_X_GITHUB_EVENT='pull_request', content_type="application/json")
|
||||
self.assertFalse(check_send_message_mock.called)
|
||||
self.assertFalse(check_send_stream_message_mock.called)
|
||||
self.assert_json_success(result)
|
||||
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_message')
|
||||
def test_push_1_commit_filtered_by_branches_ignore(self, check_send_message_mock):
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_stream_message')
|
||||
def test_push_1_commit_filtered_by_branches_ignore(self, check_send_stream_message_mock):
|
||||
# type: (MagicMock) -> None
|
||||
self.url = self.build_webhook_url(branches='master,development')
|
||||
payload = self.get_body('push_1_commit')
|
||||
result = self.client_post(self.url, payload, HTTP_X_GITHUB_EVENT='push', content_type="application/json")
|
||||
self.assertFalse(check_send_message_mock.called)
|
||||
self.assertFalse(check_send_stream_message_mock.called)
|
||||
self.assert_json_success(result)
|
||||
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_message')
|
||||
def test_push_50_commits_filtered_by_branches_ignore(self, check_send_message_mock):
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_stream_message')
|
||||
def test_push_50_commits_filtered_by_branches_ignore(self, check_send_stream_message_mock):
|
||||
# type: (MagicMock) -> None
|
||||
self.url = self.build_webhook_url(branches='master,development')
|
||||
payload = self.get_body('push_50_commits')
|
||||
result = self.client_post(self.url, payload, HTTP_X_GITHUB_EVENT='push', content_type="application/json")
|
||||
self.assertFalse(check_send_message_mock.called)
|
||||
self.assertFalse(check_send_stream_message_mock.called)
|
||||
self.assert_json_success(result)
|
||||
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_message')
|
||||
def test_push_multiple_comitters_filtered_by_branches_ignore(self, check_send_message_mock):
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_stream_message')
|
||||
def test_push_multiple_comitters_filtered_by_branches_ignore(self, check_send_stream_message_mock):
|
||||
# type: (MagicMock) -> None
|
||||
self.url = self.build_webhook_url(branches='master,development')
|
||||
payload = self.get_body('push_multiple_committers')
|
||||
result = self.client_post(self.url, payload, HTTP_X_GITHUB_EVENT='push', content_type="application/json")
|
||||
self.assertFalse(check_send_message_mock.called)
|
||||
self.assertFalse(check_send_stream_message_mock.called)
|
||||
self.assert_json_success(result)
|
||||
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_message')
|
||||
def test_push_multiple_comitters_with_others_filtered_by_branches_ignore(self, check_send_message_mock):
|
||||
@patch('zerver.webhooks.github_webhook.view.check_send_stream_message')
|
||||
def test_push_multiple_comitters_with_others_filtered_by_branches_ignore(self, check_send_stream_message_mock):
|
||||
# type: (MagicMock) -> None
|
||||
self.url = self.build_webhook_url(branches='master,development')
|
||||
payload = self.get_body('push_multiple_committers_with_others')
|
||||
result = self.client_post(self.url, payload, HTTP_X_GITHUB_EVENT='push', content_type="application/json")
|
||||
self.assertFalse(check_send_message_mock.called)
|
||||
self.assertFalse(check_send_stream_message_mock.called)
|
||||
self.assert_json_success(result)
|
||||
|
||||
@@ -3,7 +3,7 @@ import logging
|
||||
from functools import partial
|
||||
from typing import Any, Callable, Text, Dict, Optional
|
||||
from django.http import HttpRequest, HttpResponse
|
||||
from zerver.lib.actions import check_send_message
|
||||
from zerver.lib.actions import check_send_stream_message
|
||||
from zerver.lib.response import json_success
|
||||
from zerver.lib.request import JsonableError
|
||||
from zerver.models import UserProfile
|
||||
@@ -406,7 +406,7 @@ def api_github_webhook(
|
||||
if event is not None:
|
||||
subject = get_subject_based_on_type(payload, event)
|
||||
body = get_body_function_based_on_type(event)(payload)
|
||||
check_send_message(user_profile, request.client, 'stream', [stream], subject, body)
|
||||
check_send_stream_message(user_profile, request.client, stream, subject, body)
|
||||
return json_success()
|
||||
|
||||
def get_event(request, payload, branches):
|
||||
|
||||
Reference in New Issue
Block a user