#!/bin/sh # # Copyright (c) 2010 Advanced Computing Technologies LLC # Written by: John H. Baldwin # 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. WORKDIR=work usage() { echo "Usage: tests.sh [-w workdir]" exit 1 } # Allow the user to specify an alternate work directory. while getopts "w:" option; do case $option in 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 < $NEW/etc/login.conf < $TEST/etc/login.conf </dev/null } # 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 < $NEW/etc/mail/aliases < $TEST/etc/mail/aliases </dev/null } # $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" 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" 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" elif [ $# -eq 2 ]; then contents=`cat $TEST/$1` if [ "$contents" != "$2" ]; then echo "File $1 has wrong contents" fi elif [ $# -eq 3 ]; then sum=`md5 -q $TEST/$1` if [ "$sum" != "$3" ]; then echo "File $1 has wrong contents" 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" elif [ $# -gt 1 ]; then sum=`md5 -q $CONFLICTS/$1` if [ "$sum" != "$2" ]; then echo "Conflict $1 has wrong contents" 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" fi } if [ `id -u` -ne 0 ]; then echo "must be root" 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':" echo 'p' | sh ./etcupdate.sh resolve -d $WORKDIR -D $TEST >/dev/null 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':" echo 'mf' | sh ./etcupdate.sh resolve -d $WORKDIR -D $TEST >/dev/null 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':" echo 'tf' | sh ./etcupdate.sh resolve -d $WORKDIR -D $TEST >/dev/null 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 </dev/null 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'": echo 'p' | sh ./etcupdate.sh resolve -d $WORKDIR -D $TEST | grep -q newalias if [ $? -eq 0 ]; then echo "+ Extra warning" fi echo "Checking newalias warning for 'mf'": echo 'mf' | sh ./etcupdate.sh resolve -d $WORKDIR -D $TEST | grep -q newalias if [ $? -eq 0 ]; then echo "+ Extra warning" fi # Verify that 'tf' and 'r' do generate the newaliases warning. build_aliases_conflict echo "Checking newalias warning for 'tf'": echo 'tf' | sh ./etcupdate.sh resolve -d $WORKDIR -D $TEST | grep -q newalias if [ $? -ne 0 ]; then echo "- Missing warning" fi build_aliases_conflict cp $TEST/etc/mail/aliases $CONFLICTS/etc/mail/aliases echo 'r' | sh ./etcupdate.sh resolve -d $WORKDIR -D $TEST | grep -q newalias if [ $? -ne 0 ]; then echo "- Missing warning" fi