aboutsummaryrefslogtreecommitdiffstats
path: root/tests/base.py
diff options
context:
space:
mode:
authorGravatar TizzySaurus <[email protected]>2022-08-14 19:58:30 +0100
committerGravatar GitHub <[email protected]>2022-08-14 19:58:30 +0100
commit1a9e4c0c2a840635475ee0481b0d59528eeb9982 (patch)
treebdfae5ac09adb85edbb1f392c20c7f1dbc8fcf7d /tests/base.py
parentDisplay mentions instead of name attribute in `!reminder list` (diff)
parentMerge pull request #2229 from python-discord/py3.10-rediscache (diff)
Merge branch 'main' into bot-2231-enhancements
Diffstat (limited to 'tests/base.py')
-rw-r--r--tests/base.py24
1 files changed, 24 insertions, 0 deletions
diff --git a/tests/base.py b/tests/base.py
index 5e304ea9d..4863a1821 100644
--- a/tests/base.py
+++ b/tests/base.py
@@ -4,6 +4,7 @@ from contextlib import contextmanager
from typing import Dict
import discord
+from async_rediscache import RedisSession
from discord.ext import commands
from bot.log import get_logger
@@ -104,3 +105,26 @@ class CommandTestCase(unittest.IsolatedAsyncioTestCase):
await cmd.can_run(ctx)
self.assertCountEqual(permissions.keys(), cm.exception.missing_permissions)
+
+
+class RedisTestCase(unittest.IsolatedAsyncioTestCase):
+ """
+ Use this as a base class for any test cases that require a redis session.
+
+ This will prepare a fresh redis instance for each test function, and will
+ not make any assertions on its own. Tests can mutate the instance as they wish.
+ """
+
+ session = None
+
+ async def flush(self):
+ """Flush everything from the redis database to prevent carry-overs between tests."""
+ await self.session.client.flushall()
+
+ async def asyncSetUp(self):
+ self.session = await RedisSession(use_fakeredis=True).connect()
+ await self.flush()
+
+ async def asyncTearDown(self):
+ if self.session:
+ await self.session.client.close()