Skip to content

Commit

Permalink
Add branch limit
Browse files Browse the repository at this point in the history
  • Loading branch information
yqiu24 committed Nov 14, 2023
1 parent 9a3204c commit a4096f6
Show file tree
Hide file tree
Showing 5 changed files with 30 additions and 6 deletions.
3 changes: 2 additions & 1 deletion .github/workflows/cleanup.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -32,5 +32,6 @@ jobs:
with:
github_token: ${{ github.token }}
last_commit_age_days: 100
dry_run: no
dry_run: yes
ignore_branches: test_prefix/one,test_prefix/two,test_prefix_ignored/one
branch_limit: 1
6 changes: 5 additions & 1 deletion action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,10 @@ inputs:
description: "The API base url to be used in requests to GitHub Enterprise"
required: false
default: "https://api.github.com"
branch_limit:
description: "The max number of branches that can be deleted"
required: false
default: "100"

outputs:
deleted_branches: # id of output
Expand All @@ -50,5 +54,5 @@ runs:
python3 main.py --ignore-branches=${{ inputs.ignore_branches }} \
--last-commit-age-days=${{ inputs.last_commit_age_days }} --allowed-prefixes=${{ inputs.allowed_prefixes }} \
--dry-run=${{ inputs.dry_run }} --github-token=${{ inputs.github_token }} \
--github-base-url=${{ inputs.github_base_url }}
--github-base-url=${{ inputs.github_base_url }} --branch-limit=${{ inputs.branch_limit }}
shell: bash
3 changes: 2 additions & 1 deletion src/actions.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ def run_action(options: Options) -> list:
branches = github.get_deletable_branches(
last_commit_age_days=options.last_commit_age_days,
ignore_branches=options.ignore_branches,
allowed_prefixes=options.allowed_prefixes
allowed_prefixes=options.allowed_prefixes,
branch_limit=options.branch_limit
)

print(f"Branches queued for deletion: {branches}")
Expand Down
10 changes: 9 additions & 1 deletion src/github.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,12 @@ def get_deletable_branches(
self,
last_commit_age_days: int,
ignore_branches: list[str],
allowed_prefixes: list[str]
allowed_prefixes: list[str],
branch_limit: int
) -> list[str]:
if branch_limit < 1:
return []

# Default branch might not be protected
default_branch = self.get_default_branch()

Expand Down Expand Up @@ -91,6 +95,10 @@ def get_deletable_branches(
print(f'Branch `{branch_name}` meets the criteria for deletion')
deletable_branches.append(branch_name)

# Exit early if we have reached our branch limit
if len(deletable_branches) == branch_limit:
return deletable_branches

# Re-request next page
current_page += 1

Expand Down
14 changes: 12 additions & 2 deletions src/io.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,9 @@ def __init__(
allowed_prefixes: list[str],
github_token: str,
github_repo: str,
branch_limit: int
dry_run: bool = True,
github_base_url: str = DEFAULT_GITHUB_API_URL
github_base_url: str = DEFAULT_GITHUB_API_URL,
):
self.ignore_branches = ignore_branches
self.last_commit_age_days = last_commit_age_days
Expand All @@ -22,6 +23,7 @@ def __init__(
self.github_repo = github_repo
self.dry_run = dry_run
self.github_base_url = github_base_url
self.branch_limit = branch_limit


class InputParser:
Expand Down Expand Up @@ -58,6 +60,13 @@ def get_args() -> argparse.Namespace:
help="Whether to delete branches at all. Defaults to 'yes'. Possible values: yes, no (case sensitive)"
)

parser.add_argument(
"--branch-limit",
help="The max number of branches that can be deleted",
default=100,
type=int,
)

return parser.parse_args()

def parse_input(self) -> Options:
Expand All @@ -83,7 +92,8 @@ def parse_input(self) -> Options:
dry_run=dry_run,
github_token=args.github_token,
github_repo=getenv('GITHUB_REPOSITORY'),
github_base_url=args.github_base_url
github_base_url=args.github_base_url,
branch_limit=args.branch_limit
)


Expand Down

0 comments on commit a4096f6

Please sign in to comment.