aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorGravatar Harbys <[email protected]>2020-11-24 17:55:25 +0100
committerGravatar Harbys <[email protected]>2020-11-24 17:55:25 +0100
commit42c862b49923e30f66632902c86cfd168021b1e8 (patch)
treececcf9df6338a99e08b9018890f8c9b32478030e /tests
parentAdd 2 first unit tests for Stream cog (diff)
Add more tests and some comments
Diffstat (limited to 'tests')
-rw-r--r--tests/bot/exts/moderation/test_stream.py46
1 files changed, 43 insertions, 3 deletions
diff --git a/tests/bot/exts/moderation/test_stream.py b/tests/bot/exts/moderation/test_stream.py
index 872627fc1..7aa2fae26 100644
--- a/tests/bot/exts/moderation/test_stream.py
+++ b/tests/bot/exts/moderation/test_stream.py
@@ -1,7 +1,27 @@
+import asyncio
import unittest
-from bot.constants import TIME_FORMATS
+
+from async_rediscache import RedisSession
+
+from bot.constants import TIME_FORMATS, Roles
from bot.exts.moderation.stream import Stream
-from tests.helpers import MockContext, MockBot
+from tests.helpers import MockBot, MockRole, MockMember
+
+redis_session = None
+redis_loop = asyncio.get_event_loop()
+
+
+def setUpModule(): # noqa: N802
+ """Create and connect to the fakeredis session."""
+ global redis_session
+ redis_session = RedisSession(use_fakeredis=True)
+ redis_loop.run_until_complete(redis_session.connect())
+
+
+def tearDownModule(): # noqa: N802
+ """Close the fakeredis session."""
+ if redis_session:
+ redis_loop.run_until_complete(redis_session.close())
class StreamCommandTest(unittest.IsolatedAsyncioTestCase):
@@ -9,9 +29,13 @@ class StreamCommandTest(unittest.IsolatedAsyncioTestCase):
def setUp(self) -> None:
self.bot = MockBot()
self.cog = Stream(self.bot)
- self.ctx = MockContext()
def test_linking_time_format_from_alias_or_key(self):
+ """
+ User provided time format needs to be lined to a proper entry in TIME_FORMATS
+ This Test checks _link_from_alias method
+ Checking for whether alias or key exists in TIME_FORMATS is done before calling this function
+ """
FORMATS = []
for key, entry in TIME_FORMATS.items():
FORMATS.extend(entry["aliases"])
@@ -39,7 +63,23 @@ class StreamCommandTest(unittest.IsolatedAsyncioTestCase):
self.assertEqual(linked, case[1])
def test_parsing_duration_and_time_format_to_seconds(self):
+ """
+ Test calculating time in seconds from duration and time unit
+ This test is technically dependent on _link_from_alias function, not the best practice but necessary
+ """
test_cases = ((1, "minute", 60), (5, "second", 5), (2, "day", 172800))
for case in test_cases:
time_in_seconds = self.cog._parse_time_to_seconds(case[0], case[1])
self.assertEqual(time_in_seconds, case[2])
+
+ def test_checking_if_user_has_streaming_permission(self):
+ """
+ Test searching for video role in Member.roles
+ """
+ user1 = MockMember(roles=[MockRole(id=Roles.video)])
+ user2 = MockMember()
+ already_allowed_user1 = any(Roles.video == role.id for role in user1.roles)
+ self.assertEqual(already_allowed_user1, True)
+
+ already_allowed_user2 = any(Roles.video == role.id for role in user2.roles)
+ self.assertEqual(already_allowed_user2, False)