From e98c51afd6870c73d5006a22cff5322c2f4d0ba7 Mon Sep 17 00:00:00 2001 From: Jakob Unterwurzacher Date: Thu, 14 Jul 2016 09:26:00 +0200 Subject: [PATCH] tests: add loopback-mem script Helps to find memory leaks in go-fuse's loopback, which gocryptfs builds upon. --- tests/stress_tests/loopback-mem.bash | 45 ++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100755 tests/stress_tests/loopback-mem.bash diff --git a/tests/stress_tests/loopback-mem.bash b/tests/stress_tests/loopback-mem.bash new file mode 100755 index 0000000..fa3b0e3 --- /dev/null +++ b/tests/stress_tests/loopback-mem.bash @@ -0,0 +1,45 @@ +#!/bin/bash +# +# Mount a loopback filesystem somewhere on /tmp, then run an +# infinite loop inside that does the following: +# 1) Extract linux-3.0.tar.gz +# 2) Delete +# 3) Get memory profile +# +# This test is good at discovering inode-related memory leaks because it creates +# huge numbers of files. + +set -eu + +# Setup dirs +cd /tmp +wget -nv --show-progress -c https://www.kernel.org/pub/linux/kernel/v3.0/linux-3.0.tar.gz +DIR1=$(mktemp -d /tmp/loopback-mem.XXX) +DIR2=$DIR1.mnt +mkdir $DIR2 + +# Mount +loopback -l -memprofile /tmp/lmem $DIR2 $DIR1 & +LOOPBACKPID=$(jobs -p) +sleep 1 +cd $DIR2 + +# Cleanup trap +trap "cd /; fusermount -u -z $DIR2; rm -rf $DIR1 $DIR2" EXIT + +echo "Starting loop" + +N=1 +while true; do + t1=$SECONDS + tar xf /tmp/linux-3.0.tar.gz + rm -Rf linux-3.0 + t2=$SECONDS + delta=$((t2-t1)) + rss=$(grep VmRSS /proc/$LOOPBACKPID/status) + echo "Iteration $N done, $delta seconds, $rss" + let N=$N+1 + sleep 1 + kill -USR1 $LOOPBACKPID +done +