Skip to content

Commit

Permalink
v3.1.0: More stats available
Browse files Browse the repository at this point in the history
  • Loading branch information
manuelmhtr committed Dec 22, 2024
1 parent 593c720 commit 16c7b08
Show file tree
Hide file tree
Showing 27 changed files with 462 additions and 88 deletions.
7 changes: 7 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
# Changelog
All notable changes to this project will be documented in this file.

## [3.1.0] - 2024-12-22
### Added
- Adds new available stats: `reviewedAdditions`, `reviewedDeletions`, `reviewedLines`, `totalObservations`, `medianObservations`, `revisionSuccessRate`, `additions`, `deletions` and `lines`.

### Changes
- `commentsPerReview` is calculated now as the median, not the average.

## [3.0.0] - 2024-12-12
### Added
- New `stats` option to specify the stats to be calculated.
Expand Down
45 changes: 34 additions & 11 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@
[![CI](https://github.com/flowwer-dev/pull-request-stats/workflows/Tests/badge.svg)](https://github.com/flowwer-dev/pull-request-stats/actions?query=workflow%3ATests)
[![GitHub Marketplace](https://img.shields.io/badge/Marketplace-Pull%20Request%20Stats-blue.svg?colorA=24292e&colorB=0366d6&style=flat&longCache=true&logo=)](https://github.com/marketplace/actions/pull-request-stats)

Github action to print relevant stats about Pull Request reviewers.
Github action to print relevant [stats](#stats) about Pull Request.

The objective of this action is to:

* Track and increase your team's performance.
* Reduce the time taken to review the pull requests.
* Encourage quality on reviews.
* Help to decide which people to assign as reviewers.
Expand Down Expand Up @@ -52,7 +53,7 @@ The possible inputs for this action are:
| `organization` | If you prefer, you may specify your organization's name to calculate the stats across all of its repositories. When specifying an organization, **it is mandatory to pass a Personal Access Token** in the `token` parameter. | `null` |
| `period` | The period used to calculate the stats, expressed in days. | `30` |
| `limit` | The maximum number of rows to display in the table. A value of `0` means unlimited. | `0` |
| `stats` | A comma-separated list of stats to calculate and display. Possible values: `totalReviews`, `timeToReview`, `totalComments`, `commentsPerReview`, `openedPullRequests`. For details on each stats check the [Stats](#stats) section. | `totalReviews,timeToReview,totalComments` |
| `stats` | A comma-separated list of stats to calculate and display. Possible values: `totalReviews`, `timeToReview`, `totalComments`, etc... (Check all available in the [Stats](#stats) section) | `totalReviews,timeToReview,totalComments` |
| `charts` | Whether to add a chart to the start. Possible values: `true` or `false`. | `false` |
| `disableLinks` | If `true`, removes the links to the detailed charts. Possible values: `true` or `false`. | `false` |
| `sortBy` | The column used to sort the data. Possible values: `totalReviews`, `timeToReview`, `totalComments`, `commentsPerReview`, `openedPullRequests`. | `totalReviews` |
Expand Down Expand Up @@ -137,7 +138,7 @@ jobs:
charts: true
disableLinks: true
sortBy: 'totalComments'
stats: 'totalComments,openedPullRequests'
stats: 'totalComments,openedPullRequests,totalReviews'
```

This config will:
Expand All @@ -146,11 +147,11 @@ This config will:
* Display charts for the metrics.
* Remove the links to detailed charts.
* Sort results by the "Total comments" column.
* Show the "Total comments" and "Opened pull requests" columns (in that order).
* Show the "Total comments", "Opened pull requests"and "Median time to review" columns (in that order).

and print a table like this:

| | User | Total comments | Total reviews | Median time to review |
| | User | Total comments | Opened pull requests | Median time to review |
| ------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------- | ------------------------- | ------------------ | ------------------- |
| <a href="https://github.com/manuelmhtr"><img src="https://avatars2.githubusercontent.com/u/1031639" width="32"></a> | manuelmhtr<br/>🥇 | **12**<br/>▀▀▀▀▀▀▀▀ | **8**<br/>▀▀▀▀ | 53m<br/> |
| <a href="https://github.com/CarlosCRG19"><img src="https://avatars.githubusercontent.com/u/61464973" width="32"></a> | CarlosCRG19<br/>🥈 | 3<br/>▀▀ | 4<br/>▀▀ | 58m<br/> |
Expand All @@ -162,13 +163,35 @@ and print a table like this:

## Stats

The stats are calculated as follows:
This section explains the available stats that can be displayed using the [`stats` option](#action-inputs) and how they are calculated.

* **Total reviews (`totalReviews`):** The count of all Pull Requests reviewed by a person in the period.
* **Time to review (`timeToReview`):** The **median** time a reviewer takes from the _Pull Request publication_ or the last _Commit push_ (whatever happens last) to the first time the pull request is reviewed.
* **Total comments (`totalComments`):** The number of comments made while reviewing other users' Pull Requests during the specified period. Comments made on your own PRs or general PR discussions are excluded; only comments directly related to code are counted.
* **Comments per review (`commentsPerReview`):** The **average** comments the reviewer made on the pull requests.
* **Opened pull requests (`openedPullRequests`):** The number of pull requests opened by the user in the period.
### Review stats

Stats related to the review process:

| Stat name and ID | Description |
| ---------------- | ----------- |
| **Total reviews (`totalReviews`):** | The total number of pull requests reviewed by a user during the specified period. |
| **Total comments (`totalComments`):** | The number of comments made while reviewing other users' Pull Requests during the specified period. Excludes comments made on your own pull requests or general discussions; only code-related comments are included. |
| **Time to review (`timeToReview`):** | The **median** time a reviewer takes from the _Pull Request publication_ or the last _commit push_ (whatever happens last) to the first time the pull request is reviewed. |
| **Comments per review (`commentsPerReview`):** | The **median** number of comments a reviewer made per pull request. |
| **Reviewed additions (`reviewedAdditions`):** | The total number of added lines reviewed. |
| **Reviewed deletions (`reviewedDeletions`):** | The total number of deleted lines reviewed. |
| **Reviewed lines (`reviewedLines`):** | The total number of lines reviewed (additions + deletions). |

### Performance stats:

Stats related to the production process (opened pull requests):

| Stat name and ID | Description |
| ---------------- | ----------- |
| **Opened pull requests (`openedPullRequests`):** | The number of pull requests opened by the user in the period. |
| **Total observations (`totalObservations`):** | The total number of comments received on pull requests opened by the user. |
| **Median observations (`medianObservations`):** | The **median** number of comments received per pull request opened by the user. |
| **Revision success rate (`revisionSuccessRate`):** | The percentage of pull request reviews resulting in approval, compared to the total reviews received. (eg. After 2 "Comment", 4 "Request changes" and 3 "Approve" reviews, the success rate would be `0.33`)|
| **Additions (`additions`):** | The total number of added lines across the opened pull requests. |
| **Deletions (`deletions`):** | The total number of deleted lines across the opened pull requests. |
| **Lines (`lines`):** | The total number of lines changed (added and deleted) across all pull requests opened by the user. |

## Integrations 🔌

Expand Down
Loading

0 comments on commit 16c7b08

Please sign in to comment.