forked from NethermindEth/juno
-
Notifications
You must be signed in to change notification settings - Fork 0
87 lines (72 loc) · 2.72 KB
/
sync.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
on:
schedule:
# 1:05 past midnight UTC
- cron: "5 1 * * *"
push:
branches:
- "main"
name: "Sync with upstream"
jobs:
sync:
name: "Sync"
runs-on: "ubuntu-latest"
env:
DEFAULT_BRANCH: "main"
steps:
# https://github.com/actions/runner-images/issues/2840#issuecomment-790492173
- name: "Free up disk space"
run: |
sudo rm -rf /usr/share/dotnet
sudo rm -rf /opt/ghc
sudo rm -rf "/usr/local/share/boost"
sudo rm -rf "$AGENT_TOOLSDIRECTORY"
- name: "Checkout source code"
uses: "actions/checkout@v3"
with:
# Subsequent actions are not triggered unless using PAT
token: "${{ secrets.GH_PAT }}"
fetch-depth: 0
submodules: true
- name: "Setup Rust toolchain"
uses: "actions-rs/toolchain@v1"
with:
toolchain: "stable"
profile: "minimal"
- name: "Setup Golang toolchain"
uses: "actions/setup-go@v4"
with:
go-version: "1.21"
- name: "Config Git"
run: |
git config user.name "Jonathan LEI"
git config user.email "me@xjonathan.dev"
- name: "Update branch"
run: |
git fetch origin
git remote add upstream https://github.com/NethermindEth/juno
git fetch upstream --no-tags
MERGE_BASE=$(git merge-base origin/$DEFAULT_BRANCH upstream/$DEFAULT_BRANCH)
# Don't force push unnecessarily unless changes are detected
if [[ $(git rev-list $MERGE_BASE..upstream/$DEFAULT_BRANCH | wc -l) -ne 0 ]]; then
# Brings files from `home` to default branch
git checkout $DEFAULT_BRANCH
git reset --hard upstream/$DEFAULT_BRANCH
git checkout origin/home .
# Remove unwanted workflows
rm ./.github/workflows/docker-image-build-push.yml
rm ./.github/workflows/build-and-deploy.yml
rm ./.github/workflows/sync_first_100_blocks_smoke_test.yml
git add .
git commit -m "chore: README and CI changes"
# Here, we pick commits on the default branch except the first one. We do this instead
# of a naive rebase because the `home` branch might have changed, causing merge
# conflicts.
COMMIT_COUNT=$(git rev-list $MERGE_BASE..origin/$DEFAULT_BRANCH | wc -l)
git cherry-pick origin/$DEFAULT_BRANCH~$(($COMMIT_COUNT-1))..origin/$DEFAULT_BRANCH
# Makes sure the updated local branch builds
make juno
# Push updated branch
git push --force-with-lease
else
echo "No changes detected on upstream $DEFAULT_BRANCH"
fi