-
Notifications
You must be signed in to change notification settings - Fork 987
133 lines (123 loc) · 4.64 KB
/
misc.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
name: "misc-test"
on:
push:
branches:
- release-**
paths-ignore:
- 'docs/**'
- '**.md'
pull_request:
#The branches below must be a subset of the branches above
branches:
- release-**
# - main
paths-ignore:
- 'docs/**'
- '**.md'
workflow_dispatch:
schedule:
- cron: '0 0 * * *'
jobs:
misc-test:
runs-on: ubuntu-20.04
services:
redis:
# Docker Hub image
image: redis
# Set health checks to wait until redis has started
options: >-
--health-cmd "redis-cli ping"
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
# Maps port 6379 on service container to the host
- 6379:6379
steps:
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 1
- name: Setup minio
run: |
docker run -d -p 9000:9000 --name minio \
-e "MINIO_ACCESS_KEY=minioadmin" \
-e "MINIO_SECRET_KEY=minioadmin" \
-v /tmp/data:/data \
-v /tmp/config:/root/.minio \
minio/minio server /data
- name: Build
uses: ./.github/actions/build
- name: Install tool
run: |
wget -q https://dl.minio.io/client/mc/release/linux-amd64/mc
chmod +x mc
sudo .github/scripts/apt_install.sh redis-tools fio
- name: Test mount process exit on reformat
run: |
for i in {1..3}; do
echo "round $i"
meta=redis://localhost/1
./juicefs format $meta volume-$i
./juicefs mount -d $meta /tmp/myjfs$i_$j --no-usage-report
cd /tmp/myjfs$i_$j
bash -c 'for k in {1..300}; do echo abc>$k; sleep 0.2; done' || true &
cd -
sleep 3
uuid=$(./juicefs status $meta | grep UUID | cut -d '"' -f 4)
./juicefs destroy --force $meta $uuid
./juicefs format $meta new-volume-$i
sleep 15
ps -ef | grep juicefs
pidof juicefs && exit 1
uuid=$(./juicefs status $meta | grep UUID | cut -d '"' -f 4)
./juicefs destroy --force $meta $uuid
done
- name: Test config secret key
run: |
# # Consider command as failed when any component of the pipe fails:
# https://stackoverflow.com/questions/1221833/pipe-output-and-capture-exit-status-in-bash
set -o pipefail
meta_url=redis://127.0.0.1/2
mount_point=/tmp/sync-test/
./mc config host add minio http://127.0.0.1:9000 minioadmin minioadmin
./mc admin user add minio juicedata juicedata
./mc admin policy attach minio consoleAdmin --user juicedata
./juicefs format --storage minio --bucket http://localhost:9000/jfs-test --access-key juicedata --secret-key juicedata $meta_url myjfs
./juicefs mount $meta_url $mount_point -d --io-retries 1 --no-usage-report --heartbeat 5
./mc admin user remove minio juicedata
./mc admin user add minio juicedata1 juicedata1
./mc admin policy attach minio consoleAdmin --user juicedata1
./juicefs config $meta_url --access-key juicedata1 --secret-key juicedata1
sleep 6
echo abc | tee $mount_point/abc.txt && echo "write success"
cat $mount_point/abc.txt | grep abc && echo "read success"
- name: Test delay delete slice after compaction
run: |
meta=redis://localhost/3
mp=myjfs/
name=myjfs2
juicefs=./juicefs
$juicefs format $meta $name --trash-days 1
$juicefs mount -d $meta $mp --no-usage-report
fio --name=abc --rw=randwrite --refill_buffers --size=500M --bs=256k --directory=$mp
redis-cli save
# don't skip files when gc compact
export JFS_SKIPPED_TIME=1
$juicefs gc --compact --delete $meta
container_id=$(docker ps -a | grep redis | awk '{print $1}')
sudo killall -9 redis-server
sudo docker restart $container_id
sleep 3
$juicefs fsck $meta
- name: log
if: ${{ always() }}
run: |
tail -300 ~/.juicefs/juicefs.log
grep -v "UUID changed" ~/.juicefs/juicefs.log | grep "<FATAL>:" && exit 1 || true
- name: Send Slack Notification
if: ${{ failure() }}
uses: juicedata/slack-notify-action@main
with:
channel-id: "${{ secrets.SLACK_CHANNEL_ID_FOR_PR_CHECK_NOTIFY }}"
slack_bot_token: "${{ secrets.SLACK_BOT_TOKEN }}"