From 5c47607acb93fed5485fdbf7232e8a31425f672a Mon Sep 17 00:00:00 2001 From: Tom Hu <88201630+thomasrockhu-codecov@users.noreply.github.com> Date: Fri, 15 Nov 2024 10:27:07 -0500 Subject: [PATCH] fix: override commit and pr values for PR cases (#1657) * fix: override commit and pr values for PR cases * fix: remove unnecessary env vars * fix: add back in with env * fix: try no env * fix: do we need them at all? * fix: dollar curlies * fix: wrap github_env * fix: remove dollar curlies * fix: remove --- Makefile | 2 +- action.yml | 39 ++++++++++++++++++++++++++++----------- src/version | 2 +- 3 files changed, 30 insertions(+), 13 deletions(-) diff --git a/Makefile b/Makefile index a6bf4fd30..990840789 100644 --- a/Makefile +++ b/Makefile @@ -1,5 +1,5 @@ deploy: - $(eval VERSION := $(shell cat src/version | grep 'CODECOV_ACTION_VERSION=' | cut -d\" -f2)) + $(eval VERSION := $(shell cat src/version | grep 'CODECOV_ACTION_VERSION=' | cut -d\" -f2)) git tag -d v5 git push origin :v5 git tag v5 diff --git a/action.yml b/action.yml index a2959d073..36e11f2fa 100644 --- a/action.yml +++ b/action.yml @@ -166,41 +166,61 @@ runs: if [ ${{ inputs.use_oidc }} == 'true' ]; then # {"count":1984,"value":"***"} - CODECOV_TOKEN=$(curl -H "Authorization: bearer $ACTIONS_ID_TOKEN_REQUEST_TOKEN" "$ACTIONS_ID_TOKEN_REQUEST_URL&audience=api://AzureADTokenExchange" | cut -d\' -f6) - echo "CODECOV_TOKEN=$CODECOV_TOKEN" >> $GITHUB_ENV + CC_TOKEN=$(curl -H "Authorization: bearer $ACTIONS_ID_TOKEN_REQUEST_TOKEN" "$ACTIONS_ID_TOKEN_REQUEST_URL&audience=api://AzureADTokenExchange" | cut -d\' -f6) + echo "CC_TOKEN=$CC_TOKEN" >> "$GITHUB_ENV" else if [ -n ${{ inputs.token }} ]; then - CODECOV_TOKEN=${{ inputs.token }} - echo "CODECOV_TOKEN=$CODECOV_TOKEN" >> $GITHUB_ENV + CC_TOKEN=${{ inputs.token }} + echo "CC_TOKEN=$CC_TOKEN" >> "$GITHUB_ENV" fi fi - name: Override branch for forks shell: bash run: | - if [ -z "$CC_BRANCH" ] && [ -z "$CODECOV_TOKEN" ] && [ "${GITHUB_EVENT_PULL_REQUEST_REPO_FULL_NAME}" != "$GITHUB_REPOSITORY" ]; + if [ -z "$CC_BRANCH" ] && [ -z "$CC_TOKEN" ] && [ "${GITHUB_EVENT_PULL_REQUEST_REPO_FULL_NAME}" != "$GITHUB_REPOSITORY" ]; then echo -e "\033[0;32m==>\033[0m Fork detected, tokenless uploading used" TOKENLESS="$GITHUB_EVENT_PULL_REQUEST_HEAD_LABEL" CC_BRANCH="$GITHUB_EVENT_PULL_REQUEST_HEAD_LABEL" - echo "TOKENLESS=$TOKENLESS" >> $GITHUB_ENV + echo "TOKENLESS=$TOKENLESS" >> "$GITHUB_ENV" fi - echo "CC_BRANCH=$CC_BRANCH" >> $GITHUB_ENV + echo "CC_BRANCH=$CC_BRANCH" >> "$GITHUB_ENV" env: CC_BRANCH: ${{ inputs.override_branch }} GITHUB_EVENT_PULL_REQUEST_HEAD_LABEL: ${{ github.event.pull_request.head.label }} GITHUB_EVENT_PULL_REQUEST_REPO_FULL_NAME: ${{ github.event.pull_request.repo.full_name }} GITHUB_REPOSITORY: ${{ github.repository }} + - name: Override commits and pr for pull requests + shell: bash + run: | + if [ -z "$CC_SHA" ]; + then + CC_SHA="$GITHUB_EVENT_PULL_REQUEST_HEAD_SHA" + fi + if [ -z "$CC_PR" ] && [ "${GITHUB_EVENT_NAME}" == "pull_request_target" ]; + then + CC_PR="$GITHUB_EVENT_NUMBER" + fi + + echo "CC_SHA=$CC_SHA" >> "$GITHUB_ENV" + echo "CC_PR=$CC_PR" >> "$GITHUB_ENV" + env: + CC_PR: ${{ inputs.override_pr }} + CC_SHA: ${{ inputs.override_commit }} + GITHUB_EVENT_NAME: ${{ github.event_name }} + GITHUB_EVENT_NUMBER: ${{ github.event.number }} + GITHUB_EVENT_PULL_REQUEST_HEAD_SHA: ${{ github.event.pull_request.head.sha }} + - name: Upload coverage to Codecov run: ${GITHUB_ACTION_PATH}/dist/codecov.sh shell: bash working-directory: ${{ inputs.working-directory }} env: CC_BINARY: ${{ inputs.binary }} - CC_BRANCH: $CC_BRANCH CC_BUILD: ${{ inputs.override_build }} CC_BUILD_URL: ${{ inputs.override_build_url }} CC_CODE: ${{ inputs.report_code }} @@ -229,13 +249,10 @@ runs: CC_OS: ${{ inputs.os }} CC_PARENT_SHA: ${{ inputs.commit_parent }} CC_PLUGINS: ${{ inputs.plugins }} - CC_PR: ${{ inputs.override_pr }} CC_REPORT_TYPE: ${{ inputs.report_type }} - CC_SHA: ${{ inputs.override_commit }} CC_SKIP_VALIDATION: ${{ inputs.skip_validation }} CC_SLUG: ${{ inputs.slug }} CC_SWIFT_PROJECT: ${{ inputs.swift_project }} - CC_TOKEN: $CODECOV_TOKEN CC_VERBOSE: ${{ inputs.verbose }} CC_VERSION: ${{ inputs.version }} CC_YML_PATH: ${{ inputs.codecov_yml_path }} diff --git a/src/version b/src/version index 824b8f25f..5a7c4cd0f 100644 --- a/src/version +++ b/src/version @@ -1 +1 @@ -CODECOV_ACTION_VERSION="5.0.1" +CODECOV_ACTION_VERSION="5.0.2"