mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-01 03:26:45 +00:00
253 lines
5.7 KiB
Bash
253 lines
5.7 KiB
Bash
|
#!/bin/bash
|
||
|
|
||
|
echo "--- Automated CBE testing ---"
|
||
|
|
||
|
produce_pattern() {
|
||
|
local pattern="$1"
|
||
|
local size="$2"
|
||
|
[ "$pattern" = "" ] && exit 1
|
||
|
|
||
|
local tmp_file="/tmp/pattern.tmp"
|
||
|
local N=1041
|
||
|
# prints numbers until N and uses pattern as delimiter and
|
||
|
# generates about 4 KiB of data with a 1 byte pattern
|
||
|
seq -s "$pattern" $N > $tmp_file
|
||
|
dd if=$tmp_file count=1 bs=$size 2>/dev/null
|
||
|
}
|
||
|
|
||
|
test_write_1() {
|
||
|
local data_file="$1"
|
||
|
local offset=$2
|
||
|
|
||
|
local pattern_file="/tmp/pattern"
|
||
|
dd bs=4096 count=1 if=$pattern_file of=$data_file seek=$offset 2>/dev/null || exit 1
|
||
|
}
|
||
|
|
||
|
test_read_compare_1() {
|
||
|
local data_file="$1"
|
||
|
local offset=$2
|
||
|
|
||
|
local pattern_file="/tmp/pattern"
|
||
|
rm $pattern_file.out 2>/dev/null
|
||
|
|
||
|
dd bs=4096 count=1 if=$data_file of=$pattern_file.out skip=$offset 2>/dev/null || exit 1
|
||
|
local sha1=$(sha1sum $pattern_file)
|
||
|
local sha1_sum=${sha1:0:40}
|
||
|
|
||
|
local sha1out=$(sha1sum $pattern_file.out)
|
||
|
local sha1out_sum=${sha1out:0:40}
|
||
|
|
||
|
if [ "$sha1_sum" != "$sha1out_sum" ]; then
|
||
|
echo "mismatch for block $offset:"
|
||
|
echo " expected: $sha1_sum"
|
||
|
echo -n " "
|
||
|
dd if=$pattern_file bs=32 count=1 2>/dev/null; echo
|
||
|
echo " got: $sha1out_sum"
|
||
|
echo -n " "
|
||
|
dd if=$pattern_file.out bs=32 count=1 2>/dev/null; echo
|
||
|
return 1
|
||
|
fi
|
||
|
}
|
||
|
|
||
|
test_create_snapshot() {
|
||
|
local cbe_dir="$1"
|
||
|
|
||
|
echo "Create snapshot"
|
||
|
echo true > $cbe_dir/control/create_snapshot
|
||
|
}
|
||
|
|
||
|
test_list_snapshots() {
|
||
|
local cbe_dir="$1"
|
||
|
|
||
|
echo "List content of '$cbe_dir'"
|
||
|
ls -l $cbe_dir/snapshots
|
||
|
}
|
||
|
|
||
|
test_discard_snapshot() {
|
||
|
local cbe_dir="$1"
|
||
|
local snap_id=$2
|
||
|
|
||
|
echo "Discard snapshot with id: $snap_id"
|
||
|
echo $snap_id > $cbe_dir/control/discard_snapshot
|
||
|
}
|
||
|
|
||
|
test_rekey() {
|
||
|
local cbe_dir="$1"
|
||
|
|
||
|
echo "Start rekeying"
|
||
|
echo on > $cbe_dir/control/rekey
|
||
|
echo "Reykeying started"
|
||
|
}
|
||
|
|
||
|
test_vbd_extension() {
|
||
|
local cbe_dir="$1"
|
||
|
local nr_of_phys_blocks="$2"
|
||
|
|
||
|
echo "Start extending VBD"
|
||
|
echo tree=vbd, blocks=$nr_of_phys_blocks > $cbe_dir/control/extend
|
||
|
echo "VBD extension started"
|
||
|
}
|
||
|
|
||
|
test_ft_extension() {
|
||
|
local cbe_dir="$1"
|
||
|
local nr_of_phys_blocks="$2"
|
||
|
|
||
|
echo "Start extending FT"
|
||
|
echo tree=ft, blocks=$nr_of_phys_blocks > $cbe_dir/control/extend
|
||
|
echo "FT extension started"
|
||
|
}
|
||
|
|
||
|
test_rekey_state() {
|
||
|
local cbe_dir="$1"
|
||
|
local state="$(< $cbe_dir/control/rekey)"
|
||
|
|
||
|
echo "Rekeying state: $state"
|
||
|
}
|
||
|
|
||
|
test_rekey_state() {
|
||
|
local cbe_dir="$1"
|
||
|
local state="$(< $cbe_dir/control/rekey)"
|
||
|
|
||
|
echo "Rekeying state: $state"
|
||
|
}
|
||
|
|
||
|
wait_for_rekeying() {
|
||
|
local cbe_dir="$1"
|
||
|
|
||
|
echo "Wait for rekeying to finish..."
|
||
|
while : ; do
|
||
|
local file_content="$(< $cbe_dir/control/rekey)"
|
||
|
local state="${file_content:0:4}"
|
||
|
if [ "$state" = "idle" ]; then
|
||
|
local result="${file_content:5}"
|
||
|
echo "Reykeying done: $result"
|
||
|
break;
|
||
|
fi
|
||
|
sleep 2
|
||
|
done
|
||
|
}
|
||
|
|
||
|
wait_for_vbd_extension() {
|
||
|
local cbe_dir="$1"
|
||
|
|
||
|
echo "Wait for VBD extension to finish..."
|
||
|
while : ; do
|
||
|
local file_content="$(< $cbe_dir/control/extend)"
|
||
|
local state="${file_content:0:4}"
|
||
|
if [ "$state" = "idle" ]; then
|
||
|
local result="${file_content:5}"
|
||
|
echo "VBD extension done: $result"
|
||
|
break;
|
||
|
fi
|
||
|
sleep 2
|
||
|
done
|
||
|
}
|
||
|
|
||
|
wait_for_ft_extension() {
|
||
|
local cbe_dir="$1"
|
||
|
|
||
|
echo "Wait for FT extension to finish..."
|
||
|
while : ; do
|
||
|
local file_content="$(< $cbe_dir/control/extend)"
|
||
|
local state="${file_content:0:4}"
|
||
|
if [ "$state" = "idle" ]; then
|
||
|
local result="${file_content:5}"
|
||
|
echo "VBD extension done: $result"
|
||
|
break;
|
||
|
fi
|
||
|
sleep 2
|
||
|
done
|
||
|
}
|
||
|
|
||
|
main() {
|
||
|
local cbe_dir="/dev/cbe"
|
||
|
local data_file="$cbe_dir/current/data"
|
||
|
|
||
|
ls -l $cbe_dir
|
||
|
|
||
|
for i in $(seq 3); do
|
||
|
|
||
|
echo "--> Run $i:"
|
||
|
|
||
|
local pattern_file="/tmp/pattern"
|
||
|
produce_pattern "$i" "4096" > $pattern_file
|
||
|
|
||
|
test_write_1 "$data_file" "419"
|
||
|
test_write_1 "$data_file" "63"
|
||
|
test_write_1 "$data_file" "333"
|
||
|
|
||
|
test_vbd_extension "$cbe_dir" "1000"
|
||
|
test_read_compare_1 "$data_file" "63"
|
||
|
test_write_1 "$data_file" "175"
|
||
|
test_read_compare_1 "$data_file" "419"
|
||
|
test_write_1 "$data_file" "91"
|
||
|
test_read_compare_1 "$data_file" "175"
|
||
|
test_read_compare_1 "$data_file" "91"
|
||
|
test_read_compare_1 "$data_file" "333"
|
||
|
wait_for_vbd_extension "$cbe_dir"
|
||
|
|
||
|
test_write_1 "$data_file" "32"
|
||
|
test_write_1 "$data_file" "77"
|
||
|
test_write_1 "$data_file" "199"
|
||
|
|
||
|
test_ft_extension "$cbe_dir" "1000"
|
||
|
test_read_compare_1 "$data_file" "32"
|
||
|
test_write_1 "$data_file" "211"
|
||
|
test_read_compare_1 "$data_file" "77"
|
||
|
test_write_1 "$data_file" "278"
|
||
|
test_read_compare_1 "$data_file" "199"
|
||
|
test_read_compare_1 "$data_file" "278"
|
||
|
test_read_compare_1 "$data_file" "211"
|
||
|
wait_for_ft_extension "$cbe_dir"
|
||
|
|
||
|
test_write_1 "$data_file" "0"
|
||
|
test_write_1 "$data_file" "8"
|
||
|
test_write_1 "$data_file" "16"
|
||
|
test_write_1 "$data_file" "490"
|
||
|
test_write_1 "$data_file" "468"
|
||
|
|
||
|
test_read_compare_1 "$data_file" "0"
|
||
|
test_read_compare_1 "$data_file" "8"
|
||
|
test_read_compare_1 "$data_file" "16"
|
||
|
test_read_compare_1 "$data_file" "490"
|
||
|
|
||
|
test_rekey "$cbe_dir"
|
||
|
test_write_1 "$data_file" "0"
|
||
|
test_rekey_state "$cbe_dir"
|
||
|
test_read_compare_1 "$data_file" "490"
|
||
|
test_rekey_state "$cbe_dir"
|
||
|
test_write_1 "$data_file" "16"
|
||
|
test_rekey_state "$cbe_dir"
|
||
|
test_read_compare_1 "$data_file" "468"
|
||
|
test_rekey_state "$cbe_dir"
|
||
|
test_read_compare_1 "$data_file" "8"
|
||
|
test_rekey_state "$cbe_dir"
|
||
|
test_read_compare_1 "$data_file" "16"
|
||
|
test_rekey_state "$cbe_dir"
|
||
|
test_read_compare_1 "$data_file" "0"
|
||
|
test_write_1 "$data_file" "300"
|
||
|
test_write_1 "$data_file" "240"
|
||
|
test_write_1 "$data_file" "201"
|
||
|
test_write_1 "$data_file" "328"
|
||
|
wait_for_rekeying "$cbe_dir"
|
||
|
|
||
|
echo "--> Run $i done"
|
||
|
|
||
|
done
|
||
|
|
||
|
echo "--> Read/Compare test"
|
||
|
test_read_compare_1 "$data_file" "0"
|
||
|
test_read_compare_1 "$data_file" "490"
|
||
|
test_read_compare_1 "$data_file" "468"
|
||
|
test_read_compare_1 "$data_file" "8"
|
||
|
test_read_compare_1 "$data_file" "16"
|
||
|
echo "--> Read/Compare test done"
|
||
|
|
||
|
echo "--- Automated CBE testing finished, shell is yours ---"
|
||
|
}
|
||
|
|
||
|
main "$@"
|
||
|
|
||
|
# just drop into shell
|
||
|
# exit 0
|