aboutsummaryrefslogtreecommitdiffstats
path: root/tests/base.py
diff options
context:
space:
mode:
authorGravatar Izan <[email protected]>2022-09-17 19:25:37 +0100
committerGravatar Izan <[email protected]>2022-09-17 19:25:37 +0100
commit2930799460d8bc65c242b2f06426453304b6ed82 (patch)
tree7582332bfb3a83c02b2053c8415217068bd96688 /tests/base.py
parentAddress Review (diff)
parentMerge branch 'main' into bot-2231-enhancements (diff)
Merge remote-tracking branch 'origin/bot-2231-enhancements' 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()