mirror of
https://github.com/octoleo/lsyncd.git
synced 2025-01-22 14:48:29 +00:00
64 lines
1.5 KiB
Bash
Executable File
64 lines
1.5 KiB
Bash
Executable File
#!/bin/bash
|
|
set -e
|
|
CON="\E[47;34m"
|
|
COFF="\033[0m"
|
|
|
|
echo -e "$CON************************************************************$COFF"
|
|
echo -e "$CON** Testing the case of directory being moved and removed. **$COFF"
|
|
echo -e "$CON************************************************************$COFF"
|
|
|
|
WORKSOURCE=$(mktemp -d)
|
|
WORKTARGET=$(mktemp -d)
|
|
PIDFILE=$(mktemp)
|
|
LOGFILE=$(mktemp)
|
|
|
|
echo $WORKSOURCE
|
|
echo $WORKTARGET
|
|
echo $PIDFILE
|
|
|
|
echo -e "$CON* populating the filesystem.$COFF"
|
|
mkdir "${WORKSOURCE}"/a
|
|
mkdir "${WORKSOURCE}"/b
|
|
touch "${WORKSOURCE}"/a/f
|
|
touch "${WORKSOURCE}"/b/g
|
|
|
|
echo -e "$CON* starting lsyncd.$COFF"
|
|
./lsyncd --no-daemon --logfile "${LOGFILE}" --pidfile "${PIDFILE}" "${WORKSOURCE}" "${WORKTARGET}"&
|
|
LSYNCPID=$(cat "${PIDFILE}")
|
|
|
|
echo -e "$CON* waiting for lsyncd to start.$COFF"
|
|
sleep 4s
|
|
|
|
# move a file
|
|
echo -e "$CON* moving a directory$COFF"
|
|
mv "${WORKSOURCE}"/a "${WORKSOURCE}"/c
|
|
|
|
echo -e "$CON* creating a file there$COFF"
|
|
touch "${WORKSOURCE}"/c/h
|
|
|
|
echo -e "$CON* and deleting a directory$COFF"
|
|
rm -r "${WORKSOURCE}"/b
|
|
|
|
echo -e "$CON* waiting for lsyncd to do the job.$COFF"
|
|
sleep 20s
|
|
|
|
echo -e "$CON* killing lsyncd$COFF"
|
|
if ! kill "${LSYNCPID}"; then
|
|
cat "${LOGFILE}"
|
|
diff -ur "${WORKSOURCE}" "${WORKTARGET}" || true
|
|
echo "kill failed"
|
|
exit 1
|
|
fi
|
|
sleep 1s
|
|
|
|
echo -e "$CON* log file contents$COFF"
|
|
cat "${LOGFILE}"
|
|
|
|
echo -e "$CON* differences$COFF"
|
|
diff -ur "${WORKSOURCE}" "${WORKTARGET}"
|
|
|
|
rm "${PIDFILE}"
|
|
rm "${LOGFILE}"
|
|
rm -rf "${WORKTARGET}"
|
|
rm -rf "${WORKSOURCE}"
|