nfs: support object store and full-featured sync (#3823) #833
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: "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" |