From 8783187daee17e13a07e7e68ae2ab08a8e189ac0 Mon Sep 17 00:00:00 2001 From: dgw Date: Sun, 7 Nov 2021 10:48:47 -0600 Subject: [PATCH 1/2] reddit: fix matching twice for reddit.com without www. Addresses a regression introduced by #2202, which added `reddit.com` to the `short_post_url` pattern and made it possible for a post or comment URL to match BOTH that and `post_or_comment_url`. Since URLs match individually, and not as part of the line, all we need to make sure a shortlink really is one is to ensure that the link ends after the submission ID and optional trailing slash. --- sopel/modules/reddit.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sopel/modules/reddit.py b/sopel/modules/reddit.py index 4ab7512c16..68a7d42036 100644 --- a/sopel/modules/reddit.py +++ b/sopel/modules/reddit.py @@ -32,7 +32,7 @@ r'/r/\S+?/comments/(?P[\w-]+)' r'(?:/?(?:[\w%]+/(?P[\w-]+))?)' ) -short_post_url = r'https?://(redd\.it|reddit\.com)/(?P[\w-]+)' +short_post_url = r'https?://(redd\.it|reddit\.com)/(?P[\w-]+)/?$' user_url = r'%s/u(?:ser)?/([\w-]+)' % domain image_url = r'https?://i\.redd\.it/\S+' video_url = r'https?://v\.redd\.it/([\w-]+)' From e876a48ab552186090b278ec151ca0dcf02773ec Mon Sep 17 00:00:00 2001 From: dgw Date: Tue, 9 Nov 2021 13:41:12 -0600 Subject: [PATCH 2/2] test: add tests for reddit plugin URL matching --- test/modules/test_modules_reddit.py | 76 +++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) create mode 100644 test/modules/test_modules_reddit.py diff --git a/test/modules/test_modules_reddit.py b/test/modules/test_modules_reddit.py new file mode 100644 index 0000000000..e73614b5e4 --- /dev/null +++ b/test/modules/test_modules_reddit.py @@ -0,0 +1,76 @@ +"""Tests for Sopel's ``reddit`` plugin""" +from __future__ import generator_stop + +import pytest + +from sopel.trigger import PreTrigger + + +TMP_CONFIG = """ +[core] +owner = Admin +nick = Sopel +enable = + reddit +host = irc.libera.chat +""" + + +@pytest.fixture +def bot(botfactory, configfactory): + settings = configfactory('default.ini', TMP_CONFIG) + return botfactory.preloaded(settings, ['reddit']) + + +MATCHING_URLS = ( + # URLs the reddit plugin is expected to handle + # Should match ONCE each, no more, no less + 'https://redd.it/123456', + 'https://redd.it/123456/', + 'https://reddit.com/123456', + 'https://reddit.com/123456/', + 'https://reddit.com/r/subname', + 'https://reddit.com/r/subname/', + 'https://www.reddit.com/r/subname', + 'https://www.reddit.com/r/subname/', + 'https://reddit.com/r/subname/comments/123456', + 'https://reddit.com/r/subname/comments/123456/', + 'https://reddit.com/r/subname/comments/123456?param=value', + 'https://reddit.com/r/subname/comments/123456/?param=value', + 'https://www.reddit.com/r/subname/comments/123456', + 'https://www.reddit.com/r/subname/comments/123456/', + 'https://reddit.com/r/subname/comments/123456/post_title_slug/234567', + 'https://reddit.com/r/subname/comments/123456/post_title_slug/234567/', + 'https://www.reddit.com/r/subname/comments/123456/post_title_slug/234567', + 'https://www.reddit.com/r/subname/comments/123456/post_title_slug/234567/', + 'https://reddit.com/r/subname/comments/123456/post_title_slug/234567/?context=1337', + 'https://www.reddit.com/r/subname/comments/123456/post_title_slug/234567/?context=1337', +) + + +NON_MATCHING_URLS = ( + # we don't allow for query parameters on subreddit links (yet?) + 'https://reddit.com/r/subname?param=value', + 'https://reddit.com/r/subname/?param=value', + 'https://www.reddit.com/r/subname?param=value', + 'https://www.reddit.com/r/subname/?param=value', + # "shortlink" style allegedly seen in the wild, but not currently recognized + 'https://reddit.com/comments/123456', + 'https://reddit.com/comments/123456/', +) + + +@pytest.mark.parametrize('link', MATCHING_URLS) +def test_url_matching(link, bot): + line = PreTrigger(bot.nick, ':User!user@irc.libera.chat PRIVMSG #channel {}'.format(link)) + matches = bot.rules.get_triggered_rules(bot, line) + + assert len([match for match in matches if match[0].get_plugin_name() == 'reddit']) == 1 + + +@pytest.mark.parametrize('link', NON_MATCHING_URLS) +def test_url_non_matching(link, bot): + line = PreTrigger(bot.nick, ':User!user@irc.libera.chat PRIVMSG #channel {}'.format(link)) + matches = bot.rules.get_triggered_rules(bot, line) + + assert len([match for match in matches if match[0].get_plugin_name() == 'reddit']) == 0