aboutsummaryrefslogtreecommitdiffstats
path: root/tests/bot/exts (follow)
Commit message (Collapse)AuthorAgeLines
...
* Migrate code style to ruffGravatar Chris Lovering2023-04-11-175/+185
| | | | | Co-authored-by: Boris Muratov <[email protected]> Co-authored-by: wookie184 <[email protected]>
* Remove dead or unused code (#2528)Gravatar Boris Muratov2023-04-11-170/+0
|
* Merge branch 'main' into 2302-activity-in-reviewsGravatar Boris Muratov2023-04-09-690/+706
|\
| * Adjust to site using dicts in additional_settings instead of JSON stringsGravatar Boris Muratov2023-04-06-3/+3
| | | | | | | | This is to make sure that the unique constraint always compares between dicts instead of sometimes dealing with nulls.
| * Fix testGravatar Boris Muratov2023-04-05-1/+1
| |
| * Support custom value representation in filtering UIGravatar mbaruh2023-03-28-7/+9
| | | | | | | | Adds the `CustomIOField` class which can be used as a base for wrappers that store a value with a customized way to process the user input and to present the value in the UI.
| * Rename additional_field to additional_settingsGravatar mbaruh2023-03-26-3/+3
| |
| * Add support for snekbox IO in the new filtering systemGravatar mbaruh2023-03-23-19/+19
| |
| * Fix filtering testsGravatar mbaruh2023-03-23-6/+6
| |
| * Merge branch 'main' into new-filtersGravatar mbaruh2023-03-21-83/+254
| |\
| * \ Merge branch 'main' into new-filtersGravatar mbaruh2023-02-28-45/+48
| |\ \
| * | | Bring back old system testsGravatar mbaruh2023-01-22-11/+484
| | | |
| * | | Add the rest of the antispam rulesGravatar mbaruh2022-11-01-3/+3
| | | | | | | | | | | | | | | | | | | | This is mostly a copy-paste of the implementations in the old system into the new system's structure. The mentions rule required changing the `triggers_on` method to async.
| * | | Merge branch 'main' into new-filtersGravatar mbaruh2022-10-23-6/+270
| |\ \ \
| * | | | Fix testsGravatar mbaruh2022-10-01-145/+39
| | | | |
| * | | | Split actions and validations to their own packcagesGravatar mbaruh2022-09-30-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is a purely aesthetic choice. Additionally fixes a small bug where a missing entry type would repeatedly invoke a warning on cog load.
| * | | | Merge branch 'main' into new-filtersGravatar mbaruh2022-09-24-215/+298
| |\ \ \ \
| * | | | | Accept strings in channel scope and change role string interpretationGravatar mbaruh2022-07-16-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The channel scope settings were changed to accomodate strings. That means that if a string is specified, the bot will look whether the context channel's name matches. If it's a number, it will match the ID. Accordingly the same changed was applied to the bypass roles and pings settings: if it's a non-numeric string, it will look for a role with that name.
| * | | | | New filtering backbone and regex filtering migrationGravatar mbaruh2022-07-16-0/+333
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit provides the basis of the new filtering system: - The filtering cog consists of several filter lists loaded from the database (filtering.py). - Each filter list contains a list of filters, which are run in response to events (message posting, reaction, thread creation). Each filter list may choose to respond to different events (the subscribe method in filtering.py). - Each filter has settings (settings.py) which decide when it is going to be run (e.g it might be disabled in a specific channel), and what will happen if it triggers (e.g delete the offending message). - Not every filter has a value for every setting (the _settings_types package) . It will use the default settings specified by its filter list as a fallback. - Since each filter might have a different effect when triggered, we must check all relevant filters even if we found a triggered filter already, unlike in the old system. - Two triggered filters may specify different values for the same setting, therefore each entry has a rule for combining two different values (the __or__ method in each file in _settings_types). To avoid having to prefix each file with an underscore (or the bot will try to load it as a cog), the loading script was changed to ignore packages with names starting with an underscore. Alert sending is done via a webhook so that several embeds can be sent in the same message (will be useful for example for guild invite alerts). Filter lists and setting entries classes are loaded dynamically from their respective packages. In order to be able to test the new features, this commit also includes a migration of the regex-based filtering.
| * | | | | Tear down the old filtering systemGravatar mbaruh2022-07-15-739/+0
| | | | | | | | | | | | | | | | | | | | | | | | Tests and dependent functionality in other extensions will be re-added later on.
* | | | | | Merge branch 'main' into 2302-activity-in-reviewsGravatar wookie1842023-03-25-90/+261
|\ \ \ \ \ \ | | |_|_|_|/ | |/| | | |
| * | | | | Merge branch 'main' into snekbox-filesGravatar Ionite2023-03-09-12/+45
| |\ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # Conflicts: # bot/constants.py # bot/exts/utils/snekbox/_cog.py # config-default.yml
| | * | | | | Bump markdownify from 0.6.1 to 0.11.6 (#2429)Gravatar dependabot[bot]2023-03-07-0/+23
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: wookie184 <[email protected]>
| | * | | | | Merge branch 'main' into 2301-fix-voting-conditionsGravatar Boris Muratov2023-03-03-10/+10
| | |\ \ \ \ \ | | | | |_|_|/ | | | |/| | |
| | | * | | | Merge branch 'main' into migration/tagGravatar wookie1842023-02-27-3/+3
| | | |\ \ \ \
| | | * | | | | Implement reviewsGravatar Ibrahim2023-02-26-5/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | + used both `discord.User` and `discord.Member` in typehinting as `InteractionResponse.user` returns `discord.User` object + removed `ErrorHandler()._can_run` + edited `try_get_tag` to use `bot.can_run` + removed `/tag list` + change `/tag get <name>` to `/tag <name>` + remove redundant `GUILD_ID` in `tags.py` + using `discord.abc.Messageable` because `ctx.channel` returns that instead of `Channel` Object
| | | * | | | | Implement all reviewsGravatar Ibrahim2023-02-23-25/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | + Remove commented code + Remove unecessarily syncting the bot + Handle direct tag commads + 3.10 type hinting in concerned functions + Add `MockInteractionMessage` + Fix tests for `try_get_tag`
| | | * | | | | Update tests for `/tag` as of migration to slash commandsGravatar Ibrahim2750mi2023-02-14-22/+22
| | | | | | | |
| | * | | | | | Merge branch 'main' into 2301-fix-voting-conditionsGravatar wookie1842022-11-30-5/+5
| | |\| | | | |
| | * | | | | | Merge branch 'main' into 2301-fix-voting-conditionsGravatar wookie1842022-11-05-31/+34
| | |\ \ \ \ \ \
| | * | | | | | | Fix testsGravatar wookie1842022-10-22-3/+13
| | | | | | | | |
| * | | | | | | | Use PurePosixPath so tests work on windowsGravatar Ionite2023-02-22-5/+1
| | | | | | | | |
| * | | | | | | | Update unit tests for file error message changesGravatar Ionite2023-02-08-9/+5
| | | | | | | | |
| * | | | | | | | Add skip condition for windows not able to test path escapesGravatar Ionite2023-02-07-2/+6
| | | | | | | | |
| * | | | | | | | Fix unit tests for new failmail emojiGravatar Ionite2023-02-07-5/+5
| | | | | | | | |
| * | | | | | | | Add disallowed file extensions testsGravatar Ionite2023-02-06-0/+29
| | | | | | | | |
| * | | | | | | | Change failed files str to truncate on chars onlyGravatar ionite342022-12-20-13/+11
| | | | | | | | |
| * | | | | | | | Add normalize file name testsGravatar ionite342022-12-20-0/+34
| | | | | | | | |
| * | | | | | | | Refactor snekbox tests to moduleGravatar ionite342022-12-20-0/+0
| | | | | | | | |
| * | | | | | | | Rename method get_failed_files_strGravatar ionite342022-12-20-1/+1
| | | | | | | | |
| * | | | | | | | Add unit tests for EvalResult.files_error_strGravatar ionite342022-12-17-0/+21
| | | | | | | | |
| * | | | | | | | Add unit test for files_error_messageGravatar ionite342022-12-17-1/+28
| | | | | | | | |
| * | | | | | | | Update unit tests for EvalResult message changeGravatar ionite342022-12-17-7/+16
| | | | | | | | |
| * | | | | | | | Refactor to move snekbox to moduleGravatar ionite342022-12-14-18/+22
| | | | | | | | |
| * | | | | | | | Update test_post_job to use 3.10 snekboxGravatar ionite342022-12-14-1/+1
| | | | | | | | |
| * | | | | | | | Update function name `get_message`Gravatar ionite342022-12-14-3/+3
| | | | | | | | |
| * | | | | | | | Fix test_post_job unit testGravatar ionite342022-12-14-2/+2
| | | | | | | | |
| * | | | | | | | Reorder importsGravatar ionite342022-11-30-1/+1
| | | | | | | | |
| * | | | | | | | Merge branch 'main' into snekbox-filesGravatar Ionite2022-11-30-5/+5
| |\ \ \ \ \ \ \ \ | | | |_|/ / / / / | | |/| | | | | |
| * | | | | | | | Update unit tests for snekboxGravatar ionite342022-11-30-54/+57
| | | | | | | | |