diff options
| author | 2020-02-01 21:35:33 -0800 | |
|---|---|---|
| committer | 2020-02-12 10:07:56 -0800 | |
| commit | ad53b51b860858cb9434435de3d205165b2d78f8 (patch) | |
| tree | 797ded065b532d181db8a12c1260b9368edb01c4 /tests | |
| parent | Sync tests: remove mock_role fixture (diff) | |
Sync tests: test Sync cog's on_guild_role_update
A PUT request should be sent if the colour, name, permissions, or
position changes.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/bot/cogs/sync/test_cog.py | 35 | 
1 files changed, 35 insertions, 0 deletions
| diff --git a/tests/bot/cogs/sync/test_cog.py b/tests/bot/cogs/sync/test_cog.py index 604daa437..9a3232b3a 100644 --- a/tests/bot/cogs/sync/test_cog.py +++ b/tests/bot/cogs/sync/test_cog.py @@ -160,3 +160,38 @@ class SyncCogListenerTests(SyncCogTestCase):          asyncio.run(self.cog.on_guild_role_delete(role))          self.bot.api_client.delete.assert_called_once_with("bot/roles/99") + +    def test_sync_cog_on_guild_role_update(self): +        """A PUT request should be sent if the colour, name, permissions, or position changes.""" +        role_data = { +            "colour": 49, +            "id": 777, +            "name": "rolename", +            "permissions": 8, +            "position": 23, +        } +        subtests = ( +            (True, ("colour", "name", "permissions", "position")), +            (False, ("hoist", "mentionable")), +        ) + +        for should_put, attributes in subtests: +            for attribute in attributes: +                with self.subTest(should_put=should_put, changed_attribute=attribute): +                    self.bot.api_client.put.reset_mock() + +                    after_role_data = role_data.copy() +                    after_role_data[attribute] = 876 + +                    before_role = helpers.MockRole(**role_data) +                    after_role = helpers.MockRole(**after_role_data) + +                    asyncio.run(self.cog.on_guild_role_update(before_role, after_role)) + +                    if should_put: +                        self.bot.api_client.put.assert_called_once_with( +                            f"bot/roles/{after_role.id}", +                            json=after_role_data +                        ) +                    else: +                        self.bot.api_client.put.assert_not_called() | 
