mirror of
https://github.com/CodelyTV/pr-size-labeler.git
synced 2025-02-13 16:50:22 -05:00
🏷 Visualize and optionally limit the size of your Pull Requests
actionautomationcodelycodelytvgithubgithub-actiongithub-actionspull-requestpull-request-actionpull-request-managementpull-requests
* Support ignoring file deletions Tweak action.yml * Tweak the readme description Co-authored-by: Onkar Ruikar <87750369+OnkarRuikar@users.noreply.github.com> * tweak removed file check to include line_deletion var Co-authored-by: Onkar Ruikar <87750369+OnkarRuikar@users.noreply.github.com> * docs: unify the "Basic concepts or assumptions" readme section into the most related arguments to make it easier to read Improve the existing contribution guide (#74) * Improve the existing contribution guide * reorder the contribution steps to push testing up Co-authored-by: Javier Ferrer González <javier.ferrer@codely.com> * tweak contribution process opener copy Co-authored-by: Javier Ferrer González <javier.ferrer@codely.com> --------- Co-authored-by: Javier Ferrer González <javier.ferrer@codely.com> Put back accidental deletion --------- Co-authored-by: Onkar Ruikar <87750369+OnkarRuikar@users.noreply.github.com> Co-authored-by: Javier Ferrer González <javier.ferrer@codely.com> Co-authored-by: Rob W <rlw0788@gmail.com> |
||
---|---|---|
.github | ||
src | ||
tests | ||
.env | ||
.gitignore | ||
action.yml | ||
Dockerfile | ||
entrypoint.sh | ||
install-dependencies.sh | ||
LICENSE | ||
README.md |
🏷 Pull Request Size Labeler
Visualize and optionally limit the size of your Pull Requests
🚀 Usage
Create a file named labeler.yml
inside the .github/workflows
directory and paste the following configuration.
Note
Take into account that PR Size Labeler considers any line addition, deletion, or modification as a change by default, but you can configure it with optional arguments such as
files_to_ignore
,ignore_file_deletions
, or evenignore_line_deletions
.
name: labeler
on: [pull_request]
jobs:
labeler:
runs-on: ubuntu-latest
name: Label the PR size
steps:
- uses: codelytv/pr-size-labeler@v1
with:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
xs_label: 'size/xs'
xs_max_size: '10'
s_label: 'size/s'
s_max_size: '100'
m_label: 'size/m'
m_max_size: '500'
l_label: 'size/l'
l_max_size: '1000'
xl_label: 'size/xl'
fail_if_xl: 'false'
message_if_xl: >
This PR exceeds the recommended size of 1000 lines.
Please make sure you are NOT addressing multiple issues with one PR.
Note this PR might be rejected due to its size.
github_api_url: 'https://api.github.com'
files_to_ignore: ''
🎛️ Arguments
Name | Required | Default Value | Description |
---|---|---|---|
GITHUB_TOKEN |
Yes | Automatically supplied | GitHub token needed to interact with the repository. |
xs_label |
No | 'size/xs' | Label for very small-sized PRs. |
xs_max_size |
No | '10' | Maximum number of changes allowed for XS-sized PRs. |
s_label |
No | 'size/s' | Label for small-sized PRs. |
s_max_size |
No | '100' | Maximum number of changes allowed for S-sized PRs. |
m_label |
No | 'size/m' | Label for medium-sized PRs. |
m_max_size |
No | '500' | Maximum number of changes allowed for M-sized PRs. |
l_label |
No | 'size/l' | Label for large-sized PRs. |
l_max_size |
No | '1000' | Maximum number of changes allowed for L-sized PRs. |
xl_label |
No | 'size/xl' | Label for extra-large-sized PRs. A PR will be labeled as 'xl' if it exceeds the amount of changes defined in l_max_size |
fail_if_xl |
No | 'false' | Whether to fail the GitHub workflow if the PR size is 'XL' (blocks the merge). |
message_if_xl |
No | Custom message | Message to display when a PR exceeds the 'XL' size limit. |
github_api_url |
No | 'https://api.github.com' | URL for the GitHub API, can be changed for GitHub Enterprise Servers. |
files_to_ignore |
No | '' | Files to ignore during PR size calculation. Supports newline or whitespace delimited list. |
ignore_line_deletions |
No | 'false' | Whether to ignore lines which are deleted when calculating the PR size. If set to 'true', deleted lines will be ignored. |
ignore_file_deletions |
No | 'false' | Whether to ignore completely deleted files when calculating the PR size. If set to 'true', deleted files will be ignored. Distinct from ignore_line_deletions in that it only ignores files which are deleted completely. If ignore_line_deletions is used then using ignore_file_deletions is redundant. |
Example for files_to_ignore
:
files_to_ignore: 'package-lock.json *.lock'
# OR
files_to_ignore: |
"package-lock.json"
"*.lock"
"docs/*"
Contributing
If you would like to help improve the project, please read the contribution guidelines.