sync #3006
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: "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" |