Skip to content

Commit 56ec2a3

Browse files
committed
feat: add sync-dev-to-main workflow
1 parent ed0ffd2 commit 56ec2a3

File tree

1 file changed

+83
-0
lines changed

1 file changed

+83
-0
lines changed
Lines changed: 83 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,83 @@
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

Comments
 (0)