aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar MarkKoz <[email protected]>2020-07-22 16:11:32 -0700
committerGravatar MarkKoz <[email protected]>2020-07-22 16:39:26 -0700
commit12168766a153d9d1bd134ff64f74997eef8ff7b0 (patch)
tree2a4ce77bac561e21fe1aa13c1817daec6518ffd8
parentJams: create a new category if others are full (diff)
Jam tests: fix category test
-rw-r--r--tests/bot/cogs/test_jams.py38
1 files changed, 24 insertions, 14 deletions
diff --git a/tests/bot/cogs/test_jams.py b/tests/bot/cogs/test_jams.py
index 81fbcb798..54a096703 100644
--- a/tests/bot/cogs/test_jams.py
+++ b/tests/bot/cogs/test_jams.py
@@ -1,11 +1,22 @@
import unittest
-from unittest.mock import AsyncMock, MagicMock, patch
+from unittest.mock import AsyncMock, MagicMock, create_autospec
-from bot.cogs.jams import CodeJams, setup
+from discord import CategoryChannel
+
+from bot.cogs import jams
from bot.constants import Roles
from tests.helpers import MockBot, MockContext, MockGuild, MockMember, MockRole, MockTextChannel
+def get_mock_category(channel_count: int, name: str) -> CategoryChannel:
+ """Return a mocked code jam category."""
+ category = create_autospec(CategoryChannel, spec_set=True, instance=True)
+ category.name = name
+ category.channels = [MockTextChannel() for _ in range(channel_count)]
+
+ return category
+
+
class JamCreateTeamTests(unittest.IsolatedAsyncioTestCase):
"""Tests for `createteam` command."""
@@ -15,11 +26,7 @@ class JamCreateTeamTests(unittest.IsolatedAsyncioTestCase):
self.command_user = MockMember([self.admin_role])
self.guild = MockGuild([self.admin_role])
self.ctx = MockContext(bot=self.bot, author=self.command_user, guild=self.guild)
- self.cog = CodeJams(self.bot)
-
- utils_patcher = patch("bot.cogs.jams.utils")
- self.utils_mock = utils_patcher.start()
- self.addCleanup(utils_patcher.stop)
+ self.cog = jams.CodeJams(self.bot)
async def test_too_small_amount_of_team_members_passed(self):
"""Should `ctx.send` and exit early when too small amount of members."""
@@ -29,7 +36,6 @@ class JamCreateTeamTests(unittest.IsolatedAsyncioTestCase):
self.cog.add_roles = AsyncMock()
self.ctx.reset_mock()
- self.utils_mock.reset_mock()
members = (MockMember() for _ in range(case))
await self.cog.createteam(self.cog, self.ctx, "foo", members)
@@ -63,8 +69,6 @@ class JamCreateTeamTests(unittest.IsolatedAsyncioTestCase):
async def test_category_dont_exist(self):
"""Should create code jam category."""
- self.utils_mock.get.return_value = None
-
await self.cog.get_category(self.guild)
self.guild.create_category_channel.assert_awaited_once()
@@ -75,8 +79,15 @@ class JamCreateTeamTests(unittest.IsolatedAsyncioTestCase):
async def test_category_channel_exist(self):
"""Should not try to create category channel."""
- await self.cog.get_category(self.guild)
- self.guild.create_category_channel.assert_not_awaited()
+ expected_category = get_mock_category(48, jams.CATEGORY_NAME)
+ self.guild.categories = [
+ get_mock_category(48, "other"),
+ expected_category,
+ get_mock_category(6, jams.CATEGORY_NAME),
+ ]
+
+ actual_category = await self.cog.get_category(self.guild)
+ self.assertEqual(expected_category, actual_category)
async def test_channel_overwrites(self):
"""Should have correct permission overwrites for users and roles."""
@@ -103,7 +114,6 @@ class JamCreateTeamTests(unittest.IsolatedAsyncioTestCase):
async def test_team_channels_creation(self):
"""Should create new voice and text channel for team."""
- self.utils_mock.get.return_value = "foo"
members = [MockMember() for _ in range(5)]
self.cog.get_overwrites = MagicMock()
@@ -147,5 +157,5 @@ class CodeJamSetup(unittest.TestCase):
def test_setup(self):
"""Should call `bot.add_cog`."""
bot = MockBot()
- setup(bot)
+ jams.setup(bot)
bot.add_cog.assert_called_once()