2012-06-04 08:58:05 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# Tests for Serval DNA server operations.
|
|
|
|
#
|
2013-02-06 08:25:31 +00:00
|
|
|
# Copyright 2012 Serval Project, Inc.
|
2012-06-04 08:58:05 +00:00
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License
|
|
|
|
# as published by the Free Software Foundation; either version 2
|
|
|
|
# of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
|
|
|
source "${0%/*}/../testframework.sh"
|
|
|
|
source "${0%/*}/../testdefs.sh"
|
|
|
|
|
|
|
|
setup() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
}
|
|
|
|
|
|
|
|
teardown() {
|
2012-06-26 06:09:20 +00:00
|
|
|
get_servald_server_pidfile && stop_servald_server
|
2012-06-04 08:58:05 +00:00
|
|
|
kill_all_servald_processes
|
|
|
|
assert_no_servald_processes
|
|
|
|
}
|
|
|
|
|
2013-12-16 04:24:16 +00:00
|
|
|
# make sure servald config is blank
|
|
|
|
configure_servald_server() {
|
|
|
|
:
|
|
|
|
}
|
|
|
|
|
2012-06-26 06:09:20 +00:00
|
|
|
doc_StartCreateInstanceDir="Starting server creates instance directory"
|
|
|
|
setup_StartCreateInstanceDir() {
|
2012-06-04 08:58:05 +00:00
|
|
|
setup
|
|
|
|
assert [ ! -d "$SERVALINSTANCE_PATH" ]
|
|
|
|
}
|
2012-06-26 06:09:20 +00:00
|
|
|
test_StartCreateInstanceDir() {
|
|
|
|
executeOk $servald start
|
2012-06-04 08:58:05 +00:00
|
|
|
assert [ -d "$SERVALINSTANCE_PATH" ]
|
2012-06-26 06:09:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
doc_StartLogfile="Starting server gives no errors"
|
|
|
|
setup_StartLogfile() {
|
|
|
|
setup
|
2013-04-05 04:58:54 +00:00
|
|
|
executeOk_servald config set log.file.directory_path "$PWD/log"
|
2012-06-26 06:09:20 +00:00
|
|
|
}
|
|
|
|
test_StartLogfile() {
|
2013-12-16 04:24:16 +00:00
|
|
|
start_servald_server
|
|
|
|
assert_servald_server_no_errors
|
2012-06-26 06:09:20 +00:00
|
|
|
}
|
|
|
|
|
2012-12-04 07:52:26 +00:00
|
|
|
doc_StartNoInterfaces="Starting server with no configured interfaces gives warning"
|
2012-06-26 06:09:20 +00:00
|
|
|
setup_StartNoInterfaces() {
|
|
|
|
setup
|
|
|
|
}
|
|
|
|
test_StartNoInterfaces() {
|
|
|
|
start_servald_server
|
|
|
|
sleep 0.1
|
2012-12-04 07:52:26 +00:00
|
|
|
assertGrep --message="log contains 'no interfaces' warning" "$instance_servald_log" '^WARN:.*interfaces'
|
2012-06-26 06:09:20 +00:00
|
|
|
tfw_cat "$instance_servald_log"
|
|
|
|
}
|
|
|
|
|
2013-12-16 04:24:16 +00:00
|
|
|
doc_StartNoErrors="Starting server on dummy file interface gives no errors"
|
2012-06-26 06:09:20 +00:00
|
|
|
setup_StartNoErrors() {
|
|
|
|
setup
|
2013-12-16 04:24:16 +00:00
|
|
|
add_servald_interface --file
|
2012-06-26 06:09:20 +00:00
|
|
|
}
|
|
|
|
test_StartNoErrors() {
|
|
|
|
start_servald_server
|
2013-12-16 04:24:16 +00:00
|
|
|
wait_until grep "Interface .* is up" $instance_servald_log
|
|
|
|
assert_servald_server_no_errors
|
|
|
|
tfw_cat "$instance_servald_log"
|
|
|
|
}
|
|
|
|
|
|
|
|
doc_StartLocalNoErrors="Starting server on local interface gives no errors"
|
|
|
|
setup_StartLocalNoErrors() {
|
|
|
|
setup
|
|
|
|
add_servald_interface
|
|
|
|
}
|
|
|
|
test_StartLocalNoErrors() {
|
|
|
|
start_servald_server
|
|
|
|
wait_until grep "Interface .* is up" $instance_servald_log
|
2012-06-22 07:48:14 +00:00
|
|
|
assert_servald_server_no_errors
|
2012-06-22 08:02:42 +00:00
|
|
|
tfw_cat "$instance_servald_log"
|
2012-06-04 08:58:05 +00:00
|
|
|
}
|
|
|
|
|
2012-06-26 06:39:22 +00:00
|
|
|
doc_StartStart="Start server while already running"
|
|
|
|
setup_StartStart() {
|
|
|
|
setup
|
|
|
|
start_servald_server
|
|
|
|
}
|
|
|
|
test_StartStart() {
|
|
|
|
execute --exit-status=10 $servald start
|
2012-10-09 03:02:49 +00:00
|
|
|
extract_stdout_keyvalue start_instance_path 'instancepath' '.*'
|
|
|
|
extract_stdout_keyvalue start_pid 'pid' '[0-9]\+'
|
2012-06-26 06:39:22 +00:00
|
|
|
assert [ "$start_instance_path" = "$SERVALINSTANCE_PATH" ]
|
|
|
|
assert [ "$servald_pid" = "$start_pid" ]
|
|
|
|
}
|
|
|
|
|
|
|
|
doc_StartStopFast="Stop server before it finishes starting"
|
|
|
|
setup_StartStopFast() {
|
2012-06-26 06:09:20 +00:00
|
|
|
setup
|
|
|
|
export SERVALD_SERVER_START_DELAY=250
|
|
|
|
}
|
2012-06-26 06:39:22 +00:00
|
|
|
test_StartStopFast() {
|
2012-06-26 06:09:20 +00:00
|
|
|
start_servald_server
|
|
|
|
stop_servald_server
|
|
|
|
}
|
|
|
|
|
2012-10-08 06:43:17 +00:00
|
|
|
doc_NoZombie="Server process does not become a zombie"
|
|
|
|
setup_NoZombie() {
|
|
|
|
setup
|
|
|
|
export SERVALD_START_POST_SLEEP=1000
|
|
|
|
servald_start &
|
|
|
|
start_pid=$!
|
|
|
|
wait_until get_servald_server_pidfile servald_pid
|
|
|
|
assert kill -0 $start_pid
|
|
|
|
}
|
|
|
|
test_NoZombie() {
|
|
|
|
tfw_log "Before kill -KILL $servald_pid"
|
|
|
|
ps -l $start_pid $servald_pid
|
|
|
|
assert kill -KILL $servald_pid
|
|
|
|
tfw_log "After kill -KILL $servald_pid"
|
|
|
|
ps -l $start_pid $servald_pid
|
2013-01-10 01:42:51 +00:00
|
|
|
wait_until --timeout=2 ! kill -0 $servald_pid 2>/dev/null
|
|
|
|
tfw_log "After waiting"
|
|
|
|
ps -l $start_pid $servald_pid
|
|
|
|
assert --message="zombie servald process does not exist" ! kill -0 $servald_pid 2>/dev/null
|
2012-10-08 06:43:17 +00:00
|
|
|
}
|
|
|
|
teardown_NoZombie() {
|
|
|
|
kill -TERM $start_pid
|
|
|
|
kill_all_servald_processes
|
|
|
|
assert_no_servald_processes
|
|
|
|
}
|
|
|
|
|
2012-06-04 08:58:05 +00:00
|
|
|
runTests "$@"
|