Compare commits
No commits in common. "main" and "v1.6" have entirely different histories.
1 changed files with 2 additions and 98 deletions
100
.github/workflows/repo-pipeline.yml
vendored
100
.github/workflows/repo-pipeline.yml
vendored
|
|
@ -173,7 +173,6 @@ jobs:
|
||||||
|
|
||||||
- name: Dependency Review
|
- name: Dependency Review
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
if: ${{ github.event_name == 'pull_request' }}
|
||||||
continue-on-error: true
|
|
||||||
uses: actions/dependency-review-action@v4
|
uses: actions/dependency-review-action@v4
|
||||||
|
|
||||||
ai-review:
|
ai-review:
|
||||||
|
|
@ -182,104 +181,9 @@ jobs:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
permissions:
|
permissions:
|
||||||
contents: read
|
contents: read
|
||||||
pull-requests: write
|
pull-requests: read
|
||||||
issues: write
|
issues: read
|
||||||
steps:
|
steps:
|
||||||
# Claude review is performed locally by Claude Code before the PR is merged.
|
|
||||||
# See CLAUDE.md in the repository for the process.
|
|
||||||
|
|
||||||
- name: Generate ChatGPT review
|
|
||||||
env:
|
|
||||||
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}
|
|
||||||
GITHUB_TOKEN: ${{ github.token }}
|
|
||||||
PR_NUMBER: ${{ github.event.pull_request.number }}
|
|
||||||
REPO: ${{ github.repository }}
|
|
||||||
PR_TITLE: ${{ github.event.pull_request.title }}
|
|
||||||
run: |
|
|
||||||
set -euo pipefail
|
|
||||||
if [ -z "${OPENAI_API_KEY:-}" ]; then
|
|
||||||
echo "::notice::OPENAI_API_KEY not set – ChatGPT review skipped"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
python3 << 'PYEOF'
|
|
||||||
import os, json, urllib.request
|
|
||||||
|
|
||||||
token = os.environ["GITHUB_TOKEN"]
|
|
||||||
repo = os.environ["REPO"]
|
|
||||||
pr_num = os.environ["PR_NUMBER"]
|
|
||||||
headers_gh = {"Authorization": f"Bearer {token}", "User-Agent": "vanity-dev-engine",
|
|
||||||
"Accept": "application/vnd.github.v3+json"}
|
|
||||||
|
|
||||||
# Skip if ChatGPT review already exists
|
|
||||||
req = urllib.request.Request(
|
|
||||||
f"https://api.github.com/repos/{repo}/issues/{pr_num}/comments?per_page=100",
|
|
||||||
headers=headers_gh)
|
|
||||||
with urllib.request.urlopen(req) as r:
|
|
||||||
comments = json.loads(r.read())
|
|
||||||
if any("### ChatGPT" in (c.get("body") or "") for c in comments):
|
|
||||||
print("ChatGPT review already present – skipping generation.")
|
|
||||||
raise SystemExit(0)
|
|
||||||
|
|
||||||
# Fetch PR diff
|
|
||||||
req_diff = urllib.request.Request(
|
|
||||||
f"https://api.github.com/repos/{repo}/pulls/{pr_num}",
|
|
||||||
headers={**headers_gh, "Accept": "application/vnd.github.v3.diff"})
|
|
||||||
with urllib.request.urlopen(req_diff) as r:
|
|
||||||
diff = r.read().decode("utf-8", errors="replace")[:12000]
|
|
||||||
|
|
||||||
# Fetch PR body
|
|
||||||
req_pr = urllib.request.Request(
|
|
||||||
f"https://api.github.com/repos/{repo}/pulls/{pr_num}", headers=headers_gh)
|
|
||||||
with urllib.request.urlopen(req_pr) as r:
|
|
||||||
pr_data = json.loads(r.read())
|
|
||||||
pr_body = (pr_data.get("body") or "")[:800]
|
|
||||||
|
|
||||||
prompt = f"""You are a senior iOS Swift developer reviewing a pull request.
|
|
||||||
Analyse the changes carefully and write a concise code review.
|
|
||||||
|
|
||||||
PR title: {os.environ["PR_TITLE"]}
|
|
||||||
PR description: {pr_body}
|
|
||||||
|
|
||||||
Git diff (may be truncated):
|
|
||||||
{diff}
|
|
||||||
|
|
||||||
Reply with EXACTLY this structure – no deviations:
|
|
||||||
|
|
||||||
### ChatGPT
|
|
||||||
|
|
||||||
DoD status: PASS
|
|
||||||
Blocker: 0
|
|
||||||
Major: 0
|
|
||||||
|
|
||||||
<your review here – cover code quality, correctness, Swift best practices,
|
|
||||||
potential bugs, and suggestions. Be specific and constructive.>
|
|
||||||
|
|
||||||
Only set DoD status to FAIL or raise Blocker/Major above 0 when you find
|
|
||||||
real defects that must be fixed before merging."""
|
|
||||||
|
|
||||||
payload = json.dumps({
|
|
||||||
"model": "gpt-4o",
|
|
||||||
"max_tokens": 1500,
|
|
||||||
"messages": [{"role": "user", "content": prompt}]
|
|
||||||
}).encode()
|
|
||||||
req_ai = urllib.request.Request(
|
|
||||||
"https://api.openai.com/v1/chat/completions", data=payload,
|
|
||||||
headers={"Authorization": f"Bearer {os.environ['OPENAI_API_KEY']}",
|
|
||||||
"content-type": "application/json"})
|
|
||||||
with urllib.request.urlopen(req_ai) as r:
|
|
||||||
review = json.loads(r.read())["choices"][0]["message"]["content"]
|
|
||||||
|
|
||||||
# Post comment
|
|
||||||
body_payload = json.dumps({"body": review}).encode()
|
|
||||||
req_post = urllib.request.Request(
|
|
||||||
f"https://api.github.com/repos/{repo}/issues/{pr_num}/comments",
|
|
||||||
data=body_payload,
|
|
||||||
headers={**headers_gh, "Content-Type": "application/json"})
|
|
||||||
with urllib.request.urlopen(req_post) as r:
|
|
||||||
result = json.loads(r.read())
|
|
||||||
print(f"ChatGPT review posted: {result['html_url']}")
|
|
||||||
PYEOF
|
|
||||||
|
|
||||||
- name: Validate ChatGPT and Claude review status
|
- name: Validate ChatGPT and Claude review status
|
||||||
uses: actions/github-script@v7
|
uses: actions/github-script@v7
|
||||||
with:
|
with:
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue