diff options
| author | 2019-10-13 12:12:11 +0200 | |
|---|---|---|
| committer | 2019-10-13 12:12:11 +0200 | |
| commit | 4cbbe6fd8976f2cf1b2611f04b4ddce2568d9a04 (patch) | |
| tree | 0dc0314451d82bcf4e4c5b1cf09abe82aa383154 /tests | |
| parent | Merge branch 'rules-attachment-tests-unittest' into unittest-migration (diff) | |
| parent | Move test_antispam.py to tests.bot.cogs (diff) | |
Merge branch 'cogs-antispam-unittest' into unittest-migration
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/bot/cogs/test_antispam.py | 35 | 
1 files changed, 35 insertions, 0 deletions
| diff --git a/tests/bot/cogs/test_antispam.py b/tests/bot/cogs/test_antispam.py new file mode 100644 index 000000000..ce5472c71 --- /dev/null +++ b/tests/bot/cogs/test_antispam.py @@ -0,0 +1,35 @@ +import unittest + +from bot.cogs import antispam + + +class AntispamConfigurationValidationTests(unittest.TestCase): +    """Tests validation of the antispam cog configuration.""" + +    def test_default_antispam_config_is_valid(self): +        """The default antispam configuration is valid.""" +        validation_errors = antispam.validate_config() +        self.assertEqual(validation_errors, {}) + +    def test_unknown_rule_returns_error(self): +        """Configuring an unknown rule returns an error.""" +        self.assertEqual( +            antispam.validate_config({'invalid-rule': {}}), +            {'invalid-rule': "`invalid-rule` is not recognized as an antispam rule."} +        ) + +    def test_missing_keys_returns_error(self): +        """Not configuring required keys returns an error.""" +        keys = (('interval', 'max'), ('max', 'interval')) +        for configured_key, unconfigured_key in keys: +            with self.subTest( +                configured_key=configured_key, +                unconfigured_key=unconfigured_key +            ): +                config = {'burst': {configured_key: 10}} +                error = f"Key `{unconfigured_key}` is required but not set for rule `burst`" + +                self.assertEqual( +                    antispam.validate_config(config), +                    {'burst': error} +                ) | 
