version 1.1.1.3.2.1, 2019/02/24 18:56:41 |
version 1.1.1.3.2.2, 2019/06/10 22:04:06 |
|
|
|
# Copyright (C) Internet Systems Consortium, Inc. ("ISC") |
|
# |
|
# This Source Code Form is subject to the terms of the Mozilla Public |
|
# License, v. 2.0. If a copy of the MPL was not distributed with this |
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/. |
|
# |
|
# See the COPYRIGHT file distributed with this work for additional |
|
# information regarding copyright ownership. |
|
|
|
SYSTEMTESTTOP=.. |
|
. $SYSTEMTESTTOP/conf.sh |
|
|
|
RNDCCMD="$RNDC -c $SYSTEMTESTTOP/common/rndc.conf -p ${CONTROLPORT} -s" |
|
|
|
status=0 |
|
n=0 |
|
|
|
n=`expr $n + 1` |
|
echo_i "verifying that named started normally ($n)" |
|
ret=0 |
|
[ -s ns2/named.pid ] || ret=1 |
|
grep "unable to listen on any configured interface" ns2/named.run > /dev/null && ret=1 |
|
grep "another named process" ns2/named.run > /dev/null && ret=1 |
|
if [ $ret != 0 ]; then echo_i "failed"; fi |
|
status=`expr $status + $ret` |
|
|
|
n=`expr $n + 1` |
|
echo_i "verifying that named checks for conflicting named processes ($n)" |
|
ret=0 |
|
(cd ns2; $NAMED -c named-alt2.conf -D runtime-ns2-extra-2 -X named.lock -m record,size,mctx -d 99 -g -U 4 >> named3.run 2>&1 & ) |
|
sleep 2 |
|
grep "another named process" ns2/named3.run > /dev/null || ret=1 |
|
pid=`cat ns2/named3.pid 2>/dev/null` |
|
test "${pid:+set}" = set && $KILL -15 ${pid} >/dev/null 2>&1 |
|
if [ $ret != 0 ]; then echo_i "failed"; fi |
|
status=`expr $status + $ret` |
|
|
|
n=`expr $n + 1` |
|
echo_i "verifying that 'lock-file none' disables process check ($n)" |
|
ret=0 |
|
(cd ns2; $NAMED -c named-alt3.conf -D runtime-ns2-extra-3 -m record,size,mctx -d 99 -g -U 4 >> named4.run 2>&1 & ) |
|
sleep 2 |
|
grep "another named process" ns2/named4.run > /dev/null && ret=1 |
|
pid=`cat ns2/named4.pid 2>/dev/null` |
|
test "${pid:+set}" = set && $KILL -15 ${pid} >/dev/null 2>&1 |
|
if [ $ret != 0 ]; then echo_i "failed"; fi |
|
status=`expr $status + $ret` |
|
|
|
n=`expr $n + 1` |
|
echo_i "checking that named refuses to reconfigure if working directory is not writable ($n)" |
|
ret=0 |
|
copy_setports ns2/named-alt4.conf.in ns2/named.conf |
|
$RNDCCMD 10.53.0.2 reconfig > rndc.out.$n 2>&1 |
|
grep "failed: permission denied" rndc.out.$n > /dev/null 2>&1 || ret=1 |
|
sleep 1 |
|
grep "[^-]directory './nope' is not writable" ns2/named.run > /dev/null 2>&1 || ret=1 |
|
if [ $ret != 0 ]; then echo_i "failed"; fi |
|
status=`expr $status + $ret` |
|
|
|
n=`expr $n + 1` |
|
echo_i "checking that named refuses to reconfigure if managed-keys-directory is not writable ($n)" |
|
ret=0 |
|
copy_setports ns2/named-alt5.conf.in ns2/named.conf |
|
$RNDCCMD 10.53.0.2 reconfig > rndc.out.$n 2>&1 |
|
grep "failed: permission denied" rndc.out.$n > /dev/null 2>&1 || ret=1 |
|
sleep 1 |
|
grep "managed-keys-directory './nope' is not writable" ns2/named.run > /dev/null 2>&1 || ret=1 |
|
if [ $ret != 0 ]; then echo_i "failed"; fi |
|
status=`expr $status + $ret` |
|
|
|
n=`expr $n + 1` |
|
echo_i "checking that named refuses to reconfigure if new-zones-directory is not writable ($n)" |
|
ret=0 |
|
copy_setports ns2/named-alt6.conf.in ns2/named.conf |
|
$RNDCCMD 10.53.0.2 reconfig > rndc.out.$n 2>&1 |
|
grep "failed: permission denied" rndc.out.$n > /dev/null 2>&1 || ret=1 |
|
sleep 1 |
|
grep "new-zones-directory './nope' is not writable" ns2/named.run > /dev/null 2>&1 || ret=1 |
|
if [ $ret != 0 ]; then echo_i "failed"; fi |
|
status=`expr $status + $ret` |
|
|
|
n=`expr $n + 1` |
|
echo_i "checking that named refuses to start if working directory is not writable ($n)" |
|
ret=0 |
|
cd ns2 |
|
$NAMED -c named-alt4.conf -D runtime-ns2-extra-4 -d 99 -g > named4.run 2>&1 & |
|
sleep 2 |
|
grep "exiting (due to fatal error)" named4.run > /dev/null || ret=1 |
|
# pidfile could be in either place depending on whether the directory |
|
# successfully changed. |
|
pid=`cat named.pid 2>/dev/null` |
|
test "${pid:+set}" = set && $KILL -15 ${pid} >/dev/null 2>&1 |
|
pid=`cat ../named.pid 2>/dev/null` |
|
test "${pid:+set}" = set && $KILL -15 ${pid} >/dev/null 2>&1 |
|
cd .. |
|
if [ $ret != 0 ]; then echo_i "failed"; fi |
|
status=`expr $status + $ret` |
|
|
|
n=`expr $n + 1` |
|
echo_i "checking that named refuses to start if managed-keys-directory is not writable ($n)" |
|
ret=0 |
|
cd ns2 |
|
$NAMED -c named-alt5.conf -D runtime-ns2-extra-5 -d 99 -g > named5.run 2>&1 & |
|
sleep 2 |
|
grep "exiting (due to fatal error)" named5.run > /dev/null || ret=1 |
|
# pidfile could be in either place depending on whether the directory |
|
# successfully changed. |
|
pid=`cat named.pid 2>/dev/null` |
|
test "${pid:+set}" = set && $KILL -15 ${pid} >/dev/null 2>&1 |
|
pid=`cat ../named.pid 2>/dev/null` |
|
test "${pid:+set}" = set && $KILL -15 ${pid} >/dev/null 2>&1 |
|
cd .. |
|
if [ $ret != 0 ]; then echo_i "failed"; fi |
|
status=`expr $status + $ret` |
|
|
|
echo_i "exit status: $status" |
|
[ $status -eq 0 ] || exit 1 |