wildfly-github-bot helps you to keep your pull requests in the correct format.
This project is build with usage of Quarkus GitHub App: https://quarkiverse.github.io/quarkiverse-docs/quarkus-github-app/dev/index.html
- Expected format for Pull Requests - Defined in config file:
- Title - Regex, we expect to match for title of the Pull Request.
- Commit - Regex, we expect to match for at least one commit in the Pull Request.
- Description - Regexes, we expect to match for description of the Pull Request.
- Activation Rules for matching on Pull Requests and applying functionality - Defined in config file:
- Notify - List of people to request Pull Request review. People, we can't request review from, we only cc notify them - Rule functionality.
- Labels - Labels to apply on the Pull Request - Rule functionality.
- Title - Regex, used on title of the Pull Request - Rule activation.
- Body - Regex, used on body of the Pull Request - Rule activation.
- TitleBody - Regex, used on either title or body of the Pull Request - Rule activation.
- Directories - List of directories, if corresponding files are changed in the Pull Request - Rule activation.
- Option to disable format checks on Pull Request by adding message
@wildfly-bot[bot] skip format
in the description. - Automatically append JIRA links into description of the Pull Request, if issue tracker number is detected in Title, Description or Commit.
- Automatically applies/removes labels on a Pull Request:
rebase-this
- depending on conflicts withmain
branch.fix-me
- depending on Pull Request Review status update.
- Tracking changes to config file, if it's kept valid
- On startup, validates config file, creates
rebase-this
andfix-me
labels if necessary. Notifiesemails
in case of problems encountered.
After forking the project we need to register wildfly-github-bot on GitHub for your account. Go to GitHub Apps and click on New GitHub Apps
Also, you can access this page by clicking on your profile picture on gitHub and go to Settings > Developer Settings > GitHub Apps > New GitHub App
.
Fields to fill in:
- GitHub App name- should be unique
- Homepage URL- the link to the forked project
- Webhook URL
- Go to smee.io and press
Start a new channel
- Add this link to
Webhook URL
- Set up permissions
Commit statuses
-Access: Read and write
Contents
-Access Read-only
Metadata
-Access: Read-only
Pull requests
-Access: Read and write
- Subscribe to events
Push
Pull requests
Pull request review
Pull request review comment
-
Create a private key
After creating the app scroll down and press
Generate a private key
You will be asked to download the key, keep it around, we will need it for the next step.
As the configuration is environment-specific, and you probably don’t want to commit it in your repository, the best is to create in the root a .env
file.
The content of your .env file should be as follows:
QUARKUS_GITHUB_APP_APP_ID=<the numeric app id>
QUARKUS_GITHUB_APP_APP_NAME=<the name of your app>
QUARKUS_GITHUB_APP_WEBHOOK_PROXY_URL=<your Smee.io channel URL>
QUARKUS_GITHUB_APP_PRIVATE_KEY=-----BEGIN RSA PRIVATE KEY-----\
<your private key> \
-----END RSA PRIVATE KEY-----
QUARKUS_MAILER_FROM=<email address>
QUARKUS_MAILER_USERNAME=<email address>
QUARKUS_MAILER_PASSWORD=<email password>
NOTE: If you do not wish to send emails, do not fill in the
QUARKUS_MAILER_*
variables please.
QUARKUS_GITHUB_APP_APP_ID The numeric app id appears in the App ID field.
QUARKUS_GITHUB_APP_APP_NAME The name of your app is the one appearing in the GitHub URL. It is only used to improve usability in dev mode.
QUARKUS_GITHUB_APP_WEBHOOK_PROXY_URL The URL you obtained when you created your Smee.io channel.
QUARKUS_GITHUB_APP_PRIVATE_KEY The content of the private key you generated and downloaded. Open the key file with a text editor as key viewers usually only show fingerprints.
QUARKUS_MAILER_FROM email address displayed in the message
QUARKUS_MAILER_USERNAME email address sending the email
QUARKUS_MAILER_PASSWORD password to the email address corresponding to QUARKUS_MAILER_USERNAME. Note You probably want to generate it using Gmail > Settings > Security > 2-Step Verification > App passwords
Default email service is Gmail. To change this behavior or to override predefined parameters in applications.properties file please refer to Mailer Extension Documentation
- Create a new repo or use an already created one in which you want to track PRs.
- Go to the settings of your GitHub App and go to
Install App > Install > Only select repositories > Select the one you need > Install
- In your repo in the main branch create a folder
.github
and a filewildfly-bot.yml
with xml code in it:
wildfly:
rules:
- title: "test"
- body: "test"
notify: [xstefank,petrberan]
format:
title:
message: "Wrong content of the PR title"
description:
regexes:
- pattern: "JIRA:\\s+https://issues.redhat.com/browse/WFLY-\\d+|https://issues.redhat.com/browse/WFLY-\\d+"
message: "The PR description must contain a link to the JIRA issue"
emails:
- [email protected]
- [email protected]
title
- Checks the title of a PR by using a regular expression generated fromprojectKey
field, which is by default "WFLY". You can find more information in wildfly-bot-config-example.ymldescription
- Checks comments of a PR by using individual regular expressions in thepattern
fields underregexes
.
The correct format in example is "https://issues.jboss.org/browse/WFLY-11"
message
- The text of an error message in the respective check.emails
- List of emails to receive notifications.
NOTE:
title
andcommit
are enabled by default. More here.
Also, there is a possibility to select checks that you need. Just left in the wildfly-bot.yml
file checks you need.
Like this:
wildfly:
rules:
- title: "test"
- body: "test"
notify: [xstefank,petrberan]
format:
title:
message: "Wrong content of the PR title"
emails:
- [email protected]
- [email protected]
Run your application in dev mode that enables live coding using:
./mvnw compile quarkus:dev
NOTE: Dev UI available in dev mode only at http://localhost:8080/q/dev/.
NOTE: In Dev mode sending emails is mocked. To disable this, set the following property
quarkus.mailer.mock=false
Try to create a PR and update it a few times. The format check sends commit statuses that you will see in the PR.
Our application currently runs in 2 different modes.
- SSE - Events received by GitHub
- Event Polling - Retrieve manually events in scheduled intervals
For such use case, we have profile aware tests, where by default we test SSE events. To run Event Polling you should set quarkus.test.profile=polling
.
- JDK 17+ with JAVA_HOME configured appropriately
- OpenShift (e.g, https://developers.redhat.com/developer-sandbox)
- OpenShift CLI
- Apache Maven 3.8.6
Fill in the following information.
- Application name
- Homepage URL
- Webhook URL
- put any placeholder URL here, as you will get the URL after the deployment
- Webhook secret
- You can generate a secret by using GitHub's recommended method:
ruby -rsecurerandom -e 'puts SecureRandom.hex(20)'
- or use
pwgen
:pwgen -N 1 -s 40
- save it as you will need it later
- You can generate a secret by using GitHub's recommended method:
- Permissions
Commit statuses
-Access: Read and write
Metadata
-Access: Read-only
Pull requests
-Access: Read and write
- Subscribe to events
Pull requests
Pull request review comment
- Scroll down to generate a private key
- Download it as you will need it later
- You can find this in the "Install App" tab of your GitHub application
oc login -u <username>
- You will need to fill required information in prompt
oc login --token=<token> --server=<serverUrl>
- You can request the token via the
Copy Login Command
link in the OpenShift web console.
- You can request the token via the
`oc create secret generic wildfly-bot --from-literal=QUARKUS_GITHUB_APP_WEBHOOK_SECRET=<your-webhook-secret> --from-file=QUARKUS_GITHUB_APP_PRIVATE_KEY=<path-to-your-private-key>`
NOTE: If you wish to use mailing option, please append the following properties to the previous command
--from-literal=QUARKUS_MAILER_FROM=<email address> --from-literal=QUARKUS_MAILER_USERNAME=<email address> --from-literal=QUARKUS_MAILER_PASSWORD=<email password>
-
Go to the application home directory and run:
./mvnw clean install -Dquarkus.kubernetes.deploy=true -Dquarkus.openshift.env.vars.quarkus-github-app-app-id=<your-github-app-id>
-
You can also put the config properties to the
application.properties
-
Get the list of exposed routes:
oc get routes
-
Edit the WebHook URL using the retrieved
HOST/PORT
value:http://<HOST/PORT>
And that's it. Again, try to create a PR to verify the format of the PR. q
We run WildFly GitHub Bot on Openshift in production. To save resources we also deploy it as native executable.
-
Log in into Openshift
oc login ...
-
Then create the relevant secret:
oc create secret generic wildfly-bot --from-literal=QUARKUS_GITHUB_APP_WEBHOOK_SECRET={TBD} --from-file=QUARKUS_GITHUB_APP_PRIVATE_KEY={TBD} --from-literal=QUARKUS_MAILER_FROM={TBD} --from-literal=QUARKUS_MAILER_USERNAME={TBD} --from-literal=QUARKUS_MAILER_PASSWORD={TBD}
-
Deploy the bot:
./mvnw clean install -Dquarkus.kubernetes.deploy=true -Dquarkus.openshift.env.vars.quarkus-github-app-app-id={TBD} -Dquarkus.native.container-build=true -Dnative