name: PR Review Automation on: pull_request: types: [opened, synchronize, reopened] jobs: review: runs-on: self-hosted container: image: ubuntu:22.04 steps: - name: Install dependencies run: | apt-get update && apt-get install -y \ git \ curl \ jq \ && rm -rf /var/lib/apt/lists/* - name: Checkout code uses: actions/checkout@v4 with: token: ${{ secrets.TFT_GITEA_TOKEN }} ref: ${{ github.head_ref }} - name: Get PR diff id: diff run: | git fetch origin ${{ github.base_ref }} git diff origin/${{ github.base_ref }}..HEAD > /tmp/pr_diff.txt echo "diff_size=$(wc -l < /tmp/pr_diff.txt)" >> $GITHUB_OUTPUT - name: Analyze with Ollama if: steps.diff.outputs.diff_size > '0' env: OLLAMA_URL: http://172.0.0.29:3000/ollama/v1 API_KEY: ${{ secrets.OLLAMA_API_KEY }} run: | DIFF_CONTENT=$(cat /tmp/pr_diff.txt) PROMPT="Analyze the following code changes for completion, completeness, correctness, security issues, and best practices. PR Title: ${{ github.event.pull_request.title }} Diff: $DIFF_CONTENT Provide review with: 1) Completion check, 2) Completeness check, 3) Bugs/errors, 4) Security issues, 5) Best practices. Then give specific comments with suggested fixes." RESPONSE=$(curl -s -X POST "$OLLAMA_URL/chat" \ -H "Authorization: Bearer $API_KEY" \ -H "Content-Type: application/json" \ -d "{\"model\":\"qwen3-coder-next:latest\",\"messages\":[{\"role\":\"user\",\"content\":\"$PROMPT\"}],\"stream\":false}") echo "$RESPONSE" > /tmp/ollama_response.json REVIEW=$(echo "$RESPONSE" | jq -r '.choices[0].message.content // empty') echo "$REVIEW" > /tmp/pr_review.txt - name: Post review comment if: success() env: TF_TOKEN: ${{ secrets.TFT_GITEA_TOKEN }} PR_NUMBER: ${{ github.event.pull_request.number }} run: | if [ -f "/tmp/pr_review.txt" ] && [ -s "/tmp/pr_review.txt" ]; then REVIEW_BODY=$(cat /tmp/pr_review.txt | head -c 65536) curl -s -X POST "http://172.0.0.29:3000/api/v1/repos/sarman/tftsr-devops_investigation/pulls/$PR_NUMBER/reviews" \ -H "Authorization: token $TF_TOKEN" \ -H "Content-Type: application/json" \ -d "{\"body\": \"🤖 Automated PR Review:\n\n$REVIEW_BODY\n\n---\n*this is an automated review from Ollama*\", \"event\": \"COMMENT\"}" fi