2022-09-01 00:27:53 +08:00
|
|
|
name: "End to End"
|
|
|
|
|
|
|
|
on:
|
|
|
|
push:
|
|
|
|
branches: [ master ]
|
|
|
|
pull_request:
|
|
|
|
branches: [ master ]
|
|
|
|
|
|
|
|
concurrency:
|
|
|
|
group: ${{ github.head_ref }}/e2e
|
|
|
|
cancel-in-progress: true
|
|
|
|
|
|
|
|
permissions:
|
|
|
|
contents: read
|
|
|
|
|
|
|
|
defaults:
|
|
|
|
run:
|
|
|
|
working-directory: docker
|
|
|
|
|
|
|
|
jobs:
|
|
|
|
e2e:
|
|
|
|
name: FUSE Mount
|
|
|
|
runs-on: ubuntu-22.04
|
2023-09-23 07:44:45 +08:00
|
|
|
timeout-minutes: 30
|
2022-09-01 00:27:53 +08:00
|
|
|
steps:
|
|
|
|
- name: Set up Go 1.x
|
2023-12-11 23:43:14 +08:00
|
|
|
uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v2
|
2022-09-01 00:27:53 +08:00
|
|
|
with:
|
|
|
|
go-version: ^1.13
|
|
|
|
id: go
|
|
|
|
|
|
|
|
- name: Check out code into the Go module directory
|
2023-10-24 04:08:43 +08:00
|
|
|
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v2
|
2022-09-01 00:27:53 +08:00
|
|
|
|
|
|
|
- name: Install dependencies
|
|
|
|
run: |
|
|
|
|
sudo apt-get update
|
|
|
|
sudo apt-get install -y fuse
|
|
|
|
|
|
|
|
- name: Start SeaweedFS
|
|
|
|
timeout-minutes: 5
|
|
|
|
run: make build_e2e && docker compose -f ./compose/e2e-mount.yml up --wait
|
|
|
|
|
2023-09-23 07:41:39 +08:00
|
|
|
- name: Run FIO 4k
|
2023-09-23 13:35:27 +08:00
|
|
|
timeout-minutes: 15
|
2022-09-01 00:27:53 +08:00
|
|
|
run: |
|
|
|
|
echo "Starting FIO at: $(date)"
|
|
|
|
# Concurrent r/w
|
|
|
|
echo 'Run randrw with size=16M bs=4k'
|
2023-09-23 13:53:00 +08:00
|
|
|
docker compose -f ./compose/e2e-mount.yml exec mount timeout -k5 60 fio --name=fiotest --filename=/mnt/seaweedfs/fiotest --size=16M --rw=randrw --bs=4k --direct=1 --numjobs=8 --ioengine=libaio --group_reporting --runtime=30 --time_based=1
|
2023-01-17 04:46:56 +08:00
|
|
|
|
|
|
|
echo "Verify FIO at: $(date)"
|
2022-09-01 00:27:53 +08:00
|
|
|
# Verified write
|
|
|
|
echo 'Run randwrite with size=16M bs=4k'
|
2023-09-23 13:53:00 +08:00
|
|
|
docker compose -f ./compose/e2e-mount.yml exec mount timeout -k5 60 fio --name=fiotest --filename=/mnt/seaweedfs/fiotest --size=16M --rw=randwrite --bs=4k --direct=1 --numjobs=8 --ioengine=libaio --iodepth=32 --group_reporting --runtime=30 --time_based=1 --do_verify=0 --verify=crc32c --verify_backlog=1
|
2023-01-17 04:46:56 +08:00
|
|
|
|
2023-09-23 07:41:39 +08:00
|
|
|
- name: Run FIO 128k
|
2023-01-17 04:46:56 +08:00
|
|
|
timeout-minutes: 15
|
|
|
|
run: |
|
|
|
|
echo "Starting FIO at: $(date)"
|
|
|
|
# Concurrent r/w
|
|
|
|
echo 'Run randrw with size=16M bs=128k'
|
2023-01-17 05:54:07 +08:00
|
|
|
docker compose -f ./compose/e2e-mount.yml exec mount timeout -k5 60 fio --name=fiotest --filename=/mnt/seaweedfs/fiotest --size=16M --rw=randrw --bs=128k --direct=1 --numjobs=8 --ioengine=libaio --iodepth=32 --group_reporting --runtime=30 --time_based=1
|
2023-01-17 04:46:56 +08:00
|
|
|
|
|
|
|
echo "Verify FIO at: $(date)"
|
|
|
|
# Verified write
|
2022-09-01 00:27:53 +08:00
|
|
|
echo 'Run randwrite with size=16M bs=128k'
|
2023-01-17 05:54:07 +08:00
|
|
|
docker compose -f ./compose/e2e-mount.yml exec mount timeout -k5 60 fio --name=fiotest --filename=/mnt/seaweedfs/fiotest --size=16M --rw=randwrite --bs=128k --direct=1 --numjobs=8 --ioengine=libaio --iodepth=32 --group_reporting --runtime=30 --time_based=1 --do_verify=0 --verify=crc32c --verify_backlog=1
|
2023-01-17 04:46:56 +08:00
|
|
|
|
2023-09-23 07:41:39 +08:00
|
|
|
- name: Run FIO 1MB
|
2023-01-17 04:46:56 +08:00
|
|
|
timeout-minutes: 15
|
|
|
|
run: |
|
|
|
|
echo "Starting FIO at: $(date)"
|
|
|
|
# Concurrent r/w
|
|
|
|
echo 'Run randrw with size=16M bs=1m'
|
2023-01-17 05:54:07 +08:00
|
|
|
docker compose -f ./compose/e2e-mount.yml exec mount timeout -k5 60 fio --name=fiotest --filename=/mnt/seaweedfs/fiotest --size=16M --rw=randrw --bs=1m --direct=1 --numjobs=8 --ioengine=libaio --iodepth=32 --group_reporting --runtime=30 --time_based=1
|
2022-09-01 00:27:53 +08:00
|
|
|
|
2023-01-17 04:46:56 +08:00
|
|
|
echo "Verify FIO at: $(date)"
|
|
|
|
# Verified write
|
2022-09-01 00:27:53 +08:00
|
|
|
echo 'Run randwrite with size=16M bs=1m'
|
2023-01-17 05:54:07 +08:00
|
|
|
docker compose -f ./compose/e2e-mount.yml exec mount timeout -k5 60 fio --name=fiotest --filename=/mnt/seaweedfs/fiotest --size=16M --rw=randwrite --bs=1m --direct=1 --numjobs=8 --ioengine=libaio --iodepth=32 --group_reporting --runtime=30 --time_based=1 --do_verify=0 --verify=crc32c --verify_backlog=1
|
2022-09-01 00:27:53 +08:00
|
|
|
|
|
|
|
- name: Save logs
|
|
|
|
if: always()
|
|
|
|
run: |
|
|
|
|
docker compose -f ./compose/e2e-mount.yml logs > output.log
|
|
|
|
echo 'Showing last 500 log lines of mount service:'
|
|
|
|
docker compose -f ./compose/e2e-mount.yml logs --tail 500 mount
|
|
|
|
|
|
|
|
- name: Check for data races
|
|
|
|
if: always()
|
|
|
|
continue-on-error: true # TODO: remove this comment to enable build failure on data races (after all are fixed)
|
|
|
|
run: grep -A50 'DATA RACE' output.log && exit 1 || exit 0
|
|
|
|
|
|
|
|
- name: Archive logs
|
|
|
|
if: always()
|
|
|
|
uses: actions/upload-artifact@v3
|
|
|
|
with:
|
|
|
|
name: output-logs
|
|
|
|
path: docker/output.log
|
|
|
|
|
|
|
|
- name: Cleanup
|
|
|
|
if: always()
|
|
|
|
run: docker compose -f ./compose/e2e-mount.yml down --volumes --remove-orphans --rmi all
|