mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-25 17:11:12 +00:00 
			
		
		
		
	# What does this PR do?
<!-- Provide a short summary of what this PR does and why. Link to
relevant issues if applicable. -->
fix: Improve pre-commit workflow error handling and feedback
- Add explicit step to check pre-commit results and provide clear error
messages
- Improve verification steps with better error messages and file
listings
- Use GitHub Actions annotations (::error:: and :⚠️:) for better
visibility
- Maintain continue-on-error for pre-commit step but add proper failure
handling
This addresses the issue where pre-commit failures were silent but still
caused workflow failures later, making it difficult to understand what
needed to be fixed.
<!-- If resolving an issue, uncomment and update the line below -->
<!-- Closes #[issue-number] -->
## Test Plan
<!-- Describe the tests you ran to verify your changes with result
summaries. *Provide clear instructions so the plan can be easily
re-executed.* -->
Signed-off-by: Akram Ben Aissi <akram.benaissi@gmail.com>
		
	
			
		
			
				
	
	
		
			111 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| name: Pre-commit
 | |
| 
 | |
| run-name: Run pre-commit checks
 | |
| 
 | |
| on:
 | |
|   pull_request:
 | |
|   push:
 | |
|     branches: [main]
 | |
| 
 | |
| concurrency:
 | |
|   group: ${{ github.workflow }}-${{ github.ref == 'refs/heads/main' && github.run_id || github.ref }}
 | |
|   cancel-in-progress: true
 | |
| 
 | |
| jobs:
 | |
|   pre-commit:
 | |
|     runs-on: ubuntu-latest
 | |
|     permissions:
 | |
|       contents: write
 | |
|       pull-requests: write
 | |
| 
 | |
|     steps:
 | |
|       - name: Checkout code
 | |
|         uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
 | |
|         with:
 | |
|           # For dependabot PRs, we need to checkout with a token that can push changes
 | |
|           token: ${{ github.actor == 'dependabot[bot]' && secrets.GITHUB_TOKEN || github.token }}
 | |
|           # Fetch full history for dependabot PRs to allow commits
 | |
|           fetch-depth: ${{ github.actor == 'dependabot[bot]' && 0 || 1 }}
 | |
| 
 | |
|       - name: Set up Python
 | |
|         uses: actions/setup-python@e797f83bcb11b83ae66e0230d6156d7c80228e7c # v6.0.0
 | |
|         with:
 | |
|           python-version: '3.12'
 | |
|           cache: pip
 | |
|           cache-dependency-path: |
 | |
|             **/requirements*.txt
 | |
|             .pre-commit-config.yaml
 | |
| 
 | |
|       - name: Set up Node.js
 | |
|         uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0
 | |
|         with:
 | |
|           node-version: '20'
 | |
|           cache: 'npm'
 | |
|           cache-dependency-path: 'llama_stack/ui/'
 | |
| 
 | |
|       - name: Install npm dependencies
 | |
|         run: npm ci
 | |
|         working-directory: llama_stack/ui
 | |
| 
 | |
|       - name: Run pre-commit
 | |
|         id: precommit
 | |
|         uses: pre-commit/action@2c7b3805fd2a0fd8c1884dcaebf91fc102a13ecd # v3.0.1
 | |
|         continue-on-error: true
 | |
|         env:
 | |
|           SKIP: no-commit-to-branch
 | |
|           RUFF_OUTPUT_FORMAT: github
 | |
| 
 | |
|       - name: Check pre-commit results
 | |
|         if: steps.precommit.outcome == 'failure'
 | |
|         run: |
 | |
|           echo "::error::Pre-commit hooks failed. Please run 'pre-commit run --all-files' locally and commit the fixes."
 | |
|           echo "::warning::Some pre-commit hooks failed. Check the output above for details."
 | |
|           exit 1
 | |
| 
 | |
|       - name: Debug
 | |
|         run: |
 | |
|           echo "github.ref: ${{ github.ref }}"
 | |
|           echo "github.actor: ${{ github.actor }}"
 | |
| 
 | |
|       - name: Commit changes for dependabot PRs
 | |
|         if: github.actor == 'dependabot[bot]'
 | |
|         run: |
 | |
|           if ! git diff --exit-code || [ -n "$(git ls-files --others --exclude-standard)" ]; then
 | |
|             git config --local user.email "github-actions[bot]@users.noreply.github.com"
 | |
|             git config --local user.name "github-actions[bot]"
 | |
| 
 | |
|             # Ensure we're on the correct branch
 | |
|             git checkout -B ${{ github.head_ref }}
 | |
|             git add -A
 | |
|             git commit -m "Apply pre-commit fixes"
 | |
| 
 | |
|             # Pull latest changes from the PR branch and rebase our commit on top
 | |
|             git pull --rebase origin ${{ github.head_ref }}
 | |
| 
 | |
|             # Push to the PR branch
 | |
|             git push origin ${{ github.head_ref }}
 | |
|             echo "Pre-commit fixes committed and pushed"
 | |
|           else
 | |
|             echo "No changes to commit"
 | |
|           fi
 | |
| 
 | |
|       - name: Verify no uncommitted changes
 | |
|         if: github.actor != 'dependabot[bot]'
 | |
|         run: |
 | |
|           if ! git diff --exit-code; then
 | |
|             echo "::error::There are uncommitted changes after pre-commit. Please run 'pre-commit run --all-files' locally and commit the fixes."
 | |
|             echo "::warning::Files with changes:"
 | |
|             git diff --name-status
 | |
|             exit 1
 | |
|           fi
 | |
| 
 | |
|       - name: Verify if there are any new files after pre-commit
 | |
|         if: github.actor != 'dependabot[bot]'
 | |
|         run: |
 | |
|           unstaged_files=$(git ls-files --others --exclude-standard)
 | |
|           if [ -n "$unstaged_files" ]; then
 | |
|             echo "::error::There are new untracked files after pre-commit. Please run 'pre-commit run --all-files' locally and commit the fixes."
 | |
|             echo "::warning::New files:"
 | |
|             echo "$unstaged_files"
 | |
|             exit 1
 | |
|           fi
 |