some more files

This commit is contained in:
Axel Kittenberger 2008-10-06 20:35:52 +00:00
parent 742789e258
commit be93533418
7 changed files with 123 additions and 11 deletions

View File

@ -1,2 +1,4 @@
Axel Kittenberger <axel.kittenberger@univie.ac.at> Axel Kittenberger <axel.kittenberger@univie.ac.at>
Jürgen "README" Mangler <juergen.mangler@univie.ac.at> Jürgen "README" Mangler <juergen.mangler@univie.ac.at>
Eugene Sanivsky <eugenesan@gmail.com>
Junichi Uekawa <dancerj@gmail.com>

View File

@ -1,6 +1,10 @@
## Makefile.am -- Process this file with automake to produce Makefile.in ## Makefile.am -- Process this file with automake to produce Makefile.in
bin_PROGRAMS = lsyncd bin_PROGRAMS = lsyncd
lsyncd_SOURCES = lsyncd.c lsyncd_SOURCES = lsyncd.c
TESTS = tests/help.sh \
tests/version.sh \
tests/wrong-logfile.sh \
tests/wrong-rsync.sh
datarootdir = @datarootdir@ datarootdir = @datarootdir@

View File

@ -7,6 +7,7 @@
* Eugene Sanivsky <eugenesan@gmail.com> * Eugene Sanivsky <eugenesan@gmail.com>
*/ */
#include "config.h" #include "config.h"
#define _GNU_SOURCE
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
@ -292,6 +293,49 @@ void *s_realloc(void *ptr, size_t size)
return r; return r;
} }
/**
* "secured" strdup.
*/
char *s_strdup(const char* src)
{
char *s = strdup(src);
if (s == NULL) {
printlogf(LOG_ERROR, "Out of memory!");
exit(-1);
}
return s;
}
/**
* Returns the canonicalized path of a directory with a final '/',
* Makes sure it is a directory.
*/
char *realdir(const char * dir)
{
char* cs = canonicalize_file_name(dir);
if (cs == NULL) {
return NULL;
}
if (strlen(cs) + 2 >= MAX_PATH) {
// at systems maxpath already, we cannot add a '/' anyway.
return NULL;
}
struct stat st;
stat(cs, &st);
if (!S_ISDIR(st.st_mode)) {
free(cs);
return NULL;
}
strcat(cs, '/');
return cs;
}
/** /**
* Calls rsync to sync from src to dest. * Calls rsync to sync from src to dest.
* Returns after rsync has finished. * Returns after rsync has finished.
@ -338,9 +382,10 @@ bool rsync(char const * src, const char * dest, bool recursive)
waitpid(pid, &status, 0); waitpid(pid, &status, 0);
assert(WIFEXITED(status)); assert(WIFEXITED(status));
if (WEXITSTATUS(status)){ if (WEXITSTATUS(status)){
printlogf(LOG_ERROR, "Forked rsync process returned non-zero return code"); printlogf(LOG_ERROR, "Forked rsync process returned non-zero return code: %i", WEXITSTATUS(status));
//TODO: dispute, to we really want to terminate in this case? //TODO: really philosophize a little more what to do when rsync fails.
//exit(-1); // this could also be just a temp. network error while running.
exit(-1);
} }
printlogf(LOG_DEBUG, "Rsync of [%s] -> [%s] finished", src, dest); printlogf(LOG_DEBUG, "Rsync of [%s] -> [%s] finished", src, dest);
@ -833,14 +878,17 @@ bool parse_options(int argc, char **argv)
} }
if (!strcmp("logfile", long_options[oi].name)) { if (!strcmp("logfile", long_options[oi].name)) {
logfile = s_malloc(strlen(optarg) + 1); logfile = s_strdup(optarg);
strcpy(logfile, optarg);
} }
if (!strcmp("exclude-from", long_options[oi].name)) { if (!strcmp("exclude-from", long_options[oi].name)) {
exclude_file = s_malloc(strlen(optarg) + 1); exclude_file = s_strdup(optarg);
strcpy(exclude_file, optarg);
} }
if (!strcmp("rsync-binary", long_options[oi].name)) {
rsync_binary = s_strdup(optarg);
}
} }
} }
@ -849,10 +897,16 @@ bool parse_options(int argc, char **argv)
exit(-1); exit(-1);
} }
option_source = argv[optind]; /* Resolves relative source path, lsyncd might chdir to / later. */
option_source = realdir(argv[optind]);
option_target = argv[optind + 1]; option_target = argv[optind + 1];
printf("syncing %s -> %s\n", option_source, option_target);
if (!option_source) {
printf("Error: Source [%s] not found or not a directory.\n", argv[optind]);
exit(-1);
}
printlogf(LOG_NORMAL, "syncing %s -> %s\n", option_source, option_target);
return true; return true;
} }
@ -963,7 +1017,7 @@ int main(int argc, char **argv)
rsync(option_source, option_target, true); rsync(option_source, option_target, true);
} }
printlogf(LOG_NORMAL, "--- Entering normal operation with [%d] monitored directories ---", dir_watch_num); printlogf(LOG_NORMAL, "--- Entering normal operation with [%d] monitored directories ---", dir_watch_num);
signal(SIGTERM, catch_alarm); signal(SIGTERM, catch_alarm);
master_loop(); master_loop();

11
tests/help.sh Normal file
View File

@ -0,0 +1,11 @@
#!/bin/bash
# copyright 2008 Junichi Uekawa <dancer@debian.org>
# licensed under GPLv2 or later, see the file ../COPYING for details.
# test that --help outputs help message and exit code of 0
set -e
set -o pipefail
# assume that USAGE being in output is good enough.
./lsyncd --help | grep '^USAGE:'

11
tests/version.sh Normal file
View File

@ -0,0 +1,11 @@
#!/bin/bash
# copyright 2008 Junichi Uekawa <dancer@debian.org>
# licensed under GPLv2 or later, see the file ../COPYING for details.
# test that --version outputs some kind of version message and exit code of 0
set -e
set -o pipefail
./lsyncd --version | grep '^Version: '

14
tests/wrong-logfile.sh Normal file
View File

@ -0,0 +1,14 @@
#!/bin/bash
# copyright 2008 Junichi Uekawa <dancer@debian.org>
# licensed under GPLv2 or later, see the file ../COPYING for details.
# make sure wrong logfile specification gives a reasonable error
# message
WORKTARGET=$(mktemp -d)
if [[ $( ./lsyncd --logfile /nonexisting/path/name . "${WORKTARGET}" ) =~ "cannot open logfile" ]]; then
rmdir "${WORKTARGET}"
exit 0;
else
exit 1;
fi

16
tests/wrong-rsync.sh Normal file
View File

@ -0,0 +1,16 @@
#!/bin/bash
# copyright 2008 Junichi Uekawa <dancer@debian.org>
# licensed under GPLv2 or later, see the file ../COPYING for details.
# make sure that program exits with exit code of -1 when rsync path is
# wrong.
WORKTARGET=$(mktemp -d)
./lsyncd --no-daemon --rsync-binary /wrong/path/to/rsync . "${WORKTARGET}"
if [[ $? = 255 ]]; then
rmdir "${WORKTARGET}"
exit 0;
else
exit 1;
fi