]> Sergey Matveev's repositories - btrtrc.git/blobdiff - fs/test.sh
Handle torrentfs failure in test.sh
[btrtrc.git] / fs / test.sh
index f6d367c22dd3a7e5ed471bb279ab995de835f735..5374ed86b6a89a615c9e6a5fb109223400c6e5a8 100755 (executable)
@@ -1,14 +1,37 @@
-mkdir mnt torrents
-umount mnt
-set -e
-GOPPROF=http godo github.com/anacrolix/torrent/cmd/torrentfs -mountDir=mnt -metainfoDir=torrents &
-cd torrents
-wget -c https://cdimage.debian.org/debian-cd/current/amd64/bt-cd/debian-9.1.0-amd64-netinst.iso.torrent
-echo 'magnet:?xt=urn:btih:6a9759bffd5c0af65319979fb7832189f4f3c35d&dn=sintel.mp4' > sintel.magnet
-cd ..
-file=debian-9.1.0-amd64-netinst.iso
-# file=sintel.mp4
-while [ ! -e "mnt/$file" ]; do sleep 1; done
-pv "mnt/$file" | md5sum
-umount mnt
-wait
+#!/usr/bin/env bash
+echo $BASH_VERSION
+set -eux
+repopath="$(cd "$(dirname "$0")/.."; pwd)"
+debian_file=debian-10.8.0-amd64-netinst.iso
+mkdir -p mnt torrents
+# I think the timing can cause torrents to not get added correctly to the torrentfs client, so add
+# them first and start the fs afterwards.
+pushd torrents
+cp "$repopath/testdata/$debian_file.torrent" .
+godo -v -- "$repopath/cmd/torrent" metainfo "$repopath/testdata/sintel.torrent" magnet > sintel.magnet
+popd
+#file="$debian_file"
+file=Sintel/Sintel.mp4
+
+GOPPROF=http godo -v -- "$repopath/fs/cmd/torrentfs" -mountDir=mnt -metainfoDir=torrents &
+torrentfs_pid=$!
+trap "kill $torrentfs_pid" EXIT
+
+check_file() {
+       while [ ! -e "mnt/$file" ]; do sleep 1; done
+       pv -f "mnt/$file" | md5sum -c <(cat <<-EOF
+       083e808d56aa7b146f513b3458658292  -
+       EOF
+       )
+}
+
+( check_file ) &
+check_file_pid=$!
+
+trap "kill $torrentfs_pid $check_file_pid" EXIT
+wait -n
+status=$?
+sudo umount mnt
+trap - EXIT
+echo "wait returned" $status
+exit $status