diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/bot/exts/moderation/infraction/test_infractions.py | 11 | ||||
| -rw-r--r-- | tests/bot/exts/moderation/infraction/test_utils.py | 29 | 
2 files changed, 23 insertions, 17 deletions
| diff --git a/tests/bot/exts/moderation/infraction/test_infractions.py b/tests/bot/exts/moderation/infraction/test_infractions.py index 052048053..a18a4d23b 100644 --- a/tests/bot/exts/moderation/infraction/test_infractions.py +++ b/tests/bot/exts/moderation/infraction/test_infractions.py @@ -79,13 +79,13 @@ class VoiceMuteTests(unittest.IsolatedAsyncioTestCase):          """Should call voice mute applying function without expiry."""          self.cog.apply_voice_mute = AsyncMock()          self.assertIsNone(await self.cog.voicemute(self.cog, self.ctx, self.user, reason="foobar")) -        self.cog.apply_voice_mute.assert_awaited_once_with(self.ctx, self.user, "foobar", expires_at=None) +        self.cog.apply_voice_mute.assert_awaited_once_with(self.ctx, self.user, "foobar", duration_or_expiry=None)      async def test_temporary_voice_mute(self):          """Should call voice mute applying function with expiry."""          self.cog.apply_voice_mute = AsyncMock()          self.assertIsNone(await self.cog.tempvoicemute(self.cog, self.ctx, self.user, "baz", reason="foobar")) -        self.cog.apply_voice_mute.assert_awaited_once_with(self.ctx, self.user, "foobar", expires_at="baz") +        self.cog.apply_voice_mute.assert_awaited_once_with(self.ctx, self.user, "foobar", duration_or_expiry="baz")      async def test_voice_unmute(self):          """Should call infraction pardoning function.""" @@ -189,7 +189,8 @@ class VoiceMuteTests(unittest.IsolatedAsyncioTestCase):          user = MockUser()          await self.cog.voicemute(self.cog, self.ctx, user, reason=None) -        post_infraction_mock.assert_called_once_with(self.ctx, user, "voice_mute", None, active=True, expires_at=None) +        post_infraction_mock.assert_called_once_with(self.ctx, user, "voice_mute", None, active=True, +                                                     duration_or_expiry=None)          apply_infraction_mock.assert_called_once_with(self.cog, self.ctx, infraction, user, ANY)          # Test action @@ -273,7 +274,7 @@ class CleanBanTests(unittest.IsolatedAsyncioTestCase):              self.user,              "FooBar",              purge_days=1, -            expires_at=None, +            duration_or_expiry=None,          )      async def test_cleanban_doesnt_purge_messages_if_clean_cog_available(self): @@ -285,7 +286,7 @@ class CleanBanTests(unittest.IsolatedAsyncioTestCase):              self.ctx,              self.user,              "FooBar", -            expires_at=None, +            duration_or_expiry=None,          )      @patch("bot.exts.moderation.infraction.infractions.Age") diff --git a/tests/bot/exts/moderation/infraction/test_utils.py b/tests/bot/exts/moderation/infraction/test_utils.py index 5cf02033d..4c78c0bd8 100644 --- a/tests/bot/exts/moderation/infraction/test_utils.py +++ b/tests/bot/exts/moderation/infraction/test_utils.py @@ -318,14 +318,17 @@ class TestPostInfraction(unittest.IsolatedAsyncioTestCase):              "user": self.member.id,              "active": False,              "expires_at": now.isoformat(), -            "dm_sent": False +            "dm_sent": False, +            "last_applied": datetime(2020, 1, 1).isoformat(),          } -        self.ctx.bot.api_client.post.return_value = "foo" -        actual = await utils.post_infraction(self.ctx, self.member, "ban", "Test reason", now, True, False) +        # Patch the time.now(tz=timezone.utc) function to return a specific time +        with patch("bot.exts.moderation.infraction._utils.datetime.now", return_value=datetime(2020, 1, 1)): +            self.ctx.bot.api_client.post.return_value = "foo" +            actual = await utils.post_infraction(self.ctx, self.member, "ban", "Test reason", now, True, False) -        self.assertEqual(actual, "foo") -        self.ctx.bot.api_client.post.assert_awaited_once_with("bot/infractions", json=payload) +            self.assertEqual(actual, "foo") +            self.ctx.bot.api_client.post.assert_awaited_once_with("bot/infractions", json=payload)      async def test_unknown_error_post_infraction(self):          """Should send an error message to chat when a non-400 error occurs.""" @@ -356,12 +359,14 @@ class TestPostInfraction(unittest.IsolatedAsyncioTestCase):              "type": "mute",              "user": self.user.id,              "active": True, -            "dm_sent": False +            "dm_sent": False, +            "last_applied": datetime(2020, 1, 1),          } -        self.bot.api_client.post.side_effect = [ResponseCodeError(MagicMock(status=400), {"user": "foo"}), "foo"] - -        actual = await utils.post_infraction(self.ctx, self.user, "mute", "Test reason") -        self.assertEqual(actual, "foo") -        self.bot.api_client.post.assert_has_awaits([call("bot/infractions", json=payload)] * 2) -        post_user_mock.assert_awaited_once_with(self.ctx, self.user) +        # Patch the time.now(tz=timezone.utc) function to return a specific time +        with patch("bot.exts.moderation.infraction._utils.datetime.now", return_value=datetime(2020, 1, 1)): +            self.bot.api_client.post.side_effect = [ResponseCodeError(MagicMock(status=400), {"user": "foo"}), "foo"] +            actual = await utils.post_infraction(self.ctx, self.user, "mute", "Test reason") +            self.assertEqual(actual, "foo") +            self.bot.api_client.post.assert_has_awaits([call("bot/infractions", json=payload)] * 2) +            post_user_mock.assert_awaited_once_with(self.ctx, self.user) | 
