diff options
| author | 2022-08-14 19:58:30 +0100 | |
|---|---|---|
| committer | 2022-08-14 19:58:30 +0100 | |
| commit | 1a9e4c0c2a840635475ee0481b0d59528eeb9982 (patch) | |
| tree | bdfae5ac09adb85edbb1f392c20c7f1dbc8fcf7d /tests/base.py | |
| parent | Display mentions instead of name attribute in `!reminder list` (diff) | |
| parent | Merge 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.py | 24 | 
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() | 
