diff options
| author | 2019-11-03 14:49:31 -0500 | |
|---|---|---|
| committer | 2019-11-03 14:49:31 -0500 | |
| commit | dc0f8244e5f8fd20dc5188f859f4128d4bbec0b4 (patch) | |
| tree | 96f3753dc9326cbdb893e7babe4c81486d6d5b26 /tests/bot | |
| parent | Merge pull request #631 from manusaurio/master (diff) | |
| parent | Merge branch 'master' into bot-utils-init-tests (diff) | |
Merge pull request #640 from python-discord/bot-utils-init-tests
Write tests for `bot.utils`.
Diffstat (limited to 'tests/bot')
| -rw-r--r-- | tests/bot/test_utils.py | 52 | 
1 files changed, 52 insertions, 0 deletions
| diff --git a/tests/bot/test_utils.py b/tests/bot/test_utils.py new file mode 100644 index 000000000..58ae2a81a --- /dev/null +++ b/tests/bot/test_utils.py @@ -0,0 +1,52 @@ +import unittest + +from bot import utils + + +class CaseInsensitiveDictTests(unittest.TestCase): +    """Tests for the `CaseInsensitiveDict` container.""" + +    def test_case_insensitive_key_access(self): +        """Tests case insensitive key access and storage.""" +        instance = utils.CaseInsensitiveDict() + +        key = 'LEMON' +        value = 'trees' + +        instance[key] = value +        self.assertIn(key, instance) +        self.assertEqual(instance.get(key), value) +        self.assertEqual(instance.get(key.casefold()), value) +        self.assertEqual(instance.pop(key.casefold()), value) +        self.assertNotIn(key, instance) +        self.assertNotIn(key.casefold(), instance) + +        instance.setdefault(key, value) +        del instance[key] +        self.assertNotIn(key, instance) + +    def test_initialization_from_kwargs(self): +        """Tests creating the dictionary from keyword arguments.""" +        instance = utils.CaseInsensitiveDict({'FOO': 'bar'}) +        self.assertEqual(instance['foo'], 'bar') + +    def test_update_from_other_mapping(self): +        """Tests updating the dictionary from another mapping.""" +        instance = utils.CaseInsensitiveDict() +        instance.update({'FOO': 'bar'}) +        self.assertEqual(instance['foo'], 'bar') + + +class ChunkTests(unittest.TestCase): +    """Tests the `chunk` method.""" + +    def test_empty_chunking(self): +        """Tests chunking on an empty iterable.""" +        generator = utils.chunks(iterable=[], size=5) +        self.assertEqual(list(generator), []) + +    def test_list_chunking(self): +        """Tests chunking a non-empty list.""" +        iterable = [1, 2, 3, 4, 5] +        generator = utils.chunks(iterable=iterable, size=2) +        self.assertEqual(list(generator), [[1, 2], [3, 4], [5]]) | 
