From 2d9f3e34ddce2d3323b1e7ea69d1cbe9d2e140dc Mon Sep 17 00:00:00 2001 From: Ben Kochie Date: Mon, 15 Mar 2021 23:59:27 +0100 Subject: [PATCH] Improve sync_repo_files.sh * Add github_api function to make curl use consistent. * Fix up some shellcheck warnings. * Add some more output debugging to detect failed pushes. * Fix git push auth string. * Fix open PR pre-check. Signed-off-by: Ben Kochie --- scripts/sync_repo_files.sh | 62 +++++++++++++++++++++++--------------- 1 file changed, 38 insertions(+), 24 deletions(-) diff --git a/scripts/sync_repo_files.sh b/scripts/sync_repo_files.sh index c1b39d9a2..3af2e2b57 100755 --- a/scripts/sync_repo_files.sh +++ b/scripts/sync_repo_files.sh @@ -30,35 +30,41 @@ source_dir="$(pwd)" tmp_dir="$(mktemp -d)" trap 'rm -rf "${tmp_dir}"' EXIT -get_default_branch(){ - local url="https://api.github.com/repos/${1}" - curl --retry 5 --silent -u "${git_user}:${GITHUB_TOKEN}" "${url}" 2>/dev/null | jq -r .default_branch +github_api() { + local url + url="https://api.github.com/${1}" + shift 1 + curl --retry 5 --silent --fail -u "${git_user}:${GITHUB_TOKEN}" "${url}" "$@" +} + +get_default_branch() { + github_api "repos/${1}" 2> /dev/null | + jq -r .default_branch } fetch_repos() { - local url="https://api.github.com/users/${1}/repos?per_page=100" - curl --retry 5 --silent -u "${git_user}:${GITHUB_TOKEN}" "${url}" 2>/dev/null | + github_api "users/${1}/repos?per_page=100" 2> /dev/null | jq -r '.[] | select( .name != "prometheus" ) | .name' } push_branch() { + local git_url + git_url="https://${git_user}:${GITHUB_TOKEN}@github.com/${1}" # stdout and stderr are redirected to /dev/null otherwise git-push could leak # the token in the logs. # Delete the remote branch in case it was merged but not deleted. - git push --quiet "https://${git_user}:${GITHUB_TOKEN}:@github.com/${1}" \ - ":${branch}" 1>/dev/null 2>&1 - git push --quiet \ - "https://${git_user}:${GITHUB_TOKEN}:@github.com/${1}" \ - --set-upstream "${branch}" 1>/dev/null 2>&1 + git push --quiet "${git_url}" ":${branch}" 1>/dev/null 2>&1 + git push --quiet "${git_url}" --set-upstream "${branch}" 1>/dev/null 2>&1 } post_pull_request() { - post_template='{"title":"%s","base":"%s","head":"%s","body":"%s"}' - post_json="$(printf "${post_template}" "${pr_title}" "${2}" "${branch}" "${pr_msg}")" - curl --show-error --silent --fail \ - -u "${git_user}:${GITHUB_TOKEN}" \ - -d "${post_json}" \ - "https://api.github.com/repos/${1}/pulls" + local repo="$1" + local default_branch="$2" + local post_json + post_json="$(printf '{"title":"%s","base":"%s","head":"%s","body":"%s"}' "${pr_title}" "${default_branch}" "${branch}" "${pr_msg}")" + echo "Posting PR to ${default_branch} on ${repo}" + github_api "repos/${repo}/pulls" --data "${post_json}" --show-error | + jq -r '"PR URL " + .html_url' } check_license() { @@ -67,14 +73,17 @@ check_license() { } process_repo() { - local org_repo="$1" + local org_repo + local default_branch + org_repo="$1" echo -e "\e[32mAnalyzing '${org_repo}'\e[0m" - default_branch="$(get_default_branch ${1})" + default_branch="$(get_default_branch "${org_repo}")" if [[ -z "${default_branch}" ]]; then echo "Can't get the default branch." return fi + echo "Default branch: ${default_branch}" local needs_update=() for source_file in ${SYNC_FILES}; do @@ -100,6 +109,7 @@ process_repo() { echo "${source_file} is already in sync." continue fi + echo "${source_file} needs updating." needs_update+=("${source_file}") done @@ -114,17 +124,22 @@ process_repo() { git checkout -b "${branch}" || return 1 # Update the files in target repo by one from prometheus/prometheus. - for source_file in ${needs_update[@]}; do + for source_file in "${needs_update[@]}"; do cp -f "${source_dir}/${source_file}" "./${source_file}" done - if [ -n "$(git status --porcelain)" ]; then + if [[ -n "$(git status --porcelain)" ]]; then git config user.email "${git_mail}" git config user.name "${git_user}" git add . git commit -s -m "${commit_msg}" if push_branch "${org_repo}"; then - post_pull_request "${org_repo}" "${default_branch}" + if ! post_pull_request "${org_repo}" "${default_branch}"; then + return 1 + fi + else + echo "Pushing ${branch} to ${org_repo} failed" + return 1 fi fi } @@ -136,9 +151,8 @@ for org in ${orgs}; do # currently. fetch_repos "${org}" | while read -r repo; do # Check if a PR is already opened for the branch. - prLink=$(curl --show-error --silent \ - -u "${git_user}:${GITHUB_TOKEN}" \ - "https://api.github.com/repos/${org}/${repo}/pulls?head=${repo}:${branch}" | jq '.[0].url') + fetch_uri="repos/${org}/${repo}/pulls?state=open&head=${org}:${branch}" + prLink="$(github_api "${fetch_uri}" --show-error | jq -r '.[0].html_url')" if [[ "${prLink}" != "null" ]]; then echo "Pull request already opened for branch '${branch}': ${prLink}" echo "Either close it or merge it before running this script again!"