-
Notifications
You must be signed in to change notification settings - Fork 44.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ci(all): take two on the global status checker (#7849)
* ci(all): fundamentally change how we do this * Update workflow-checker.yml * ci: dupe and move file in attempt to figure out why its not accessible * Update workflow-checker.yml * fix: sleep before checking, move files, improve code * Update workflow-checker.yml * Update check_actions_status.py * Update check_actions_status.py * Update workflow-checker.yml * Update workflow-checker.yml * ci: remove debug, add more * Update check_actions_status.py * Update check_actions_status.py * Update check_actions_status.py * Revert "Update check_actions_status.py" This reverts commit 3613452. * Revert "Update check_actions_status.py" This reverts commit 828aabf. * Update check_actions_status.py * Update check_actions_status.py * Update check_actions_status.py * Update check_actions_status.py
- Loading branch information
Showing
3 changed files
with
145 additions
and
99 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,51 +1,43 @@ | ||
name: PR Status Checker | ||
on: | ||
workflow_run: | ||
workflows: ["*"] | ||
types: | ||
- completed | ||
pull_request: | ||
types: [opened, synchronize, reopened] | ||
|
||
jobs: | ||
status-check: | ||
name: Check Actions Status | ||
name: Check PR Status | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Set up Python | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version: "3.10" | ||
- name: Install dependencies | ||
run: | | ||
python -m pip install --upgrade pip | ||
pip install requests | ||
- name: Debug Information | ||
run: | | ||
echo "Event name: ${{ github.event_name }}" | ||
echo "Workflow: ${{ github.workflow }}" | ||
echo "Action: ${{ github.action }}" | ||
echo "Actor: ${{ github.actor }}" | ||
echo "Repository: ${{ github.repository }}" | ||
echo "Ref: ${{ github.ref }}" | ||
echo "Head ref: ${{ github.head_ref }}" | ||
echo "Base ref: ${{ github.base_ref }}" | ||
echo "Event payload:" | ||
cat $GITHUB_EVENT_PATH | ||
- name: Debug File Structure | ||
run: | | ||
echo "Current directory:" | ||
pwd | ||
echo "Directory contents:" | ||
ls -R | ||
echo "GitHub workspace:" | ||
echo $GITHUB_WORKSPACE | ||
echo "GitHub workspace contents:" | ||
ls -R $GITHUB_WORKSPACE | ||
- name: Check Actions Status | ||
run: | | ||
echo "Current directory before running Python script:" | ||
pwd | ||
echo "Attempting to run Python script:" | ||
python .github/scripts/check_actions_status.py | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
# - name: Wait some time for all actions to start | ||
# run: sleep 30 | ||
- uses: actions/checkout@v4 | ||
# with: | ||
# fetch-depth: 0 | ||
- name: Set up Python | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version: "3.10" | ||
- name: Install dependencies | ||
run: | | ||
python -m pip install --upgrade pip | ||
pip install requests | ||
- name: Debug Information | ||
run: | | ||
echo "Event name: ${{ github.event_name }}" | ||
echo "Workflow: ${{ github.workflow }}" | ||
echo "Action: ${{ github.action }}" | ||
echo "Actor: ${{ github.actor }}" | ||
echo "Repository: ${{ github.repository }}" | ||
echo "Ref: ${{ github.ref }}" | ||
echo "Head ref: ${{ github.head_ref }}" | ||
echo "Base ref: ${{ github.base_ref }}" | ||
echo "Event payload:" | ||
cat $GITHUB_EVENT_PATH | ||
- name: Check PR Status | ||
run: | | ||
echo "Current directory before running Python script:" | ||
pwd | ||
echo "Attempting to run Python script:" | ||
python check_actions_status.py | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
import json | ||
import os | ||
import requests | ||
import sys | ||
import time | ||
from typing import Dict, List, Tuple | ||
|
||
|
||
def get_environment_variables() -> Tuple[str, str, str, str, str]: | ||
"""Retrieve and return necessary environment variables.""" | ||
try: | ||
with open(os.environ["GITHUB_EVENT_PATH"]) as f: | ||
event = json.load(f) | ||
|
||
sha = event["pull_request"]["head"]["sha"] | ||
|
||
return ( | ||
os.environ["GITHUB_API_URL"], | ||
os.environ["GITHUB_REPOSITORY"], | ||
sha, | ||
os.environ["GITHUB_TOKEN"], | ||
os.environ["GITHUB_RUN_ID"], | ||
) | ||
except KeyError as e: | ||
print(f"Error: Missing required environment variable or event data: {e}") | ||
sys.exit(1) | ||
|
||
|
||
def make_api_request(url: str, headers: Dict[str, str]) -> Dict: | ||
"""Make an API request and return the JSON response.""" | ||
try: | ||
print("Making API request to:", url) | ||
response = requests.get(url, headers=headers, timeout=10) | ||
response.raise_for_status() | ||
return response.json() | ||
except requests.RequestException as e: | ||
print(f"Error: API request failed. {e}") | ||
sys.exit(1) | ||
|
||
|
||
def process_check_runs(check_runs: List[Dict]) -> Tuple[bool, bool]: | ||
"""Process check runs and return their status.""" | ||
runs_in_progress = False | ||
all_others_passed = True | ||
|
||
for run in check_runs: | ||
if str(run["name"]) != "Check PR Status": | ||
status = run["status"] | ||
conclusion = run["conclusion"] | ||
|
||
if status == "completed": | ||
if conclusion not in ["success", "skipped", "neutral"]: | ||
all_others_passed = False | ||
print( | ||
f"Check run {run['name']} (ID: {run['id']}) has conclusion: {conclusion}" | ||
) | ||
else: | ||
runs_in_progress = True | ||
print(f"Check run {run['name']} (ID: {run['id']}) is still {status}.") | ||
all_others_passed = False | ||
else: | ||
print( | ||
f"Skipping check run {run['name']} (ID: {run['id']}) as it is the current run." | ||
) | ||
|
||
return runs_in_progress, all_others_passed | ||
|
||
|
||
def main(): | ||
api_url, repo, sha, github_token, current_run_id = get_environment_variables() | ||
|
||
endpoint = f"{api_url}/repos/{repo}/commits/{sha}/check-runs" | ||
headers = { | ||
"Accept": "application/vnd.github.v3+json", | ||
} | ||
if github_token: | ||
headers["Authorization"] = f"token {github_token}" | ||
|
||
print(f"Current run ID: {current_run_id}") | ||
|
||
while True: | ||
data = make_api_request(endpoint, headers) | ||
|
||
check_runs = data["check_runs"] | ||
|
||
print("Processing check runs...") | ||
|
||
print(check_runs) | ||
|
||
runs_in_progress, all_others_passed = process_check_runs(check_runs) | ||
|
||
if not runs_in_progress: | ||
break | ||
|
||
print( | ||
"Some check runs are still in progress. Waiting 3 minutes before checking again..." | ||
) | ||
time.sleep(180) | ||
|
||
if all_others_passed: | ||
print("All other completed check runs have passed. This check passes.") | ||
sys.exit(0) | ||
else: | ||
print("Some check runs have failed or have not completed. This check fails.") | ||
sys.exit(1) | ||
|
||
|
||
if __name__ == "__main__": | ||
main() |