318 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Python
		
	
	
			
		
		
	
	
			318 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Python
		
	
	
| # Copyright 2021 Šimon Brandner <simon.bra.ag@gmail.com>
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| #     http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| 
 | |
| 
 | |
| from typing import List
 | |
| 
 | |
| from synapse.api.constants import ReadReceiptEventFields
 | |
| from synapse.types import JsonDict
 | |
| 
 | |
| from tests import unittest
 | |
| 
 | |
| 
 | |
| class ReceiptsTestCase(unittest.HomeserverTestCase):
 | |
|     def prepare(self, reactor, clock, hs):
 | |
|         self.event_source = hs.get_event_sources().sources.receipt
 | |
| 
 | |
|     # In the first param of _test_filters_hidden we use "hidden" instead of
 | |
|     # ReadReceiptEventFields.MSC2285_HIDDEN. We do this because we're mocking
 | |
|     # the data from the database which doesn't use the prefix
 | |
| 
 | |
|     def test_filters_out_hidden_receipt(self):
 | |
|         self._test_filters_hidden(
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@rikj:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                     "hidden": True,
 | |
|                                 }
 | |
|                             }
 | |
|                         }
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|             [],
 | |
|         )
 | |
| 
 | |
|     def test_does_not_filter_out_our_hidden_receipt(self):
 | |
|         self._test_filters_hidden(
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$1435641916hfgh4394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@me:server.org": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                     "hidden": True,
 | |
|                                 },
 | |
|                             }
 | |
|                         }
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$1435641916hfgh4394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@me:server.org": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                     ReadReceiptEventFields.MSC2285_HIDDEN: True,
 | |
|                                 },
 | |
|                             }
 | |
|                         }
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     def test_filters_out_hidden_receipt_and_ignores_rest(self):
 | |
|         self._test_filters_hidden(
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$1dgdgrd5641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@rikj:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                     "hidden": True,
 | |
|                                 },
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 },
 | |
|                             }
 | |
|                         }
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$1dgdgrd5641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         }
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     def test_filters_out_event_with_only_hidden_receipts_and_ignores_the_rest(self):
 | |
|         self._test_filters_hidden(
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$14356419edgd14394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@rikj:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                     "hidden": True,
 | |
|                                 },
 | |
|                             }
 | |
|                         },
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         },
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         }
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     def test_handles_missing_content_of_m_read(self):
 | |
|         self._test_filters_hidden(
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$14356419ggffg114394fHBLK:matrix.org": {"m.read": {}},
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         },
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$14356419ggffg114394fHBLK:matrix.org": {"m.read": {}},
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         },
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     def test_handles_empty_event(self):
 | |
|         self._test_filters_hidden(
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$143564gdfg6114394fHBLK:matrix.org": {},
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         },
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$143564gdfg6114394fHBLK:matrix.org": {},
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         },
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     def test_filters_out_receipt_event_with_only_hidden_receipt_and_ignores_rest(self):
 | |
|         self._test_filters_hidden(
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$14356419edgd14394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@rikj:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                     "hidden": True,
 | |
|                                 },
 | |
|                             }
 | |
|                         },
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 },
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         },
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 },
 | |
|             ],
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$1435641916114394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@user:jki.re": {
 | |
|                                     "ts": 1436451550453,
 | |
|                                 }
 | |
|                             }
 | |
|                         }
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 }
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     def test_handles_string_data(self):
 | |
|         """
 | |
|         Tests that an invalid shape for read-receipts is handled.
 | |
|         Context: https://github.com/matrix-org/synapse/issues/10603
 | |
|         """
 | |
| 
 | |
|         self._test_filters_hidden(
 | |
|             [
 | |
|                 {
 | |
|                     "content": {
 | |
|                         "$14356419edgd14394fHBLK:matrix.org": {
 | |
|                             "m.read": {
 | |
|                                 "@rikj:jki.re": "string",
 | |
|                             }
 | |
|                         },
 | |
|                     },
 | |
|                     "room_id": "!jEsUZKDJdhlrceRyVU:example.org",
 | |
|                     "type": "m.receipt",
 | |
|                 },
 | |
|             ],
 | |
|             [],
 | |
|         )
 | |
| 
 | |
|     def _test_filters_hidden(
 | |
|         self, events: List[JsonDict], expected_output: List[JsonDict]
 | |
|     ):
 | |
|         """Tests that the _filter_out_hidden returns the expected output"""
 | |
|         filtered_events = self.event_source.filter_out_hidden(events, "@me:server.org")
 | |
|         self.assertEquals(filtered_events, expected_output)
 |