CI: generate coverage daily report #2
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: "coverage-report" | |
on: | |
push: | |
branches: | |
- main | |
- release** | |
paths: | |
- '**/coverage-report.yml' | |
pull_request: | |
branches: | |
- main | |
- release** | |
paths: | |
- '**/coverage-report.yml' | |
workflow_dispatch: | |
inputs: | |
debug: | |
type: boolean | |
description: "Run the build with tmate debugging enabled" | |
required: false | |
default: false | |
last_date: | |
type: string | |
description: "last date of coverage data" | |
required: false | |
default: "" | |
schedule: | |
- cron: '0 23 * * *' | |
jobs: | |
coverage-report: | |
strategy: | |
fail-fast: false | |
matrix: | |
branch: ['main'] | |
test: ['ut', 'it', 'all'] | |
timeout-minutes: 60 | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout | |
timeout-minutes: 1 | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 1 | |
- name: mount coverage dir | |
timeout-minutes: 5 | |
uses: ./.github/actions/mount-coverage-dir | |
with: | |
mount_point: schedule | |
subdir: schedule | |
access_key: ${{ secrets.CI_COVERAGE_AWS_AK }} | |
secret_key: ${{ secrets.CI_COVERAGE_AWS_SK }} | |
- name: Determine lastdate dir | |
timeout-minutes: 120 | |
run: | | |
if [[ -n "${{github.event.inputs.last_date}}" ]]; then | |
last_date=${{github.event.inputs.last_date}} | |
else | |
last_date=$(ls -t schedule | head -n 1) | |
[[ -z "$last_date" ]] && echo "no data found in schedule" && exit 1 | |
fi | |
[[ ! -d "schedule/$last_date" ]] && echo "schedule/$last_date not found" && exit 1 | |
echo "last_date=$last_date" >> $GITHUB_ENV | |
- name: Generate today's coverage report | |
timeout-minutes: 30 | |
working-directory: schedule/${{env.last_date}} | |
run: | | |
echo "current dir is $(pwd)" | |
coverdirs="" | |
for dir in $(find . -mindepth 1 -maxdepth 1 -type d -exec basename {} \;); do | |
if [[ ${{matrix.test}} == "ut" ]]; then | |
if [[ "$dir" == "unit-test" || "$dir" == "unit-random-test" ]]; then | |
coverdirs+="$dir," | |
fi | |
elif [[ ${{matrix.test}} == "it" ]]; then | |
if [[ "$dir" != "unit-test" && "$dir" != "unit-random-test" ]]; then | |
coverdirs+="$dir," | |
fi | |
elif [[ ${{matrix.test}} == "all" ]]; then | |
coverdirs+="$dir," | |
fi | |
done | |
coverdirs=${coverdirs%,} | |
echo coverdirs is $coverdirs | |
[[ -z "$coverdirs" ]] && echo "no coverage dir found" && exit 1 | |
name=cover_${{matrix.test}} | |
sudo go tool covdata percent -i=$coverdirs | sudo tee ${name}.percent | |
echo "generated coverage percent report:" $(realpath ${name}.percent) | |
sudo go tool covdata textfmt -o ${name}.txt -i=$coverdirs | |
echo "generated coverage report in text format:" $(realpath ${name}.txt) | |
sudo go tool cover -html=${name}.txt -o ${name}.html | |
echo "generated coverage report in html format:" $(realpath ${name}.html) | |
ls -l cover_* | |
- name: upload coverage report | |
working-directory: schedule/${{env.last_date}} | |
timeout-minutes: 10 | |
run: | | |
echo "current dir is $(pwd)" | |
UPLOAD_PATH=${{github.workflow}}_${{github.run_id}}_${{matrix.test}}.html | |
response=$(curl -w '%{http_code}' -s -o /dev/null --form 'file=@cover_${{matrix.test}}.html' https://juicefs.com/upload-file-u80sdvuke/${UPLOAD_PATH}?token=${{secrets.CI_COVERAGE_FILE_UPLOAD_AUTH_TOKEN}}) | |
if [ "$response" -eq 200 ]; then | |
echo Coverage Report for ${{matrix.test}}: https://i.juicefs.io/ci-coverage/${UPLOAD_PATH} | |
else | |
echo "Upload failed with status code $response" | |
exit 1 | |
fi | |
- name: Setup upterm session | |
if: failure() && (github.event.inputs.debug == 'true' || github.run_attempt != 1) | |
# if: failure() | |
timeout-minutes: 30 | |
uses: lhotari/action-upterm@v1 |