1+ name : Sync Dev to Main
2+
3+ on :
4+ # Manual trigger
5+ workflow_dispatch :
6+
7+ # Daily schedule at 2 AM UTC
8+ schedule :
9+ - cron : ' 0 2 * * *'
10+
11+ jobs :
12+ sync-branches :
13+ runs-on : ubuntu-latest
14+
15+ steps :
16+ - name : Checkout repository
17+ uses : actions/checkout@v4
18+ with :
19+ fetch-depth : 0
20+ token : ${{ secrets.GITHUB_TOKEN }}
21+
22+ - name : Configure Git
23+ run : |
24+ git config --global user.name "github-actions[bot]"
25+ git config --global user.email "github-actions[bot]@users.noreply.github.com"
26+
27+ - name : Check if dev branch exists
28+ id : check_dev
29+ run : |
30+ if git show-ref --verify --quiet refs/remotes/origin/dev; then
31+ echo "dev_exists=true" >> $GITHUB_OUTPUT
32+ else
33+ echo "dev_exists=false" >> $GITHUB_OUTPUT
34+ fi
35+
36+ - name : Exit if dev branch doesn't exist
37+ if : steps.check_dev.outputs.dev_exists == 'false'
38+ run : |
39+ echo "Dev branch does not exist. Skipping sync."
40+ exit 0
41+
42+ - name : Check for changes between dev and main
43+ id : check_changes
44+ run : |
45+ git fetch origin dev:dev
46+ git fetch origin main:main
47+
48+ # Check if there are any differences
49+ if git diff --quiet main dev; then
50+ echo "has_changes=false" >> $GITHUB_OUTPUT
51+ echo "No changes detected between dev and main"
52+ else
53+ echo "has_changes=true" >> $GITHUB_OUTPUT
54+ echo "Changes detected between dev and main"
55+ fi
56+
57+ - name : Exit if no changes
58+ if : steps.check_changes.outputs.has_changes == 'false'
59+ run : |
60+ echo "No changes to sync. Exiting."
61+ exit 0
62+
63+ - name : Attempt merge
64+ id : merge
65+ run : |
66+ git checkout main
67+ git pull origin main
68+
69+ # Try to merge dev into main
70+ if git merge origin/dev --no-edit; then
71+ echo "merge_success=true" >> $GITHUB_OUTPUT
72+ echo "Merge completed successfully"
73+ else
74+ echo "merge_success=false" >> $GITHUB_OUTPUT
75+ echo "Merge failed due to conflicts"
76+ git merge --abort
77+ fi
78+
79+ - name : Push changes if merge succeeded
80+ if : steps.merge.outputs.merge_success == 'true'
81+ run : |
82+ git push origin main
83+ echo "Successfully synced dev to main"
0 commit comments