Constable is a web application that grades the contributability of a repository. It provides as a Github badge which developers can add to their repositories and the contributors can use it to get a first glance of the project quality without putting a lot of effort. It displays the entire grade report along with the link for the badge in a Dashboard which can be manually added to the repository. It also provides a simple add action to any GitHub Actions workflow you like and start seeing how contributable your repository is. A sample workflow is provided below:
name: "units-test"
on:
pull_request:
jobs:
# Constable
pull-request-workflow:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: constable
uses: dangoslen/constable-github-action@v0.1
- name: Comment PR
uses: thollander/actions-comment-pull-request@master
with:
message: "
# ![](https://img.shields.io/badge/Constable-${{ pull-request-workflow.constable.outputs.grade }}-blue)
<details>
<summary>Click to see the report!</summary>
${{ pull-request-workflow.constable.outputs.report }}
</details>"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
This workflow checks out the repository, grades it with Constable, and supplies the grade and the report to the pull request as a comment. You can combine Constable with whatever workflow you like!
Constable ranks contributability in "letter grades". A+/-, B+/-, C+/-, D+/-, F. For finer granularity, we also provide the raw percentage from 0 - 100 and a report in a .md
format. The letter grades is determined from the raw percentage using a 10 point scale where the +/- is the top 3 points and bottom 3 points of each 10 point range.
Constable looks for the presence of files that are associated with making it easy to contribute, as well as signs the repository is active. We currently use the following
- Presence of a
README.md
file - Presence of a
CONTRIBUTING.md
file - Presence of a
CODE_OF_CONDUCT.md
file - Presence of a
License
file - Presence of a
Citation
file - Presence of a
.gitignore
file - Average pull request closing time
- Average issue closing time
Do you have an idea of how to grade a repository's contributability? We want you to contribute to this project! Please see our Contributing file to how to contribute to Constable!
A summary of the outputs is listed below. You can also see this in the Action Definition
grade
- a string
containing the letter grade (A+/-, B+/-, C+/-, D+/-, F) of the repositories contributability.
score
- an integer
from 0 - 100 of the
report
- a string
containing a report of why the repository recieved the percentage it did.
We think this effort from GitHub is a great start. However, many more elements of of a repository make it contributable than just a few files being present. The goal of Constable is to be a simple tool that can be used to extend what GitHub has started. Eventually, Constable would hope to be available to other providers like GitLab or BitBucket via a REST API.
Before contributing to Constable, please see our CONTRIBUTING.md file. All processes for adding features, reporting bugs, or asking questions can be found there.
Constable uses the GitHub Action Toolkit for the various packages.
Packaging for distribution happens automatically for every pull request or push to main
or releases
. If you want to package the source for distribution from your own branch before opening a pull request, you can simply run the following:
npm run package
Since the packaged index.js
is run from the ./dist
folder.
git add dist
And now GitHub will know to use the action sourced under the ./dist
folder. You could use it in a workflow like
uses: dangoslen/constable-github-action@<your-branch>
From the root folder run the following commands:
cd src/constable-app
npm install
npm start
This would run the server and you'll be able to see the UI in your browser. A sample of the UI is shown below:
Now key in the username and repository name to get the statistics and grade for your repository! Here is the grade report for Zephyr:
Before you push the code, run the following command to build the code:
npm run package