25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

160 lines
5.6 KiB

  1. # -*- coding: utf-8 -*-
  2. # Copyright 2015, 2016 OpenMarket Ltd
  3. #
  4. # Licensed under the Apache License, Version 2.0 (the "License");
  5. # you may not use this file except in compliance with the License.
  6. # You may obtain a copy of the License at
  7. #
  8. # http://www.apache.org/licenses/LICENSE-2.0
  9. #
  10. # Unless required by applicable law or agreed to in writing, software
  11. # distributed under the License is distributed on an "AS IS" BASIS,
  12. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. # See the License for the specific language governing permissions and
  14. # limitations under the License.
  15. import synapse.types
  16. from synapse.api.errors import Codes
  17. from synapse.http.server import JsonResource
  18. from synapse.rest.client.v2_alpha import filter
  19. from synapse.types import UserID
  20. from synapse.util import Clock
  21. from tests import unittest
  22. from tests.server import (
  23. ThreadedMemoryReactorClock as MemoryReactorClock,
  24. make_request,
  25. setup_test_homeserver,
  26. wait_until_result,
  27. )
  28. PATH_PREFIX = "/_matrix/client/v2_alpha"
  29. class FilterTestCase(unittest.TestCase):
  30. USER_ID = "@apple:test"
  31. EXAMPLE_FILTER = {"room": {"timeline": {"types": ["m.room.message"]}}}
  32. EXAMPLE_FILTER_JSON = b'{"room": {"timeline": {"types": ["m.room.message"]}}}'
  33. TO_REGISTER = [filter]
  34. def setUp(self):
  35. self.clock = MemoryReactorClock()
  36. self.hs_clock = Clock(self.clock)
  37. self.hs = setup_test_homeserver(
  38. self.addCleanup, http_client=None, clock=self.hs_clock, reactor=self.clock
  39. )
  40. self.auth = self.hs.get_auth()
  41. def get_user_by_access_token(token=None, allow_guest=False):
  42. return {
  43. "user": UserID.from_string(self.USER_ID),
  44. "token_id": 1,
  45. "is_guest": False,
  46. }
  47. def get_user_by_req(request, allow_guest=False, rights="access"):
  48. return synapse.types.create_requester(
  49. UserID.from_string(self.USER_ID), 1, False, None
  50. )
  51. self.auth.get_user_by_access_token = get_user_by_access_token
  52. self.auth.get_user_by_req = get_user_by_req
  53. self.store = self.hs.get_datastore()
  54. self.filtering = self.hs.get_filtering()
  55. self.resource = JsonResource(self.hs)
  56. for r in self.TO_REGISTER:
  57. r.register_servlets(self.hs, self.resource)
  58. def test_add_filter(self):
  59. request, channel = make_request(
  60. "POST",
  61. "/_matrix/client/r0/user/%s/filter" % (self.USER_ID),
  62. self.EXAMPLE_FILTER_JSON,
  63. )
  64. request.render(self.resource)
  65. wait_until_result(self.clock, channel)
  66. self.assertEqual(channel.result["code"], b"200")
  67. self.assertEqual(channel.json_body, {"filter_id": "0"})
  68. filter = self.store.get_user_filter(user_localpart="apple", filter_id=0)
  69. self.clock.advance(0)
  70. self.assertEquals(filter.result, self.EXAMPLE_FILTER)
  71. def test_add_filter_for_other_user(self):
  72. request, channel = make_request(
  73. "POST",
  74. "/_matrix/client/r0/user/%s/filter" % ("@watermelon:test"),
  75. self.EXAMPLE_FILTER_JSON,
  76. )
  77. request.render(self.resource)
  78. wait_until_result(self.clock, channel)
  79. self.assertEqual(channel.result["code"], b"403")
  80. self.assertEquals(channel.json_body["errcode"], Codes.FORBIDDEN)
  81. def test_add_filter_non_local_user(self):
  82. _is_mine = self.hs.is_mine
  83. self.hs.is_mine = lambda target_user: False
  84. request, channel = make_request(
  85. "POST",
  86. "/_matrix/client/r0/user/%s/filter" % (self.USER_ID),
  87. self.EXAMPLE_FILTER_JSON,
  88. )
  89. request.render(self.resource)
  90. wait_until_result(self.clock, channel)
  91. self.hs.is_mine = _is_mine
  92. self.assertEqual(channel.result["code"], b"403")
  93. self.assertEquals(channel.json_body["errcode"], Codes.FORBIDDEN)
  94. def test_get_filter(self):
  95. filter_id = self.filtering.add_user_filter(
  96. user_localpart="apple", user_filter=self.EXAMPLE_FILTER
  97. )
  98. self.clock.advance(1)
  99. filter_id = filter_id.result
  100. request, channel = make_request(
  101. "GET", "/_matrix/client/r0/user/%s/filter/%s" % (self.USER_ID, filter_id)
  102. )
  103. request.render(self.resource)
  104. wait_until_result(self.clock, channel)
  105. self.assertEqual(channel.result["code"], b"200")
  106. self.assertEquals(channel.json_body, self.EXAMPLE_FILTER)
  107. def test_get_filter_non_existant(self):
  108. request, channel = make_request(
  109. "GET", "/_matrix/client/r0/user/%s/filter/12382148321" % (self.USER_ID)
  110. )
  111. request.render(self.resource)
  112. wait_until_result(self.clock, channel)
  113. self.assertEqual(channel.result["code"], b"400")
  114. self.assertEquals(channel.json_body["errcode"], Codes.NOT_FOUND)
  115. # Currently invalid params do not have an appropriate errcode
  116. # in errors.py
  117. def test_get_filter_invalid_id(self):
  118. request, channel = make_request(
  119. "GET", "/_matrix/client/r0/user/%s/filter/foobar" % (self.USER_ID)
  120. )
  121. request.render(self.resource)
  122. wait_until_result(self.clock, channel)
  123. self.assertEqual(channel.result["code"], b"400")
  124. # No ID also returns an invalid_id error
  125. def test_get_filter_no_id(self):
  126. request, channel = make_request(
  127. "GET", "/_matrix/client/r0/user/%s/filter/" % (self.USER_ID)
  128. )
  129. request.render(self.resource)
  130. wait_until_result(self.clock, channel)
  131. self.assertEqual(channel.result["code"], b"400")