lsyncd/tests/directorycpr.sh

64 lines
1.7 KiB
Bash
Raw Normal View History

#!/bin/bash
set -e
2010-08-03 14:24:46 +00:00
CON="\E[47;34m"
COFF="\033[0m"
2010-08-03 15:03:42 +00:00
echo -e "$CON***************************************************************$COFF"
echo -e "$CON** Testing the case of directory being cp -r'ed and touched. **$COFF"
echo -e "$CON** With default delay **$COFF"
echo -e "$CON***************************************************************$COFF"
WORKSOURCE=$(mktemp -d)
2010-08-03 15:03:42 +00:00
WORKTARGET=$(mktemp -d)
PIDFILE=$(mktemp)
LOGFILE=$(mktemp)
2010-08-03 14:24:46 +00:00
echo -e "$CON* populating the filesystem$COFF"
mkdir -p "${WORKSOURCE}"/a/a
echo 'test' > "${WORKSOURCE}"/a/a/file
2010-08-03 14:24:46 +00:00
echo -e "$CON* starting lsyncd$COFF"
2010-08-04 10:52:31 +00:00
./lsyncd --logfile "${LOGFILE}" --pidfile "${PIDFILE}" --no-daemon "${WORKSOURCE}" "${WORKTARGET}"&
2010-08-03 14:24:46 +00:00
echo -e "$CON* waiting for lsyncd to start$COFF"
2008-11-20 21:38:58 +00:00
sleep 4s
2010-08-03 14:24:46 +00:00
# cp -r the directory
2010-08-03 15:03:42 +00:00
echo -e "$CON* making a lot of data$COFF"
for A in 1 2 3 4 5 6 7 8 9 10; do
cp -r "${WORKSOURCE}"/a "${WORKSOURCE}"/b${A}
echo 'test2' > "${WORKSOURCE}"/b${A}/a/another
done
mkdir -p "${WORKSOURCE}"/c/a
echo 'test3' > "${WORKSOURCE}"/c/a/file
for A in 1 2 3 4 5 6 7 8 9 10; do
cp -r "${WORKSOURCE}"/c "${WORKSOURCE}"/d${A}
echo 'test2' > "${WORKSOURCE}"/d${A}/a/another
done
2010-08-03 15:13:18 +00:00
echo -e "$CON* waiting for lsyncd to do the job.$COFF"
2010-08-03 15:03:42 +00:00
sleep 20s
2010-08-03 15:13:18 +00:00
echo -e "$CON* killing lsyncd$COFF"
LSYNCPID=$(cat "${PIDFILE}")
if ! kill "${LSYNCPID}"; then
cat "${LOGFILE}"
diff -urN "${WORKSOURCE}" "${WORKTARGET}" || true
echo "kill failed"
exit 1
fi
sleep 1s
2010-08-03 14:24:46 +00:00
#echo "log file contents"
#cat "${LOGFILE}"
##this should be grep.
2010-08-03 15:13:18 +00:00
echo -e "$CON* differences$COFF"
diff -urN "${WORKSOURCE}" "${WORKTARGET}"
2010-08-03 15:03:42 +00:00
rm "${PIDFILE}"
rm "${LOGFILE}"
rm -rf "${WORKTARGET}"
rm -rf "${WORKSOURCE}"
2010-08-03 15:13:18 +00:00