Skip to content

nfs: support object store and full-featured sync #830

nfs: support object store and full-featured sync

nfs: support object store and full-featured sync #830

Workflow file for this run

name: "command-test"
on:
push:
branches:
- 'main'
- 'release-**'
paths-ignore:
- 'docs/**'
- '**.md'
pull_request:
branches:
- 'main'
- 'release-**'
paths-ignore:
- 'docs/**'
- '**.md'
schedule:
- cron: '30 20 * * *'
workflow_dispatch:
inputs:
debug:
type: boolean
description: "Run the build with tmate debugging enabled"
required: false
default: false
jobs:
build-matrix:
runs-on: ubuntu-20.04
steps:
- id: set-matrix
run: |
echo "github.event_name is ${{github.event_name}}"
echo "GITHUB_REF_NAME is ${GITHUB_REF_NAME}"
if [ "${{github.event_name}}" == "schedule" ]; then
echo 'meta_matrix=["sqlite3", "redis", "tikv"]' >> $GITHUB_OUTPUT
elif [ "${{github.event_name}}" == "pull_request" ]; then
echo 'meta_matrix=["redis"]' >> $GITHUB_OUTPUT
elif [ "${{github.event_name}}" == "workflow_dispatch" ]; then
echo 'meta_matrix=["sqlite3", "redis", "tikv"]' >> $GITHUB_OUTPUT
else
echo 'meta_matrix=["redis"]' >> $GITHUB_OUTPUT
fi
outputs:
meta_matrix: ${{ steps.set-matrix.outputs.meta_matrix }}
command_test1:
needs: [build-matrix]
strategy:
fail-fast: true
matrix:
# meta: [ 'sqlite3', 'redis', 'tikv']
meta: ${{ fromJson(needs.build-matrix.outputs.meta_matrix) }}
runs-on: ubuntu-20.04
steps:
- name: Remove unused software
shell: bash
run: |
echo "before remove unused software"
sudo df -h
sudo rm -rf /usr/share/dotnet
sudo rm -rf /usr/local/lib/android
sudo rm -rf /opt/ghc
echo "after remove unused software"
sudo df -h
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 1
- name: Build
uses: ./.github/actions/build
- name: Test Config
run: |
sudo META=${{matrix.meta}} .github/scripts/command/config.sh
- name: Test Clone
timeout-minutes: 30
run: |
sudo META=${{matrix.meta}} .github/scripts/command/clone.sh
- name: Test fsck
timeout-minutes: 30
run: |
sudo META=${{matrix.meta}} .github/scripts/command/fsck.sh
- name: Test Gc
timeout-minutes: 30
run: |
sudo META=${{matrix.meta}} .github/scripts/command/gc.sh
- name: Test Load & Dump
timeout-minutes: 30
run: |
sudo META=${{matrix.meta}} .github/scripts/command/load_dump.sh
- name: Test Info
run: |
sudo META=${{matrix.meta}} .github/scripts/command/info.sh
- name: Log
if: ${{ always() }}
run: |
echo "juicefs log"
sudo tail -n 1000 /var/log/juicefs.log
grep "<FATAL>:" /var/log/juicefs.log && exit 1 || true
- name: Setup upterm session
if: ${{ failure() && github.event_name == 'workflow_dispatch' && github.event.inputs.debug }}
# if: failure()
timeout-minutes: 60
uses: lhotari/action-upterm@v1
command_test2:
needs: [build-matrix]
strategy:
fail-fast: true
matrix:
meta: ${{ fromJson(needs.build-matrix.outputs.meta_matrix) }}
runs-on: ubuntu-20.04
steps:
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 1
- name: Build
uses: ./.github/actions/build
- name: Test Quota
timeout-minutes: 30
run: |
sudo META=${{matrix.meta}} .github/scripts/command/quota.sh
- name: Log
if: ${{ always() }}
run: |
echo "juicefs log"
sudo tail -n 1000 /var/log/juicefs.log
grep "<FATAL>:" /var/log/juicefs.log && exit 1 || true
- name: Setup upterm session
if: ${{ failure() && github.event_name == 'workflow_dispatch' && github.event.inputs.debug }}
# if: failure()
timeout-minutes: 60
uses: lhotari/action-upterm@v1
command_test3:
needs: [build-matrix]
strategy:
fail-fast: true
matrix:
meta: ${{ fromJson(needs.build-matrix.outputs.meta_matrix) }}
runs-on: ubuntu-20.04
steps:
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 1
- name: Build
uses: ./.github/actions/build
# with:
# useBeta: true
- name: Test Sync
timeout-minutes: 30
run: |
sudo META=${{matrix.meta}} .github/scripts/command/sync.sh
- name: Test Sync with mino
timeout-minutes: 30
run: |
sudo META=${{matrix.meta}} .github/scripts/command/sync_minio.sh
- name: Test Sync with multi nodes
timeout-minutes: 30
run: |
if [ "${{matrix.meta}}" != "redis" ]; then
echo "skip sync with multi nodes when meta is not redis"
exit 0
fi
# not supported algo: "dsa" "ecdsa-sk" "ed25519-sk"
types=("ecdsa" "ed25519" "rsa")
random_type=${types[$RANDOM % ${#types[@]}]}
sudo CI=true META=${{matrix.meta}} KEY_TYPE=$random_type .github/scripts/command/sync_cluster.sh
- name: Log
if: ${{ always() }}
run: |
echo "juicefs log"
sudo tail -n 1000 /var/log/juicefs.log
grep "<FATAL>:" /var/log/juicefs.log && exit 1 || true
- name: Setup upterm session
if: ${{ failure() && github.event_name == 'workflow_dispatch' && github.event.inputs.debug }}
# if: failure()
timeout-minutes: 60
uses: lhotari/action-upterm@v1
success-all-test:
runs-on: ubuntu-latest
needs: [command_test1, command_test2, command_test3]
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: 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"