如何使用 GitHub API 进行快进合并?

How can I do a fast-forward merge using the GitHub API?

我正在设置 Jenkins 管道脚本并使用 API 调用 GitHub 以在测试通过后执行合并和发布。

对于我预期的工作流程,我需要使用 Jenkinsfile 将我的 release-candidate 分支合并到我的 beta-release 分支中。这种合并应该始终是快进合并,因为这是工作进入 beta-release 分支的唯一途径。不创建合并提交很重要,因为我检查了该分支中最新提交的 GitHub 状态,以查看测试是否是最新的。

我尝试了 merge API call,但它总是创建一个合并提交。

我尝试创建一个 PR 然后将其与 rebase 策略合并,但这也创建了一个合并提交。

是否可以使用 GitHub API 执行快进合并?

您实际上可以执行引用更新而不是合并。

status=$(curl --write-out %{http_code} -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_TOKEN}" -X PATCH https://api.github.com/repos/:owner/${REPO}/git/refs/heads/${BASE} \
-d '{  "sha": $(curl -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_TOKEN}" -X GET https://api.github.com/repos/:owner/${REPO}/git/refs/heads/${HEAD} | jq .object.sha ),  "force": false  }')
# In case of non-fast-forward case create a pull request
if (( $status != 200 )); then 
   curl -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_TOKEN}" -X POST https://api.github.com/repos/:owner/${REPO}/pulls \
   -d '{  "title": "Great pull request", "body": "Please check this non-fast-forward merge", "head": "${HEAD}",  "base": "${BASE}"  }'
fi;
params:
  REPO, BASE, HEAD, GITHUB_TOKEN