eslint-github-botPlugin-based GitHub bot for ESLint
ESLint GitHub bot
eslint-github-bot
is a bot created with probot which automates some common tasks for repositories run by the ESLint team.
The bot can perform the following tasks:
- Triage - adds the "triage" label to newly-created issues which don't have labels.
- Commit message check - adds a status check to pull requests to verify that they follow ESLint's pull request guidelines
- Needs info - adds a comment to issues requesting more information when a maintainer adds the
needs info
label. - Release/TSC meeting issues - creates a new issue with the
release
/tsc meeting
label scheduled two weeks later, after another release/TSC meeting issue is closed. - Release monitor - searches the repository for an issue with the
release
andpatch release pending
labels, indicating that a patch release might soon be created frommaster
. If an issue is found, adds a pending status check to all PRs that would require a semver-minor release, to prevent anyone from accidentally merging them. - Issue Archiver - Locks and adds a label to issues which have been closed for a while
- Issue Closer - Closes and adds a label to issues which have been inactive for a while
- WIP Tracking - adds pending status check for PRs with WIP in the title or with "do not merge" label, and marks the status check as successful once the WIP indicators are removed.
- PR ready to merge (experimental) - adds a label to all PRs which are "ready to merge", defined by the following criteria:
- At least one review is approved.
- Build status is
success
.
- Check unit tests (experimental) - makes sure a PR contains unit tests. This check will be ignored for PRs with
Build|Chore|Docs|Upgrade
in the commit message. - Duplicate comments (inactive) - removes all the duplicates comments by this bot and leaves the last one of each type.
🔧
Setup
- Clone this repo.
npm install
- Start the app
-
npm start
to start it as a GitHub APP
-
ENV variables required:
-
PORT
: Port for web server (optional, defaults to 8000). -
SECRET
: Secret setup for GitHub webhook or you generated when you created the app. -
PRIVATE_KEY
: the contents of the private key you downloaded after creating the app. -
APP_ID
: The numeric app ID
Adding plugins
To add a plugin:
- Create the plugin as a new file in
src/plugins
. - Add the plugin to the list in
src/plugins/index.js
. - Add the plugin to the list in
src/app.js
to enable it by default.
Deployment
The bot is deployed to a Dokku instance named github-bot.eslint.org and is installed as a GitHub Application at the organization level.
评论