#!/bin/ksh -p # # Copyright (c) 1992 Diomidis Spinellis. # Copyright (c) 1992, 1993 # The Regents of the University of California. 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. # 3. Neither the name of the University nor the names of its contributors # may be used to endorse or promote products derived from this software # without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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. # # @(#)sed.test 8.1 (Berkeley) 6/6/93 # # $FreeBSD$ # # sed Regression Tests # # The directory regress.test.out contains the expected test results # # These are the regression tests mostly created during the development # of the BSD sed. Each test should have a unique mark name, which is # used for naming the corresponding file in regress.multitest.out. SRCDIR=$(dirname $0) SED=${SED:=/usr/bin/sed} # # Sanitize the environment so we're able to operate with known good # defaults. Note, tests such as 7.1 require that we're in the C locale. # unalias -a export LANG=C typeset -i err=0 typeset -i pass=0 typeset -i fail=0 fatal() { echo "[FATAL] $*" > /dev/stderr exit 1 } main() { REGRESS=${SRCDIR}/regress.multitest.out [[ -d $REGRESS ]] || fatal "Could not locate regress directory" DICT=/usr/share/lib/dict/words [[ -r $DICT ]] || fatal "Coult not read dictionary $DICT" OPDIR=$(mktemp -d) [[ -n "$OPDIR" && -d "$OPDIR" ]] || \ fatal "Could not create output directory" awk 'END { for (i = 1; i < 15; i++) print "l1_" i}' \ $OPDIR/lines1 awk 'END { for (i = 1; i < 10; i++) print "l2_" i}' \ $OPDIR/lines2 [[ -s $OPDIR/lines1 && -s $OPDIR/lines2 ]] || \ fatal "Could not seed lines files" lines1=$OPDIR/lines1 lines2=$OPDIR/lines2 lines3=$OPDIR/lines3 lines4=$OPDIR/lines4 script1=$OPDIR/script1 script2=$OPDIR/script2 exec 4>&1 5>&2 tests exec 1>&4 2>&5 # Remove temporary files rm -rf $OPDIR/ } tests() { MARK=0 test_args test_addr test_group test_acid test_branch test_pattern test_print test_subst test_error # Handle the result of the last test result } # Display a test's result result() { if [ "$TODO" = '1' ] ; then TODO='TODO ' else TODO='' fi if ! [ -r $REGRESS/${TESTNAME} ] ; then echo "Seeding $REGRESS/${TESTNAME} with current result" 1>&2 cp $OPDIR/current.out $REGRESS/${TESTNAME} fi if cmp -s $REGRESS/${TESTNAME} $OPDIR/current.out ; then echo "[PASS] $MARK $TESTNAME # $TODO$OCOMMENT" ((pass++)) else echo "[FAIL] $MARK $TESTNAME # $TODO$OCOMMENT" if [[ -z "$TODO" ]]; then diff -u $REGRESS/${TESTNAME} $OPDIR/current.out ((fail++)) err=1 fi fi 1>&4 2>&5 } # Mark the beginning of each test mark() { [ $MARK -gt 0 ] && result OCOMMENT=$COMMENT MARK=`expr $MARK + 1` TESTNAME=$1 exec 1>&4 2>&5 exec >"$OPDIR/current.out" } test_args() { COMMENT='Argument parsing - first type' mark '1.1' $SED 's/^/e1_/p' $lines1 mark '1.2' ; $SED -n 's/^/e1_/p' $lines1 mark '1.3' $SED 's/^/e1_/p' <$lines1 mark '1.4' ; $SED -n 's/^/e1_/p' <$lines1 COMMENT='Argument parsing - second type' mark '1.4.1' $SED -e '' <$lines1 echo 's/^/s1_/p' >$script1 echo 's/^/s2_/p' >$script2 mark '1.5' $SED -f $script1 $lines1 mark '1.6' $SED -f $script1 <$lines1 mark '1.7' $SED -e 's/^/e1_/p' $lines1 mark '1.8' $SED -e 's/^/e1_/p' <$lines1 mark '1.9' ; $SED -n -f $script1 $lines1 mark '1.10' ; $SED -n -f $script1 <$lines1 mark '1.11' ; $SED -n -e 's/^/e1_/p' $lines1 mark '1.12' $SED -n -e 's/^/e1_/p' <$lines1 mark '1.13' $SED -e 's/^/e1_/p' -e 's/^/e2_/p' $lines1 mark '1.14' $SED -f $script1 -f $script2 $lines1 mark '1.15' $SED -e 's/^/e1_/p' -f $script1 $lines1 mark '1.16' $SED -e 's/^/e1_/p' $lines1 $lines1 # POSIX D11.2:11251 mark '1.17' ; $SED p <$lines1 $lines1 cat >$script1 <$lines3 # GNU and SunOS sed behave differently here mark '7.1' $SED -n l $lines3 mark '7.2' ; $SED -e '/l2_/=' $lines1 $lines2 rm -f $lines4 mark '7.3' ; $SED -e "3,12w $lines4" $lines1 COMMENT='w results' cat $lines4 mark '7.4' ; $SED -e "4r $lines2" $lines1 mark '7.5' ; $SED -e '5r /dev/dds' $lines1 mark '7.6' ; $SED -e '6r /dev/null' $lines1 mark '7.7' $SED '200q' $DICT | $SED 's$.*$s/^/&/w tmpdir/&$' >$script1 rm -rf tmpdir mkdir tmpdir $SED -f $script1 $lines1 cat tmpdir/* rm -rf tmpdir mark '7.8' echo line1 > $lines3 echo "" >> $lines3 $SED -n -e '$p' $lines3 /dev/null } test_subst() { COMMENT='Substitution commands' mark '8.1' ; $SED -e 's/./X/g' $lines1 mark '8.2' ; $SED -e 's,.,X,g' $lines1 # SunOS sed thinks we are escaping . as wildcard, not as separator mark '8.3' $SED -e 's.\..X.g' $lines1 mark '8.4' ; $SED -e 's/[\/]/Q/' $lines1 mark '8.5' ; $SED -e 's_\__X_' $lines1 mark '8.6' ; $SED -e 's/./(&)/g' $lines1 mark '8.7' ; $SED -e 's/./(\&)/g' $lines1 mark '8.8' ; $SED -e 's/\(.\)\(.\)\(.\)/x\3x\2x\1/g' $lines1 mark '8.9' ; $SED -e 's/_/u0\ u1\ u2/g' $lines1 mark '8.10' $SED -e 's/./X/4' $lines1 rm -f $lines4 mark '8.11' ; $SED -e "s/1/X/w $lines4" $lines1 COMMENT='s wfile results' cat $lines4 mark '8.12' ; $SED -e 's/[123]/X/g' $lines1 mark '8.13' ; $SED -e 'y/0123456789/9876543210/' $lines1 mark '8.14' ; $SED -e 'y10\123456789198765432\101' $lines1 mark '8.15' ; $SED -e '1N;2y/\n/X/' $lines1 mark '8.16' echo 'eeefff' | $SED -e ' p s/e/X/p :x s//Y/p # Establish limit counter in the hold space # GNU sed version 3.02 enters into an infinite loop here x /.\{10\}/ { s/.*/ERROR/ b } s/.*/&./ x /f/bx ' # POSIX does not say that this should work, # but it does for GNU, BSD, and SunOS mark '8.17' ; $SED -e 's/[/]/Q/' $lines1 COMMENT='[ as an s delimiter and its escapes' mark '8.18' ; $SED -e 's[_[X[' $lines1 # This is a matter of interpretation # POSIX 1003.1, 2004 says "Within the BRE and the replacement, # the BRE delimiter itself can be used as a *literal* character # if it is preceded by a backslash" # SunOS 5.1 /usr/bin/sed and Mac OS X follow the literal POSIX # interpretation. # GNU sed version 4.1.5 treats \[ as the beginning of a character # set specification (both with --posix and without). mark '8.19' ; $SED 's/l/[/' $lines1 | $SED -e 's[\[.[X[' mark '8.20' ; $SED 's/l/[/' $lines1 | $SED -e 's[\[.[X\[[' COMMENT='\\ in y command' mark '8.21' echo 'a\\b(c' | \ $SED 'y%ABCDEFGHIJKLMNOPQRSTUVWXYZ, /\\()"%abcdefghijklmnopqrstuvwxyz,------%' COMMENT='\\n in a character class' mark '8.22' ; (echo 1; echo 2) | $SED -n '1{;N;s/[\n]/X/;p;}' COMMENT='\\n in a BRE' mark '8.23' ; (echo 1; echo 2) | $SED -n '1{;N;s/\n/X/;p;}' } test_error() { COMMENT='Error cases' mark '9.1' ; $SED -x 2>/dev/null ; echo $? mark '9.2' ; $SED -f 2>/dev/null ; echo $? mark '9.3' ; $SED -e 2>/dev/null ; echo $? mark '9.4' ; $SED -f /dev/xyzzyxyzy 2>/dev/null ; echo $? mark '9.5' ; $SED p /dev/xyzzyxyzy 2>/dev/null ; echo $? mark '9.6' ; $SED -f /bin/sh 2>/dev/null ; echo $? mark '9.7' ; $SED '{' 2>/dev/null ; echo $? mark '9.8' ; $SED '{' 2>/dev/null ; echo $? mark '9.9' ; $SED '/hello/' 2>/dev/null ; echo $? mark '9.10' ; $SED '1,/hello/' 2>/dev/null ; echo $? mark '9.11' ; $SED -e '-5p' 2>/dev/null ; echo $? mark '9.12' ; $SED '/jj' 2>/dev/null ; echo $? mark '9.13' ; $SED 'a hello' 2>/dev/null ; echo $? mark '9.14' ; $SED 'a \ hello' 2>/dev/null ; echo $? mark '9.15' ; $SED 'b foo' 2>/dev/null ; echo $? mark '9.16' ; $SED 'd hello' 2>/dev/null ; echo $? mark '9.17' ; $SED 's/aa' 2>/dev/null ; echo $? mark '9.18' ; $SED 's/aa/' 2>/dev/null ; echo $? mark '9.19' ; $SED 's/a/b' 2>/dev/null ; echo $? mark '9.20' ; $SED 's/a/b/c/d' 2>/dev/null ; echo $? mark '9.21' ; $SED 's/a/b/ 1 2' 2>/dev/null ; echo $? mark '9.22' ; $SED 's/a/b/ 1 g' 2>/dev/null ; echo $? mark '9.23' ; $SED 's/a/b/w' 2>/dev/null ; echo $? mark '9.24' ; $SED 'y/aa' 2>/dev/null ; echo $? mark '9.25' ; $SED 'y/aa/b/' 2>/dev/null ; echo $? mark '9.26' ; $SED 'y/aa/' 2>/dev/null ; echo $? mark '9.27' ; $SED 'y/a/b' 2>/dev/null ; echo $? mark '9.28' ; $SED 'y/a/b/c/d' 2>/dev/null ; echo $? mark '9.29' ; $SED '!' 2>/dev/null ; echo $? mark '9.30' ; $SED supercalifrangolisticexprialidociussupercalifrangolisticexcius 2>/dev/null ; echo $? mark '9.31' ; $SED '' /dev/null 2>/dev/null ; echo $? } main echo "Pass/fail - $pass/$fail" exit $err