home / skills / openclaw / skills / pr-review-loop
This skill automates PR review loops by reading Greptile feedback, applying fixes, pushing updates, and auto-merging when score reaches 4/5.
npx playbooks add skill openclaw/skills --skill pr-review-loopReview the files below or copy the command above to add this skill to your agents.
---
name: pr-review-loop
description: Autonomous PR review loop with Greptile. Use when an agent creates a PR and needs to autonomously handle code review feedback — reading Greptile reviews, fixing issues, pushing fixes, re-triggering review, and auto-merging when score is 4/5+. Trigger on commands like "pr review {url}", "review my PR", or when a Greptile review webhook/poll delivers feedback.
---
# PR Review Loop
Autonomous cycle: Greptile reviews PR → agent fixes feedback → pushes → re-triggers → repeats until score ≥ 4/5 or max rounds.
## Quick Start
When triggered with a PR URL or review payload:
```bash
# Run the review loop
bash scripts/pr-review-loop.sh <owner/repo> <pr-number>
```
Or invoke steps manually — see below.
## Workflow
### 1. Fetch Review
```bash
# Get latest Greptile review
gh api "/repos/{owner}/{repo}/pulls/{pr}/reviews" \
--jq '[.[] | select(.user.login == "greptile-apps[bot]")] | last'
# Get inline comments
gh api "/repos/{owner}/{repo}/pulls/{pr}/comments" \
--jq '[.[] | select(.user.login == "greptile-apps[bot]")]'
```
### 2. Parse Score
Look for confidence/quality score in review body. Greptile typically includes a score like `Score: X/5` or `Confidence: X/5`. Extract it:
- **Score ≥ 4/5** → auto-merge
- **Score < 4/5** → fix issues
- **No score found** → treat as needing fixes if there are comments, otherwise merge
### 3. Auto-Merge (score ≥ 4)
```bash
gh pr merge <number> --merge --delete-branch --repo <owner/repo>
```
### 4. Fix Issues (score < 4)
For each Greptile comment:
1. Read the file and line referenced
2. Understand the feedback
3. Apply the fix
4. Stage changes
Commit with a descriptive message listing each fix:
```
Address Greptile review feedback (round N)
- Fix X in path/to/file.ts
- Fix Y in path/to/other.ts
- Improve Z per reviewer suggestion
```
Push and re-trigger:
```bash
git push
gh pr comment <number> --repo <owner/repo> --body "@greptileai review"
```
### 5. Track State
Maintain `review-state.json` in workspace:
```json
{
"owner/repo#123": {
"rounds": 2,
"maxRounds": 5,
"lastScore": 3,
"sameScoreCount": 1
}
}
```
Update after each round. Check exit conditions:
- **rounds ≥ 5** → merge anyway, notify Master
- **sameScoreCount ≥ 2** (same score 2 rounds in a row) → merge anyway, notify Master
### 6. Escalation
- **Architectural decisions** (review mentions architecture, design patterns, breaking changes) → ping Master on Telegram, don't auto-fix
- **Max rounds reached** → merge + notify Master with summary
- **Unclear feedback** → ask Master
## Command Interface
Agents should respond to:
- `pr review <url>` — start review loop on a PR
- `pr review <owner/repo#number>` — same, by reference
- `pr status` — show active review loops and their state
## References
See `references/greptile-patterns.md` for common Greptile feedback patterns and fix strategies.
This skill implements an autonomous PR review loop that reads Greptile reviews, applies fixes, re-submits changes, and auto-merges when quality thresholds are met. It runs iteratively until the PR reaches an acceptable score or predefined exit conditions trigger escalation. Use it to automate back-and-forth review cycles so agents can complete PRs without manual intervention.
The skill fetches Greptile review bodies and inline comments, extracts a numeric score (e.g., "Score: X/5"), and decides whether to auto-merge or apply fixes. For low scores it reads referenced files/lines, makes targeted edits, commits and pushes changes, then re-triggers Greptile for another review. It tracks state per PR (rounds, last score, same-score streak) and escalates to a human when rules are met.
What if Greptile doesn't include a score?
If no score is found but comments exist, treat the review as needing fixes; if no comments exist, consider the PR mergeable and proceed with merge.
When does the skill escalate to a human?
Escalation happens for architectural/design feedback, unclear requests, max rounds reached, or repeated identical scores that indicate stagnation.