Skip to content

Commit

Permalink
Fix deploy workflow (take 2)
Browse files Browse the repository at this point in the history
Generate data after rebasing; only rebase when main has changed; force push. Fixes #1125.
  • Loading branch information
zcorpan committed Nov 21, 2024
1 parent b7d0aa3 commit 05ebcf2
Showing 1 changed file with 10 additions and 19 deletions.
29 changes: 10 additions & 19 deletions .github/workflows/build-and-deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -35,42 +35,33 @@ jobs:
python3 -m pip install --upgrade pip
pip install -r requirements.txt
- name: Generate Merged Data
run: |
python3 gh-data.py
python3 merge-data.py
- name: Switch to `gh-pages` and Preserve Changes
- name: Fetch and Check Out `gh-pages`
run: |
git config --global user.name "github-actions[bot]"
git config --global user.email "github-actions[bot]@users.noreply.github.com"
# Stash changes to preserve them
git stash --include-untracked
# Fetch and switch to `gh-pages`
git fetch origin gh-pages:gh-pages || git checkout --orphan gh-pages
git checkout gh-pages
# Rebase `gh-pages` onto `main` to ensure a linear history
- name: Rebase `gh-pages` onto `main` (if triggered by push to main)
if: github.event_name == 'push' && github.ref == 'refs/heads/main'
run: |
git rebase main
# Apply stashed changes
git stash pop || echo "No changes to apply."
- name: Generate Merged Data
run: |
python3 gh-data.py
python3 merge-data.py
- name: Commit and Push Updates
run: |
# Add changes
git add -f merged-data.json
git add .
# Commit changes if there are any
if git diff --cached --quiet; then
echo "No changes to commit."
else
git commit -m "Update GitHub Pages with latest data"
fi
git commit -m "Update GitHub Pages with latest data"
# Push changes back to `gh-pages`
git remote set-url origin [email protected]:${{ github.repository }}.git
git push origin gh-pages
git push origin gh-pages --force

0 comments on commit 05ebcf2

Please sign in to comment.