diff options
author | Richard van der Hoff <richard@matrix.org> | 2017-10-20 23:51:07 +0100 |
---|---|---|
committer | Richard van der Hoff <richard@matrix.org> | 2017-10-21 00:30:39 +0100 |
commit | 1135193dfde2a844d38dab4bd50a69658891abcb (patch) | |
tree | 1e8304fc8431038e40d8357266086e18b809d66d /tests | |
parent | Allow = in mxids and groupids (diff) | |
download | synapse-1135193dfde2a844d38dab4bd50a69658891abcb.tar.xz |
Validate group ids when parsing
May as well do it whenever we parse a Group ID. We check the sigil and basic structure here so it makes sense to check the grammar in the same place.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test_types.py | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/tests/test_types.py b/tests/test_types.py index 24d61dbe54..115def2287 100644 --- a/tests/test_types.py +++ b/tests/test_types.py @@ -17,7 +17,7 @@ from tests import unittest from synapse.api.errors import SynapseError from synapse.server import HomeServer -from synapse.types import UserID, RoomAlias +from synapse.types import UserID, RoomAlias, GroupID mock_homeserver = HomeServer(hostname="my.domain") @@ -60,3 +60,25 @@ class RoomAliasTestCase(unittest.TestCase): room = RoomAlias("channel", "my.domain") self.assertEquals(room.to_string(), "#channel:my.domain") + + +class GroupIDTestCase(unittest.TestCase): + def test_parse(self): + group_id = GroupID.from_string("+group/=_-.123:my.domain") + self.assertEqual("group/=_-.123", group_id.localpart) + self.assertEqual("my.domain", group_id.domain) + + def test_validate(self): + bad_ids = [ + "$badsigil:domain", + "+:empty", + ] + [ + "+group" + c + ":domain" for c in "A%?æ£" + ] + for id_string in bad_ids: + try: + GroupID.from_string(id_string) + self.fail("Parsing '%s' should raise exception" % id_string) + except SynapseError as exc: + self.assertEqual(400, exc.code) + self.assertEqual("M_UNKNOWN", exc.errcode) |