-
Notifications
You must be signed in to change notification settings - Fork 25.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Automatically close invalid PRs using GitHub Actions #3313
Conversation
I'm fine with using a GH action to filter out these bad PRs, but think this only solves part of the problem. If there's a solution to do that, I'd be all for it as the noise caused to my (and your's) inboxes is a nuisance. Only option I've found is to unsubcribe from all notifications on this repo, which I'd prefer not to do. |
You're right that this doesn't automatically unsubscribe us or otherwise cleans up our inboxes, but I do find it occasionally useful when the author continues to push commits after opening the PR. It's also nice that pushes to the HEAD branch will no longer be considered "updates" once a PR is closed, so I'd say it helps more or less. After all it saves you some time to close each PR after your inbox gets cluttered up so you'll only have to delete the emails. The ultimate solution, unfortunately, is to unsubscribe from the repo (issues/PRs at least) and only subscribe to specific threads we're interested in. There certainly are more elaborate methods to build complex stuff to achieve this but I'd doubt it'd be worth the efforts (I've already made something alike). I'd say this is as far as we can get without stepping too deep into this swamp. |
@mmistakes Does this PR deserve more attention or higher priority? |
On Gitlab there are more controls over Merge Requests (aka PR), like who can submit a MR, and you can limit it to Project Members. So at the end you can require to send the patches with a different workflow... This plus the @iBug solution would help a lot... BTW, I'm a long time user and following everything is going on since a long time. @mmistakes, you know me from the Remmina project maybe and via PayPal ;-) if you need triaging issues and PRs, I can help you a bit. Beside asking for more information, I could simply add specific comments, like (@mmistakes close, or attention, or merge, or whatever), or if you can give me a little of powers, I can also close those PRs myself, like #3322 |
Part of the reason I'm making this automated thing is my reminiscence of Michael's not willing to give write access to other people. GitHub so far doesn't allow "Triage" access for personal repositories, only "collaborators" that includes push access, so I "had to" implement something that doesn't depend on me having power over the repository. Adding to @antenore's comment, I'm also glad to help with triaging Issues, PRs and Discussions if Michael'd grant me the privileges. (Pretty sure I expressed this before) |
I appreciate the support and willingness to jump in and help. But as stated before, I feel more comfortable doing it myself. Most of the issues/PRs/discussions that lack action or feedback from me are usually ones that I feel are "thorny" and require a defense for something I have no interest in acting on. Sometimes it's just easier to remain silent. That's a failing on my part, but hey... open source is hard. I suppose I could just close issues/PRs, but that would likely rub people the wrong way. RE: this PR. My hesitation is it's a partial solution. I'd rather do something that fixes the entire problem or nothing at all. Closing a pull request doesn't really bother me. It's the notifications... and those repeat ones when someone constantly pushes commits. Are you certain that once a pull request is closed... the notifications stop? Because I could have sworn that in the past I would still get emails even after closing them. I had to unsubscribe from each to get that to take affect. But maybe something has changed in recent years. |
Thanks for the heads up! Once a PR is closed, new pushes to the head (source) branch won't trigger additional notifications. However if anyone comments on the PR it still shows up (which happens rarely). If you want to completely halt it as-is you'll have to lock them as well, which I'm not confident in pushing this as the detection heuristics is too simple at this point (I can do it if you want). If it were my repo I could've built more sophisticated solutions using webhooks and GitHub API (with my Personal Access Token), writing automated stuff that cleans up and unsubscribes myself from these mistaken PRs. Unfortunately without going "too intrusive" it's only possible to create a partial solution. This is as far as I can get so that in most cases you only have to delete your emails and take no more actions. For you this relieves some tedious tasks, and for me this mostly solves the case where the author continues to add extra activities before either of us reacts that stacks up in our inboxes. So I'd classify this PR as "nice-to-haves" for everyone watching the repository. |
BTW, I just figured out that I could unwatch from the repo and watch again using a bot account. Then I could parse notifications for the bot account and only subscribe myself to the ones (Issues/PRs) I'm interested in. Maybe I could make some prototype or proof-of-concept when my exam-season is over. |
OK. I'll merge this in and see if it helps anything. I'd rather not over engineer things and add more complexity to this repo. |
There's been 3 bad PRs handled by this new "facility". The response time is typically within 20 seconds - looks decent to me. |
Thanks @iBug! It's working great. Big improvement. |
* root_project/master: (317 commits) Update CHANGELOG and history Automatically close invalid PRs using GitHub Actions (mmistakes#3313) Update CHANGELOG and history Add missing comma (mmistakes#3318) Update CHANGELOG and history ✏ fix typo (mmistakes#3232) Update CHANGELOG and history Fix keybase class (mmistakes#3221) Update CHANGELOG and history Update CHANGELOG and history Update Brazilian Portuguese translation (mmistakes#3204) feat: Sort comments by date ascending (mmistakes#3184) Link clarifying adding plugins (mmistakes#3181) Making verbiage consistent w/current _config.yml (mmistakes#3180) Fix broken link & Add Baidu site verification (mmistakes#3139) Added optional label attribute (mmistakes#3128) Delete stale.yml Delete stale.yml Use GitHub issue templates (mmistakes#3133) Update CHANGELOG and history ... # Conflicts: # _config.yml # _includes/archive-single.html # _sass/minimal-mistakes/_base.scss # _sass/minimal-mistakes/skins/_neon.scss
So far, we have 100% precision and ~97% recall (179 / 185) over the past three months, and PR 3592 is the sixth false negative. It's interesting that they did bother reading the template in whole and removed just the last comment, and without thinking carefully about what they're submitting. One good point is the first 5 FNs are closed by their authors after realizing they've submitted undesired stuff, and this is the first that stayed up for longer than necessary. I've always had this in mind: A new (additional) heuristic that can maintain a 99%+ recall over the past samples.
It's more likely this is a one-of-a-kind occurrence or a "tolerable error", so I don't think it's urgent to get this implemented and running. Anyway, I'm leaving this idea here for future reference, and I'd be glad to put it up if you want. |
* Try auto-closing bad PRs * Include empty PR body as well * Add "Type: Invalid" label as well
* Try auto-closing bad PRs * Include empty PR body as well * Add "Type: Invalid" label as well
* Try auto-closing bad PRs * Include empty PR body as well * Add "Type: Invalid" label as well
* Change tab indent to space for consistency (mmistakes#2614) * Fix link for author name (mmistakes#2575) Missed from bcd6126 * Update CHANGELOG and history * Update zh-cn (mmistakes#2576) * Update zh-cn * Update ui-text.yml * Update CHANGELOG and history * Use layout: none instead of null (mmistakes#2617) * Use layout: none instead of null * Update CHANGELOG and history * Configure entries layout `list` or `grid` (mmistakes#2616) * Configure entries layout `list` or `grid` This allows to use grid layout on `page.entries_layout` on the home layout. Included a break since when using grid the post images are too close to the horizontal line bellow `posts` text. There's a entries div now surrounding the posts since the first row of the grid was having a slight padding on the left. The home now behaves like posts/categories/tags pages with grid but including the paginator. For best results on desktop use `classes: wide` and `paginate: 4` on `_config.yml` (or multiples of 4 if you want more rows) * Fix indent * Archive subtitle leaves space on the bottom * Now space is added through style * Update CHANGELOG and history * Include documentation for home page grid view * Update 10-layouts.md * Update UI text for zh-CN and zh-TW (mmistakes#2626) * Update UI text for zh-CN and zh-TW * Update CHANGELOG and history Not touching last_modified_at this time - it's messy enough * Update documentation for mmistakes#2621 (mmistakes#2624) * Update documentation for mmistakes#2621 * Update CHANGELOG and history * Update last_modified_at * remove hidden posts from `/posts` (mmistakes#2625) * Update CHANGELOG and history * Show date of posts (mmistakes#2526) * add date to read-time.html * add option for show_date, dynamic icon style * change read-time to post__meta * cleanup post__metal.html * cleanup post__meta include variables * put date before read time * remove space in include variable * allow customisation of post__meta separator * add some documentation * oops fix typo derp * add post date image * change page meta separator customisation to CSS * Update CHANGELOG and history * Fix grammar * Remove extra back ticks * Release 4.20.0 💎 * Update remote_theme * Fix grammar * Fix grid `entries_layout` in home.html * Release 4.20.1 💎 * Update remote_theme version * Fix `entries_layout: grid` Close mmistakes#2639 * Update CHANGELOG and history * Change "fa" to "fas" for Font Awesome 5 (mmistakes#2649) * main.js: fa -> fas for FA 5 * Update CHANGELOG and history * added css changes, modified jquery.greedy-navigation and built the main.min.js again * Removed duplicated CSS definitions (mmistakes#2666) * Update CHANGELOG and history * Added article:author used by Pinterest (mmistakes#2670) * Update CHANGELOG and history * Refactor page meta (mmistakes#2641) * Rename include * Add grid view test pages * Rename `.post__meta-sep` and use CSS to add line break * Improve collection grid archive * Improve page grid archive * Enable `grid` * Don't show date icon if there is no `date` value * Add blank line at EOF * Add space * Wrap date and reading time in named `span` elements * Update CHANGELOG and history * Bump copyright year * Fix typo Close mmistakes#2678 * Fix broken link in documentation Close mmistakes#2677 * Release 4.20.2 💎 * Bump theme version * Update allejo/jekyll-toc to v1.0.14 https://github.com/allejo/jekyll-toc/releases/tag/v1.0.14 * Fix dead link to "CI services" Jekyll (mmistakes#2692) * Fix mmistakes#2635 * Update CHANGELOG and history * Update README.md * Update CONTRIBUTING.md * Update stale.yml * Fix closing tag of figures without captions in lists (mmistakes#2697) When the figure helper is used in a list, which can be either ordered or unordered, and no caption is specified, a line with text "</figure>" will be shown below the figure on the rendered page. This is because, if the '{% if include.caption %}' evaluates to false, the lines between that 'if' statement and '{% endif %}' will be emptied, not removed, so the block will be filled by empty lines. HTML ignores redundant empty lines, but Markdown takes them seriously. In addition, Markdown expects proper indentation of lines inside lists, and the closing '</figure>' tag is not indented. When combined, the empty space and absence of indentation cause Markdown to process the '</figure>' tag as a separate paragraph instead of an HTML tag, thus the text for the tag is directly rendered on the page. The fix for this issue is very simple: remove the empty space when 'include.caption' is false. As described in <https://shopify.github.io/liquid/basics/whitespace/>, this can be done by adding hyphens to the 'if' and 'endif' tags. * Update CHANGELOG and history * Update CHANGELOG and history * Norwegian translation (mmistakes#2702) * Update CHANGELOG and history * Update CHANGELOG and history * Fix a small typo in documentation * Update ui-text.yml for Vietnamese * Added some translation for indonesian language * Update indonesian translation * Update CHANGELOG and history * Update CHANGELOG and history * Update jQuery to 3.5.1 (mmistakes#2713) * Update jQuery to 3.5.1 Closes mmistakes#2712 * Build NodeJS Run using `npm run build:js` * Update CHANGELOG and history * Release 4.21.0 💎 * Update `remote_theme` version * Fix heading level * Fix Font Awesome icon color in various skins Close mmistakes#2724 * Update remote theme instructions * jekyll-install-cache gem should be added to Gemfile * Update CHANGELOG and history * indonesian translation minor typo fix (mmistakes#2731) * Update CHANGELOG and history * Update 404.md (mmistakes#2737) Removed Google Search script which no longer worked. mmistakes#2597 * Update CHANGELOG and history * Delete support.md * Delete feature_request.md * Update allejo/jekyll-toc to v1.1.0, skip headings without an ID (mmistakes#2752) * Update allejo/jekyll-toc to v1.1.0, skip headings without an ID https://github.com/allejo/jekyll-toc/releases/tag/v1.1.0 * Update CHANGELOG and history * Add toc_sticky parameter's description (mmistakes#2741) * Update CHANGELOG and history * Fix typo * Add hebrew translation (mmistakes#2760) * Update CHANGELOG and history * Add .webp to supported lightbox images (mmistakes#2788) * Update CHANGELOG and history * Remove google's fixurl.js from example (mmistakes#2789) Unfortunately, it no longer exists. * Update CHANGELOG and history * Upgrade Lunrjs to 2.3.9 and switch to relative_url (mmistakes#2805) * Update Lunr to 2.3.9 * Switch from absolute_url to relative_url * Update CHANGELOG and history * Allow custom gradient in page header overlays (mmistakes#2806) * Allow custom gradient in page header overlays * Update documentation * Update CHANGELOG and history * Add toggle option for RSS feed visibility (mmistakes#2787) * add a "hide" value in config for atom * Update footer to use param * update header to use param * Update docs to note configuration * undo formatting * use unless syntax * unless syntax and indentation * indentation * Update CHANGELOG and history * Use sort_natural instead of custom-logic (mmistakes#2756) * Update CHANGELOG and history * Allow custom sorting for collections (mmistakes#2723) * Allow custom sorting for collections * Update docs with custom sort of collections * Refactoring * Update CHANGELOG and history * Release 4.22.0 💎 * Update * Force rebuild of demo site * Fix typos * Remove G-stuff CSS (mmistakes#2852) (mmistakes#2855) * Add alt attr to site logo in masthead (mmistakes#2824) Co-authored-by: Michael Rose <[email protected]> * Add note on TOC heading level issue (mmistakes#2902) mmistakes#2892 (comment) * Add Baidu site verfication (mmistakes#2830) * Update CHANGELOG and history * Remove all references to official public Staticman API instance. (mmistakes#2831) * Updated Staticman docs * remove any ref to official public instance in docs * remove fallback instance for staticman v2 left staticman v1 untouched as I dunno how to deal with that * Update CHANGELOG and history * Datetime format (mmistakes#2844) * datetime_format * page__meta * page__date * page__date test * update docs * update docs * Update CHANGELOG and history * Color notices based on skin colors instead of fixed values (mmistakes#2887) * Made notice Sass color mixing in based on $background-color and $text-color instead of hard-coded black and white values. * Made some style adjustments to notices to improve readability. Notice links are slightly darkened from the notice color, mostly because the gray-on-gray default notice links were very hard to read. Rather than being $notice-color, they are `mix(#000, $notice-color, 10%)`. The notice background mix and code-background mix can now be set with the SCSS variables $notice-background-mix and $code-notice-background-mix. The default mix for background was adjusted to 80%, from 90%. The default mix for code-background was adjusted to 90%, from 95%. Skins that still didn't read well were adjusted individually. * Adjusted sunrise $notice-background-mix to 75% * Adjusted dark theme notice background mix colors back to the default Co-authored-by: Tom Manner <[email protected]> * Update CHANGELOG and history * Document user custom element hooks (mmistakes#2815) * Added documentation for including custom CSS on a site or page * Removed non-configuration related content from 05-configuration.md and cleaned up some style in new sections of 16-stylesheets.md * Moved small custom head documentation to a ProTip in _docs/06-overriding-theme-defaults.md * Cleaned up some documentation, and added some example uses of custom head and footer. * Replace double space with single * Replace double spaces with single Co-authored-by: Tom Manner <[email protected]> Co-authored-by: Michael Rose <[email protected]> * Update CHANGELOG and history * Add Arabic Translation 📝 * Update onchange and uglify-js dependencies * Fix typo * Update * Update 14-helpers.md (mmistakes#2940) Fix missing backtick. * Update CHANGELOG and history * Fix Jekyll environment note in configuration documentation Close mmistakes#2912 * Fix typo Close mmistakes#2911 * Update stale action * Update stale.yml * FIx menu toggle ref: mmistakes#2957 * Release 4.23.0 💎 * Update CHANGELOG and history * Bump theme version * Enable auto ads * Update Google Adsense * Update FUNDING.yml * Update FUNDING.yml * Update README.md * Disable auto ads * Update support buttons * Update Adsense * Add banner above related posts * Update FUNDING.yml * Update FUNDING.yml * Fix broken image Close mmistakes#3013 * feat: Search icon in masthead is a Font Awesome icon. (mmistakes#2774) * feat: Allow search icon in masthead to be set to a Font Awesome icon. * fix indentations * Users wishing to avoid FontAwesome should override _includes/masthead.html * Update CHANGELOG and history * Loads font-awesome asynchronously (mmistakes#2967) Loading font-awesome asynchronously allows to display the site faster. This change is advised by google pagespeed insights * Update CHANGELOG and history * Remove H2 as it is not important to site structure (mmistakes#3012) This should not use a H2, as that is not an important headline, and thus a H2 here would probably hurt in page SEO. * Update CHANGELOG and history * Fix broken links in documentation Close mmistakes#3004 * Remove `tabindex="-1"` from `input` elements in `search.html` layout Make `input` elements accessible by keyboard. Fixes mmistakes#2982 * Update README text for Gumshoejs license (mmistakes#3024) * Update CHANGELOG and history * Remove IE9 flexbox fallback (mmistakes#3042) IE9 is absolutely, completely, totally dead. it's marketshare is less than 0.1%. REF: https://caniuse.com/usage-table Save some bytes in the HTML for all users by removing the fallback inline CSS. * Update CHANGELOG and history * Add giscus support (mmistakes#3022) * Add script in same style as utterances But adjusted for the various filed differences * Add initial script * Add default settings * Update changelog * Add feature to readme * Add comments html * add comment provider include * update config in docs * Add URL for additional reference * docs for giscus comments * Unrelated bugfix: add missing version separator So that things match the "history" doc. * add space * update history doc * update about doc * add to test config yaml * remove unnecessary / incorrect async attribute * probably should pass the right config paths * lowercase the repo name * Update docs to address '1' and '0' for reactions_enabled Figured I'd match the giscus format rather than convert a boolean to an int there. * update two additional docs * docs wording fix * Release 4.24.0 💎 * Update version * Remove site.url from first breadcrumb link (mmistakes#3051) * Remove site.url from first breadcrumb link Fixes mmistakes#3050 * Use relative_rul filter instead of site.baseurl * Update CHANGELOG and history * Fixed a grammar error in the german translation (mmistakes#3063) * Update CHANGELOG and history * fix: change heading tag of related posts section from `h4` to `h2` for SEO enhancement (mmistakes#3064) * Update heading tag from `h4` to `h2` * Update heading tag from `h4` to `h2` * Update CHANGELOG and history * Add instructions on how to unminify main.js for easier browser debugging (mmistakes#3055) * Add instructions on how to unminify main.js for easier browser debugging * Fixed Markdown style like sggested by @iBug * Update CHANGELOG and history * Make small grammar changes * Update 01-quick-start-guide.md * Add Microformats (mmistakes#3052) * Add rel=me to author profile links * Add h-card Microformats markup * Add h-entry microformat markup * Fix missing anchor tag * Fix h-entry microformat markup on single template * Use minimal subset of Microformat elements * Move dt-published to `page__date.html` and remove dt-updated * Remove "author" and "summary" Leaves "url" as a hidden element * Add page link to h1 tag The h1 tag now contains the Schema-org `url` itemprop and the Microformats `url` class in an anchor tag. The anchor tag is styled to not look like a link. * Put author 'u-url' on author__name h3 This also puts the same `{{ author.home | default: '/' | absolute_url }}` construct on `author__avatar` to remove the Jekyll `author.home` conditional. Also addresses SCSS text color error. * Update CHANGELOG and history * Enable toc sidebar scrolling (mmistakes#2874) * Enable toc sidebar scrolling * Refactor style rules * Move style rules from 'navigation' to 'sidebar' * Remove custom scrollbar styles * Enable sticky toc on test post * Update CHANGELOG and history * Add margin around Google ads * Add role to search (mmistakes#3086) * Update CHANGELOG and history * Added Danish translations (mmistakes#3095) * Added Danish translations * Fixed wrong commit. * Update CHANGELOG and history * Enable magnific popup on <a> tags only when it has <img> (mmistakes#3114) * Update CHANGELOG and history * Remove extra semi-colon * Bump path-parse from 1.0.6 to 1.0.7 Bumps [path-parse](https://github.com/jbgutierrez/path-parse) from 1.0.6 to 1.0.7. - [Release notes](https://github.com/jbgutierrez/path-parse/releases) - [Commits](https://github.com/jbgutierrez/path-parse/commits/v1.0.7) --- updated-dependencies: - dependency-name: path-parse dependency-type: indirect ... Signed-off-by: dependabot[bot] <[email protected]> * Update CHANGELOG and history * include video does not survive compress.html (mmistakes#3117) * Update CHANGELOG and history * Use GitHub issue templates (mmistakes#3133) https://docs.github.com/en/communities/using-templates-to-encourage-useful-issues-and-pull-requests/configuring-issue-templates-for-your-repository * Delete stale.yml * Delete stale.yml * Added optional label attribute (mmistakes#3128) Added label attribute as per utterances optional label setting. * Fix broken link & Add Baidu site verification (mmistakes#3139) * Fix broken link Link to Bing Webmaster Tools was broken. * Fix broken link Link to Open Graph debug tool was broken. * Add Baidu site verification (mmistakes#2830) Added `baidu_site_verification` to `_config.yml` * Making verbiage consistent w/current _config.yml (mmistakes#3180) The plugin in question comes by-default listed in _config.yml ; it's better to say that the user must _retain_ it as listed, not that the user needs to add it. * Link clarifying adding plugins (mmistakes#3181) The phrase "put them here!" doesn't sufficiently clarify what to do; I add link to the Jekyll documentation with the proper syntax. * feat: Sort comments by date ascending (mmistakes#3184) * Update Brazilian Portuguese translation (mmistakes#3204) * Update Brazilian Portuguese translation * Revert some translations to reduce friction * Update CHANGELOG and history * Update CHANGELOG and history * Fix keybase class (mmistakes#3221) * Fix keybase class * Fix fas->fab * Update CHANGELOG and history * ✏ fix typo (mmistakes#3232) * Update CHANGELOG and history * Add missing comma (mmistakes#3318) Co-authored-by: Yuchen Zhong <[email protected]> * Update CHANGELOG and history * Automatically close invalid PRs using GitHub Actions (mmistakes#3313) * Try auto-closing bad PRs * Include empty PR body as well * Add "Type: Invalid" label as well * Update CHANGELOG and history * Added sameAs (mmistakes#3087) * Update CHANGELOG and history * Use <a> color for blockquote.notice border (mmistakes#3140) Close mmistakes#3068 * Update CHANGELOG and history * Fix inline code style not applied to stylized text (mmistakes#3253) * bug: inline code style not applied to stylized text * Use double colons for pseudoelements * Update CHANGELOG and history * Update to Jquery 3.6.0 (mmistakes#3254) * Update CHANGELOG and history * fix typo about loading javascript in footer (mmistakes#3350) * Update CHANGELOG and history * add optinal lunr searching of pages (mmistakes#3352) * Update CHANGELOG and history * Exclude `main.scss` from Lunr search index * Add Kiswahili translation (mmistakes#3489) * Add Kiswahili translation * Add Kiswahli to README * Add Kiswahili to documentation * Update * Update attribution link (mmistakes#3553) * Update CHANGELOG and history * Update link to Font Awesome gallery (mmistakes#3599) * Update CHANGELOG and history * Make it possible to enable breadcrumbs per page (mmistakes#3096) * Make it possible to disable breadcrumbs per page * Update single.html * Update single.html * Update algolia-search-scripts.html (mmistakes#3102) Fix issue mmistakes#3101 * Update CHANGELOG and history * Replace with public YouTube video Close mmistakes#3649 * Replace with public YouTube video embeds * Update CHANGELOG and history * Fix mmistakes#3096 enabling breadcrumb on all pages (mmistakes#3668) * Remove IE9 upgrade notice (mmistakes#3666) * Update CHANGELOG and history * Fix mmistakes#3668 breaking "disable per-page when globally enabled" (mmistakes#3669) * Fix mmistakes#3668 breaking "disable per-page when globally enabled" * `default:` filter doesn't fit here https://shopify.github.io/liquid/filters/default/ * Update CHANGELOG and history * Improve PR close auto-comment message (mmistakes#3713) * Improve auto-comment message * Lock these PRs after closing * add webrick * whatever, line ending perhaps * bug fix --------- Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: iBug ♦ <[email protected]> Co-authored-by: dianlujitao <[email protected]> Co-authored-by: Michael Rose <[email protected]> Co-authored-by: 谭九鼎 <[email protected]> Co-authored-by: Juan Ara <[email protected]> Co-authored-by: Michael Rose <[email protected]> Co-authored-by: Andrey Kartashov <[email protected]> Co-authored-by: Lim Jing Heng <[email protected]> Co-authored-by: Miguel Belardinelli Prytoluk <[email protected]> Co-authored-by: Johannes Ganzenmüller <[email protected]> Co-authored-by: Lars Olesen <[email protected]> Co-authored-by: Leo <[email protected]> Co-authored-by: Kai A <[email protected]> Co-authored-by: Quan <[email protected]> Co-authored-by: M. Akhyar Rahman H <[email protected]> Co-authored-by: Mitchell Skaggs <[email protected]> Co-authored-by: Susan Stevens <[email protected]> Co-authored-by: Jip-Hop <[email protected]> Co-authored-by: gricn <[email protected]> Co-authored-by: Uri Brecher <[email protected]> Co-authored-by: PHOENiX <[email protected]> Co-authored-by: Sean Killeen <[email protected]> Co-authored-by: Johannes Ganzenmüller <[email protected]> Co-authored-by: Nicolas Elie <[email protected]> Co-authored-by: luweizheng <[email protected]> Co-authored-by: Vincent Tam <[email protected]> Co-authored-by: Tom Manner <[email protected]> Co-authored-by: Tom Manner <[email protected]> Co-authored-by: ShifraSec <[email protected]> Co-authored-by: David Lechner <[email protected]> Co-authored-by: Randall Wood <[email protected]> Co-authored-by: Guillaume Gautreau <[email protected]> Co-authored-by: Christian Oliff <[email protected]> Co-authored-by: Erik Westrup <[email protected]> Co-authored-by: Anton Brall <[email protected]> Co-authored-by: Kulbhushan Chand <[email protected]> Co-authored-by: Peter Murray <[email protected]> Co-authored-by: Johnson <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: John Scott <[email protected]> Co-authored-by: Nathan Cho <[email protected]> Co-authored-by: Jason Hemann <[email protected]> Co-authored-by: Daniel Schroeder <[email protected]> Co-authored-by: Georger Araújo <[email protected]> Co-authored-by: Andrew McIntosh <[email protected]> Co-authored-by: Sander Holvoet <[email protected]> Co-authored-by: Yuchen <[email protected]> Co-authored-by: Yuchen Zhong <[email protected]> Co-authored-by: Nicholas Perry <[email protected]> Co-authored-by: Benson Muite <[email protected]> Co-authored-by: FavorMylikes <[email protected]>
* Try auto-closing bad PRs * Include empty PR body as well * Add "Type: Invalid" label as well
This is an enhancement or feature.
Summary
Use a GitHub Actions to close invalid PRs that would have been done manually.
This PR adds two aspects of content:
An "identification token" for detection, based on the fact that most (if not all) invalid PRs don't even bother reading the
PULL_REQUEST_TEMPLATE
, let alone properly filling them. This provides us with a nice simple heuristic that should "just work" for 99% of the cases.This PR adds something at the end of the PR template with the hope that a reasonable user would have removed it should they want to submit some real thing, and checks if the "must remove" content is left intact.
Update 1: Shortly after the creation of this PR there came 3314 that included an empty body (the user just deleted everything pre-filled in the input box). Considering that this could also be a pattern, I updated the workflow file to include a check for this case.
A workflow file that runs on every opened or reopened PR, checking the "identification token", and closes it if found.
This workflow runs on
pull_request_target
because the intuitivepull_request
event does not trigger a workflow run if the PR has merge conflicts, which is often the case for invalid PRs. There's a reply suggesting this alternative trigger that according to my tests, works.Unfortunately, I have yet to discover an easy way to perform these actions (comment + close) using only GitHub-provided workflow steps. While I certainly could craft API calls using
curl
or another command-line tool (or use more sophisticated things like Python, altogether), I chose not to overcomplicate things and use a Marketplace Actions step. If external dependencies are a concern to you, I'm happy to do this myself with scripts. Please let me know if this is the case.Since we're not loading any content from the submitted PR (or any code at all), we should be safe from (malicious) code. The only input we're consuming is a string sent as part of the event payload. The only operation performed on it is
contains()
which is a substring match. TBH I would have been shocked if there were any security concerns on this simple thing.Demo
Please see this PR and this workflow run on my repo.
Context
Recent influx of invalid PRs that submit personal site content instead of something intended to be included into the project.
P.S. I've been watching this repository for years and I too am tired of unsubscribing every invalid PR and cleaning up my email inbox.