Dev Rating is a command-line tool that suggests minimal Pull Request size for each contributor so that the PRs will have the same impact to the codebase. Having PRs with the same impact makes it easier to evaluate the amount of work done.
It counts the deleted lines of code in the PRs and builds a contributor rating based on code stability. Low-rated members are encouraged to post more code in PR because their code statistically lives less.
Merge commits authors treated as authors of the PRs. In the case of rebased PRs, it treats each commit as a separate PR.
Install the tool:
dotnet tool install -g devrating.consoleapp
Analyze your repository:
cd <path-to-repo>
git checkout master
devrating update
Print the suggested PR sizes for each contributor:
devrating top
Sample output:
Rating | PRs (90d) | Suggested additions | Author
------- | --------- | ------------------- | ------
1553.86 | 45 | 21 | <[email protected]>
1524.85 | 10 | 23 | <[email protected]>
1513.59 | 13 | 24 | <[email protected]>
1499.43 | 0 | 25 | <[email protected]>
1496.14 | 0 | 25 | <[email protected]>
1495.48 | 0 | 25 | <[email protected]>
1485.74 | 0 | 26 | <[email protected]>
1481.63 | 96 | 26 | <[email protected]>
1475.78 | 12 | 27 | <[email protected]>
1473.52 | 77 | 27 | <[email protected]>
When Developer A deletes lines of code, he increases his rating and lowers the rating of the deleted lines author (Developer B). The Elo rating system is used:
where
-
$n$ - number of PRs authored by Developer B, -
$Add_{Bi}$ - number of added lines by Developer B in the$i$ -th PR, -
$Del_{Ai}$ - number of deleted lines by Developer A from the$i$ -th PR, -
$R_A$ - initial rating of Developer A, -
$R_B$ - initial rating of Developer B, -
$R_A^{'}$ - new rating of Developer A, -
$R_B^{'}$ - new rating of Developer B.
When the system meets a new author it sets
Minimal additions per PR:
where
-
$M_A$ - the minimal added lines number for Developer A in his PRs.
An average-rated member suggested to add 25 lines of code in PRs.
The tool doesn't change rating if deleted line was introduced in previous major versions of code. It reads git tags with semver
to figure out when was the last major update.
dotnet run --project ./consoleapp
This repository is a Software Quality Award winner.