Skip to content

auto merge upstream #39

auto merge upstream

auto merge upstream #39

name: auto merge upstream
on:
workflow_dispatch: # allows manual triggering
schedule:
- cron: "0 17 * * 5" # runs weekly on Saturday at 02:00 (JST)
permissions:
contents: write
pull-requests: write
jobs:
auto-merge-upstream:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: andstor/file-existence-action@v3
id: check_lockfile
with:
files: "lazy-lock.json"
- name: Merge upstream
id: merge-upstream
continue-on-error: true
run: |
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
git config --global user.name "github-actions[bot]"
git remote add upstream https://github.com/ayamir/nvimdots.git
git fetch upstream
remote_update=$(git merge upstream/main --allow-unrelated-histories --no-commit --no-ff)
echo "remote_update=${remote_update}" >> $GITHUB_OUTPUT
- name: Fix conflict
id: fix-conflict
if: steps.merge-upstream.outputs.remote_update != 'Already up to date.'
run: |
git reset HEAD lazy-lock.json
git checkout lazy-lock.json
git commit --no-edit
- uses: rhysd/action-setup-vim@v1
if: steps.check_lockfile.outputs.files_exists == 'true'
with:
neovim: true
- name: Run lockfile-autoupdate
if: steps.check_lockfile.outputs.files_exists == 'true'
timeout-minutes: 5
run: |
cp ./scripts/install.sh ./scripts/install_my_repo.sh
sed -i -e "s/ayamir\/nvimdots/misumisumi\/nvimdots/g" ./scripts/install_my_repo.sh
./scripts/install_my_repo.sh
nvim --headless "+Lazy! update" +qa
cp -pv "${HOME}/.config/nvim/lazy-lock.json" .
curl -L https://raw.githubusercontent.com/ayamir/nvimdots/main/lazy-lock.json -o lazy-lock.upstream.json
# refer to the upstream lazy-lock.json and merge common plugins with priority given to the upstream version.
jq -s '
.[0] as $x
| .[1] as $y
| $x
| to_entries
| map(.key as $k
| if ($y | has($k)) then
{($k): $y[$k]}
else
{($k): .value}
end)
| add' lazy-lock.json lazy-lock.upstream.json > lazy-lock.tmp.json
mv lazy-lock.tmp.json lazy-lock.json
rm lazy-lock.upstream.json
- uses: stefanzweifel/git-auto-commit-action@v5
if: steps.check_lockfile.outputs.files_exists == 'true' || contains(fromJSON('["success", "skipped"]'), steps.fix-conflict.outcome)
with:
file_pattern: "lazy-lock.json"
commit_message: "chore: auto merge upstream and update lazy-lock.json"
commit_user_name: "github-actions[bot]"
commit_user_email: "41898282+github-actions[bot]@users.noreply.github.com"
commit_author: "github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>"