forked from linuxdeepin/dtk
-
Notifications
You must be signed in to change notification settings - Fork 0
114 lines (108 loc) · 4.46 KB
/
synchronize-to-dtk6.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
name: synchronize to dtk6
on:
workflow_call:
inputs:
dest_repo:
type: string
required: true
source_repo:
type: string
required: true
source_repo:
type: string
required: true
source_ref:
type: string
required: true
pull_number:
type: number
required: true
secrets:
CI_ROBOT_PAT:
required: true
env:
GH_TOKEN: ${{ secrets.CI_ROBOT_PAT }}
jobs:
sync-pull-request:
runs-on: ubuntu-latest
steps:
- name: Checkout source repository ${{ inputs.source_repo }}
- name: Checkout source repository ${{ inputs.source_repo }}
uses: actions/checkout@v3
with:
token: ${{ env.GH_TOKEN }}
token: ${{ env.GH_TOKEN }}
ref: ${{ inputs.source_ref }}
path: 'source'
repository: ${{ inputs.source_repo }}
repository: ${{ inputs.source_repo }}
fetch-depth: 0
- name: Checkout dest repository ${{ inputs.dest_repo }}
uses: actions/checkout@v3
with:
token: ${{ env.GH_TOKEN }}
token: ${{ env.GH_TOKEN }}
ref: 'master'
path: 'dest'
repository: ${{ inputs.dest_repo }}
- name: Synchronize files to ${{ inputs.dest_repo }}
id: rsync
run: |
git config --global user.name "deepin-ci-robot"
git config --global user.email "[email protected]"
tbranch="sync-${{ inputs.pull_number }}"
set -x
cd ${{ github.workspace }}/dest
git checkout -B ${tbranch}
git checkout -B ${tbranch}
cd ${{ github.workspace }}/source
git remote add upstream ${{ github.event.repository.clone_url }}
git fetch --all
git rebase upstream/master
if [[ -f ${{ github.workspace }}/source/.syncexclude ]]; then
rsync -avzp --delete --exclude=.git --exclude=.github --exclude=.obs --exclude=debian --exclude=archlinux --exclude=rpm --exclude-from=.syncexclude ${{ github.workspace }}/source/ ${{ github.workspace }}/dest/
rsync -avzp --delete --exclude=.git --exclude=.github --exclude=.obs --exclude=debian --exclude=archlinux --exclude=rpm --exclude-from=.syncexclude ${{ github.workspace }}/source/ ${{ github.workspace }}/dest/
else
rsync -avzp --delete --exclude=.git --exclude=.github --exclude=.obs --exclude=debian --exclude=archlinux --exclude=rpm ${{ github.workspace }}/source/ ${{ github.workspace }}/dest/
rsync -avzp --delete --exclude=.git --exclude=.github --exclude=.obs --exclude=debian --exclude=archlinux --exclude=rpm ${{ github.workspace }}/source/ ${{ github.workspace }}/dest/
fi
cd ${{ github.workspace }}/dest
difference=$(git diff)
echo "tbranch=${tbranch}" >> $GITHUB_OUTPUT
if [[ ! -z ${difference} ]]; then
echo "has_diff=true" >> $GITHUB_OUTPUT
else
echo "has_diff=false" >> $GITHUB_OUTPUT
fi
- name: Commit changes to ${{ inputs.dest_repo }}
if: steps.rsync.outputs.has_diff
run: |
tbranch=${{ steps.rsync.outputs.tbranch }}
cd ${{ github.workspace }}/dest
difference=$(git diff)
echo "tbranch=${tbranch}" >> $GITHUB_OUTPUT
if [[ ! -z ${difference} ]]; then
echo "has_diff=true" >> $GITHUB_OUTPUT
else
echo "has_diff=false" >> $GITHUB_OUTPUT
fi
- name: Commit changes to ${{ inputs.dest_repo }}
if: steps.rsync.outputs.has_diff
run: |
tbranch=${{ steps.rsync.outputs.tbranch }}
cd ${{ github.workspace }}/dest
git add :/
git commit \
-m "sync: from ${{ github.repository }}" \
-m "Synchronize source files from ${{ github.repository }}." \
-m "Source-pull-request: https://github.com/${{ github.repository }}/pull/${{ inputs.pull_number }}"
git push -u -f origin ${tbranch}
-m "Source-pull-request: https://github.com/${{ github.repository }}/pull/${{ inputs.pull_number }}"
git push -u -f origin ${tbranch}
cd ${{ github.workspace }}/dest
gh repo set-default ${{ inputs.dest_repo }}
result=$(gh pr list --base master --head ${tbranch} --state open)
if [[ -z $result ]]; then
gh pr create -B master -H ${tbranch} --fill
gh pr create -B master -H ${tbranch} --fill
fi