aboutsummaryrefslogtreecommitdiffstats
path: root/.github/workflows/sync_cmakebuild.yml
blob: d1ccd4991723c2621e45b4c29a1dd81c1f76b424 (plain) (blame)
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
name: Sync cmakebuild with main
on:
  schedule:
    - cron: "0 * * * *"
  workflow_dispatch:
concurrency:
  group: ${{ github.workflow }}
  cancel-in-progress: true
env:
  REPO: ${{ github.repository }}
  TOKEN: ${{ secrets.GH_PERSONAL_ACCESS_TOKEN }}
jobs:
  sync:
    runs-on: ubuntu-latest
    steps:
    - name: Sync
      run: |
        mainsha=$(curl -s -H "Accept: application/vnd.github.VERSION.sha" https://api.github.com/repos/$REPO/commits/main)
        echo "Main sha: ${mainsha}"
        lastsha=$(curl -s https://raw.githubusercontent.com/$REPO/cmakebuild/ydb/ci/cmakegen.txt)
        echo "Last sha: ${lastsha}"
        if [ "${mainsha}" == "${lastsha}" ];then
          echo "No new commits on the main branch to merge, exiting"
          exit 0
        fi
        git clone -b main --shallow-exclude cmakebuild https://$TOKEN@github.com/$REPO.git ydb
        git config --global user.email "alex@ydb.tech"
        git config --global user.name "Alexander Smirnov"
        cd ydb
        git fetch --depth `expr $(git rev-list --count HEAD) + 1`
        git fetch origin cmakebuild:cmakebuild --depth 3 # 1st with cmake generation, 2nd with previous merge, 3rd is common between main and cmakebuild
        mainsha=$(git rev-parse HEAD)
        git checkout cmakebuild
        prevsha=$(git rev-parse HEAD)
        git merge main --no-edit
        currsha=$(git rev-parse HEAD)
        if [ ${prevsha} == ${currsha} ];then
          echo "Merge did not bring any changes, exiting"
          exit
        fi
        ./generate_cmake -k
        echo ${mainsha} > ydb/ci/cmakegen.txt
        git add .
        git commit -m "Generate cmake for ${mainsha}"
        git push --set-upstream origin cmakebuild