2012-07-13 13:23:48 +00:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
2015-04-23 14:22:20 +00:00
|
|
|
# Copyright (c) 2010 Hudson River Trading LLC
|
2012-07-13 13:23:48 +00:00
|
|
|
# Written by: John H. Baldwin <jhb@FreeBSD.org>
|
|
|
|
# All rights reserved.
|
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions
|
|
|
|
# are met:
|
|
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
|
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
|
|
# documentation and/or other materials provided with the distribution.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
# SUCH DAMAGE.
|
|
|
|
#
|
|
|
|
# $FreeBSD$
|
|
|
|
|
|
|
|
# Various regression tests to run for the 'resolve' command.
|
|
|
|
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=no
|
2012-07-13 13:23:48 +00:00
|
|
|
WORKDIR=work
|
|
|
|
|
|
|
|
usage()
|
|
|
|
{
|
2013-11-12 19:15:06 +00:00
|
|
|
echo "Usage: conflicts.sh [-s script] [-w workdir]"
|
2012-07-13 13:23:48 +00:00
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2013-11-12 19:15:06 +00:00
|
|
|
# Allow the user to specify an alternate work directory or script.
|
|
|
|
COMMAND=etcupdate
|
|
|
|
while getopts "s:w:" option; do
|
2012-07-13 13:23:48 +00:00
|
|
|
case $option in
|
2013-11-12 19:15:06 +00:00
|
|
|
s)
|
|
|
|
COMMAND="sh $OPTARG"
|
|
|
|
;;
|
2012-07-13 13:23:48 +00:00
|
|
|
w)
|
|
|
|
WORKDIR=$OPTARG
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo
|
|
|
|
usage
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
shift $((OPTIND - 1))
|
|
|
|
if [ $# -ne 0 ]; then
|
|
|
|
usage
|
|
|
|
fi
|
|
|
|
|
|
|
|
CONFLICTS=$WORKDIR/conflicts
|
|
|
|
OLD=$WORKDIR/old
|
|
|
|
NEW=$WORKDIR/current
|
|
|
|
TEST=$WORKDIR/test
|
|
|
|
|
|
|
|
# These tests deal with conflicts to a single file. For each test, we
|
|
|
|
# generate a conflict in /etc/login.conf. Each resolve option is tested
|
|
|
|
# to ensure it DTRT.
|
|
|
|
build_login_conflict()
|
|
|
|
{
|
|
|
|
|
|
|
|
rm -rf $OLD $NEW $TEST $CONFLICTS
|
|
|
|
mkdir -p $OLD/etc $NEW/etc $TEST/etc
|
|
|
|
|
|
|
|
# Generate a conflict in /etc/login.conf.
|
|
|
|
cat > $OLD/etc/login.conf <<EOF
|
|
|
|
default:\\
|
|
|
|
:passwd_format=md5:
|
|
|
|
EOF
|
|
|
|
cat > $NEW/etc/login.conf <<EOF
|
|
|
|
default:\\
|
|
|
|
:passwd_format=md5:\\
|
|
|
|
:copyright=/etc/COPYRIGHT
|
|
|
|
EOF
|
|
|
|
cat > $TEST/etc/login.conf <<EOF
|
|
|
|
default:\\
|
|
|
|
:passwd_format=md5:\\
|
|
|
|
:welcome=/etc/motd:
|
|
|
|
EOF
|
|
|
|
|
2013-11-12 19:15:06 +00:00
|
|
|
$COMMAND -r -d $WORKDIR -D $TEST >/dev/null
|
2012-07-13 13:23:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# This is used to verify special handling for /etc/mail/aliases and
|
|
|
|
# the newaliases warning.
|
|
|
|
build_aliases_conflict()
|
|
|
|
{
|
|
|
|
|
|
|
|
rm -rf $OLD $NEW $TEST $CONFLICTS
|
|
|
|
mkdir -p $OLD/etc/mail $NEW/etc/mail $TEST/etc/mail
|
|
|
|
|
|
|
|
# Generate a conflict in /etc/mail/aliases
|
|
|
|
cat > $OLD/etc/mail/aliases <<EOF
|
|
|
|
# root: me@my.domain
|
|
|
|
|
|
|
|
# Basic system aliases -- these MUST be present
|
|
|
|
MAILER-DAEMON: postmaster
|
|
|
|
postmaster: root
|
|
|
|
EOF
|
|
|
|
cat > $NEW/etc/mail/aliases <<EOF
|
|
|
|
# root: me@my.domain
|
|
|
|
|
|
|
|
# Basic system aliases -- these MUST be present
|
|
|
|
MAILER-DAEMON: postmaster
|
|
|
|
postmaster: root
|
|
|
|
|
|
|
|
# General redirections for pseudo accounts
|
|
|
|
_dhcp: root
|
|
|
|
_pflogd: root
|
|
|
|
EOF
|
|
|
|
cat > $TEST/etc/mail/aliases <<EOF
|
|
|
|
root: someone@example.com
|
|
|
|
|
|
|
|
# Basic system aliases -- these MUST be present
|
|
|
|
MAILER-DAEMON: postmaster
|
|
|
|
postmaster: foo
|
|
|
|
EOF
|
|
|
|
|
2013-11-12 19:15:06 +00:00
|
|
|
$COMMAND -r -d $WORKDIR -D $TEST >/dev/null
|
2012-07-13 13:23:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# $1 - relative path to file that should be missing from TEST
|
|
|
|
missing()
|
|
|
|
{
|
|
|
|
if [ -e $TEST/$1 -o -L $TEST/$1 ]; then
|
|
|
|
echo "File $1 should be missing"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# $1 - relative path to file that should be present in TEST
|
|
|
|
present()
|
|
|
|
{
|
|
|
|
if ! [ -e $TEST/$1 -o -L $TEST/$1 ]; then
|
|
|
|
echo "File $1 should be present"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# $1 - relative path to regular file that should be present in TEST
|
|
|
|
# $2 - optional string that should match file contents
|
|
|
|
# $3 - optional MD5 of the flie contents, overrides $2 if present
|
|
|
|
file()
|
|
|
|
{
|
|
|
|
local contents sum
|
|
|
|
|
|
|
|
if ! [ -f $TEST/$1 ]; then
|
|
|
|
echo "File $1 should be a regular file"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
elif [ $# -eq 2 ]; then
|
|
|
|
contents=`cat $TEST/$1`
|
|
|
|
if [ "$contents" != "$2" ]; then
|
|
|
|
echo "File $1 has wrong contents"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
elif [ $# -eq 3 ]; then
|
|
|
|
sum=`md5 -q $TEST/$1`
|
|
|
|
if [ "$sum" != "$3" ]; then
|
|
|
|
echo "File $1 has wrong contents"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# $1 - relative path to a regular file that should have a conflict
|
|
|
|
# $2 - optional MD5 of the conflict file contents
|
|
|
|
conflict()
|
|
|
|
{
|
|
|
|
local sum
|
|
|
|
|
|
|
|
if ! [ -f $CONFLICTS/$1 ]; then
|
|
|
|
echo "File $1 missing conflict"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
elif [ $# -gt 1 ]; then
|
|
|
|
sum=`md5 -q $CONFLICTS/$1`
|
|
|
|
if [ "$sum" != "$2" ]; then
|
|
|
|
echo "Conflict $1 has wrong contents"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# $1 - relative path to a regular file that should no longer have a conflict
|
|
|
|
resolved()
|
|
|
|
{
|
|
|
|
if [ -f $CONFLICTS/$1 ]; then
|
|
|
|
echo "Conflict $1 should be resolved"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
if [ `id -u` -ne 0 ]; then
|
|
|
|
echo "must be root"
|
2014-03-16 02:27:27 +00:00
|
|
|
exit 0
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -r /etc/etcupdate.conf ]; then
|
|
|
|
echo "WARNING: /etc/etcupdate.conf settings may break some tests."
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Test each of the following resolve options: 'p', 'mf', 'tf', 'r'.
|
|
|
|
|
|
|
|
build_login_conflict
|
|
|
|
|
|
|
|
# Verify that 'p' doesn't do anything.
|
|
|
|
echo "Checking 'p':"
|
2013-11-12 19:15:06 +00:00
|
|
|
echo 'p' | $COMMAND resolve -d $WORKDIR -D $TEST >/dev/null
|
2012-07-13 13:23:48 +00:00
|
|
|
|
|
|
|
file /etc/login.conf "" 95de92ea3f1bb1bf4f612a8b5908cddd
|
|
|
|
missing /etc/login.conf.db
|
|
|
|
conflict /etc/login.conf
|
|
|
|
|
|
|
|
# Verify that 'mf' removes the conflict, but does nothing else.
|
|
|
|
echo "Checking 'mf':"
|
2013-11-12 19:15:06 +00:00
|
|
|
echo 'mf' | $COMMAND resolve -d $WORKDIR -D $TEST >/dev/null
|
2012-07-13 13:23:48 +00:00
|
|
|
|
|
|
|
file /etc/login.conf "" 95de92ea3f1bb1bf4f612a8b5908cddd
|
|
|
|
missing /etc/login.conf.db
|
|
|
|
resolved /etc/login.conf
|
|
|
|
|
|
|
|
build_login_conflict
|
|
|
|
|
|
|
|
# Verify that 'tf' installs the new version of the file.
|
|
|
|
echo "Checking 'tf':"
|
2013-11-12 19:15:06 +00:00
|
|
|
echo 'tf' | $COMMAND resolve -d $WORKDIR -D $TEST >/dev/null
|
2012-07-13 13:23:48 +00:00
|
|
|
|
|
|
|
file /etc/login.conf "" 7774a0f9a3a372c7c109c32fd31c4b6b
|
|
|
|
file /etc/login.conf.db
|
|
|
|
resolved /etc/login.conf
|
|
|
|
|
|
|
|
build_login_conflict
|
|
|
|
|
|
|
|
# Verify that 'r' installs the resolved version of the file. To
|
|
|
|
# simulate this, manually edit the merged file so that it doesn't
|
|
|
|
# contain conflict markers.
|
|
|
|
echo "Checking 'r':"
|
|
|
|
cat > $CONFLICTS/etc/login.conf <<EOF
|
|
|
|
default:\\
|
|
|
|
:passwd_format=md5:\\
|
|
|
|
:copyright=/etc/COPYRIGHT\\
|
|
|
|
:welcome=/etc/motd:
|
|
|
|
EOF
|
|
|
|
|
2013-11-12 19:15:06 +00:00
|
|
|
echo 'r' | $COMMAND resolve -d $WORKDIR -D $TEST >/dev/null
|
2012-07-13 13:23:48 +00:00
|
|
|
|
|
|
|
file /etc/login.conf "" 966e25984b9b63da8eaac8479dcb0d4d
|
|
|
|
file /etc/login.conf.db
|
|
|
|
resolved /etc/login.conf
|
|
|
|
|
|
|
|
build_aliases_conflict
|
|
|
|
|
|
|
|
# Verify that 'p' and 'mf' do not generate the newaliases warning.
|
|
|
|
echo "Checking newalias warning for 'p'":
|
2013-11-12 19:15:06 +00:00
|
|
|
echo 'p' | $COMMAND resolve -d $WORKDIR -D $TEST | grep -q newalias
|
2012-07-13 13:23:48 +00:00
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
echo "+ Extra warning"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
echo "Checking newalias warning for 'mf'":
|
2013-11-12 19:15:06 +00:00
|
|
|
echo 'mf' | $COMMAND resolve -d $WORKDIR -D $TEST | grep -q newalias
|
2012-07-13 13:23:48 +00:00
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
echo "+ Extra warning"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Verify that 'tf' and 'r' do generate the newaliases warning.
|
|
|
|
build_aliases_conflict
|
|
|
|
echo "Checking newalias warning for 'tf'":
|
2013-11-12 19:15:06 +00:00
|
|
|
echo 'tf' | $COMMAND resolve -d $WORKDIR -D $TEST | grep -q newalias
|
2012-07-13 13:23:48 +00:00
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
echo "- Missing warning"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
build_aliases_conflict
|
|
|
|
cp $TEST/etc/mail/aliases $CONFLICTS/etc/mail/aliases
|
2013-11-12 19:15:06 +00:00
|
|
|
echo 'r' | $COMMAND resolve -d $WORKDIR -D $TEST | grep -q newalias
|
2012-07-13 13:23:48 +00:00
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
echo "- Missing warning"
|
2014-03-16 02:27:27 +00:00
|
|
|
FAILED=yes
|
2012-07-13 13:23:48 +00:00
|
|
|
fi
|
2014-03-16 02:27:27 +00:00
|
|
|
|
|
|
|
[ "${FAILED}" = no ]
|