Skip to content

sync

sync #3006

Workflow file for this run

name: "sync"
on:
push:
branches:
- 'main'
- 'release-**'
paths:
- '**.go'
- 'Makefile'
- '**/sync.yml'
- '.github/scripts/sync/**'
- '.github/scripts/hypo/sync.py'
- '.github/scripts/hypo/sync_test.py'
- '.github/actions/upload-coverage/action.yml'
- '.github/actions/mount-coverage-dir/action.yml'
- '.github/actions/upload-total-coverage/action.yml'
pull_request:
branches:
- 'main'
- 'release-**'
paths:
- '**.go'
- 'Makefile'
- '**/sync.yml'
- '.github/scripts/sync/**'
- '.github/scripts/hypo/sync.py'
- '.github/scripts/hypo/sync_test.py'
- '.github/actions/upload-coverage/action.yml'
- '.github/actions/mount-coverage-dir/action.yml'
- '.github/actions/upload-total-coverage/action.yml'
workflow_dispatch:
inputs:
debug:
type: boolean
description: "Run the build with tmate debugging enabled"
required: false
default: false
schedule:
- cron: '0 17 * * *'
jobs:
sync:
runs-on: ubuntu-20.04
strategy:
fail-fast: false
matrix:
type: ['sync', 'sync_fsrand', 'sync_minio', 'sync_cluster', 'sync_exclude']
steps:
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 1
- name: mount coverage dir
timeout-minutes: 5
uses: ./.github/actions/mount-coverage-dir
with:
mount_point: cover
access_key: ${{ secrets.CI_COVERAGE_AWS_AK }}
secret_key: ${{ secrets.CI_COVERAGE_AWS_SK }}
token: ${{ secrets.CI_COVERAGE_AWS_TOKEN }}
- name: Build
uses: ./.github/actions/build
- name: Test Sync
timeout-minutes: 60
run: |
if [[ "${{matrix.type}}" == 'sync' ]]; then
sudo GOCOVERDIR=$(pwd)/cover META=redis .github/scripts/sync/sync.sh
elif [[ "${{matrix.type}}" == 'sync_fsrand' ]]; then
sudo GOCOVERDIR=$(pwd)/cover META=redis .github/scripts/sync/sync_fsrand.sh
elif [[ "${{matrix.type}}" == 'sync_minio' ]]; then
sudo GOCOVERDIR=$(pwd)/cover META=redis .github/scripts/sync/sync_minio.sh
elif [[ "${{matrix.type}}" == 'sync_cluster' ]]; then
types=("ecdsa" "ed25519" "rsa")
random_type=${types[$RANDOM % ${#types[@]}]}
sudo CI=true GOCOVERDIR=$(pwd)/cover META=redis KEY_TYPE=$random_type .github/scripts/sync/sync_cluster.sh
elif [[ "${{matrix.type}}" == 'sync_exclude' ]]; then
sudo GOCOVERDIR=$(pwd)/cover python3 .github/scripts/hypo/sync_test.py
if [ "${{github.event_name}}" == "schedule" ]; then
sudo GOCOVERDIR=$(pwd)/cover MAX_EXAMPLE=100 STEP_COUNT=50 PROFILE=ci python3 .github/scripts/hypo/sync.py
else
sudo GOCOVERDIR=$(pwd)/cover MAX_EXAMPLE=50 STEP_COUNT=30 PROFILE=ci python3 .github/scripts/hypo/sync.py
fi
else
echo "Unknown type: ${{matrix.type}}"
exit 1
fi
- name: Setup upterm session
if: failure() && (github.event.inputs.debug == 'true' || github.run_attempt != 1)
# if: failure()
timeout-minutes: 60
uses: lhotari/action-upterm@v1
success-all-test:
runs-on: ubuntu-latest
needs: [sync]
if: always()
steps:
- uses: technote-space/workflow-conclusion-action@v3
- uses: actions/checkout@v3
- name: Check Failure
if: env.WORKFLOW_CONCLUSION == 'failure'
run: exit 1
- name: mount coverage dir
timeout-minutes: 5
uses: ./.github/actions/mount-coverage-dir
with:
mount_point: cover
access_key: ${{ secrets.CI_COVERAGE_AWS_AK }}
secret_key: ${{ secrets.CI_COVERAGE_AWS_SK }}
token: ${{ secrets.CI_COVERAGE_AWS_TOKEN }}
- name: upload total coverage report
timeout-minutes: 5
uses: ./.github/actions/upload-total-coverage
with:
UPLOAD_TOKEN: ${{ secrets.CI_COVERAGE_FILE_UPLOAD_AUTH_TOKEN }}
- name: Send Slack Notification
if: failure() && github.event_name != 'workflow_dispatch'
uses: juicedata/slack-notify-action@main
with:
channel-id: "${{ secrets.SLACK_CHANNEL_ID_FOR_PR_CHECK_NOTIFY }}"
slack_bot_token: "${{ secrets.SLACK_BOT_TOKEN }}"
- name: Success
if: success()
run: echo "All Done"