#!/bin/sh # # aegis - project change supervisor # Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998 Peter Miller; # All rights reserved. # # 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., 59 Temple Place, Suite 330, Boston, MA 02111, USA. # # MANIFEST: Test 'aegis -DIFFerence' when the edit number is out-of-date. # # The bug results in a string of length 0 being passed. # unset AEGIS_PROJECT unset AEGIS_CHANGE unset AEGIS_PATH unset AEGIS unset LINES unset COLS umask 022 USER=${USER:-${LOGNAME:-`whoami`}} PAGER=cat export PAGER AEGIS_FLAGS="delete_file_preference = no_keep; \ lock_wait_preference = always; \ diff_preference = automatic_merge; \ pager_preference = never; \ persevere_preference = all; \ log_file_preference = never;" export AEGIS_FLAGS AEGIS_THROTTLE=2 export AEGIS_THROTTLE work=${AEGIS_TMP:-/tmp}/$$ here=`pwd` if test $? -ne 0; then exit 2; fi if test "$1" != "" ; then bin="$here/$1/bin"; else bin="$here/bin"; fi no_result() { set +x echo "NO RESULT for test of 'aegis -DIFFerence' when the edit number is out-of-date ($activity)" 1>&2 cd $here find $work -type d -user $USER -exec chmod u+w {} \; rm -rf $work exit 2 } fail() { set +x echo "FAILED test of 'aegis -DIFFerence' when the edit number is out-of-date ($activity)" 1>&2 cd $here find $work -type d -user $USER -exec chmod u+w {} \; rm -rf $work exit 1 } pass() { set +x echo PASSED 1>&2 cd $here find $work -type d -user $USER -exec chmod u+w {} \; rm -rf $work exit 0 } trap "no_result" 1 2 3 15 # # some variable to make things earier to read # worklib=$work/lib workproj=$work/foo.proj workchan=$work/foo.chan workchan3=$work/foo.chan3 tmp=$work/tmp # # make the directories # activity="working directory 82" mkdir $work $work/lib if test $? -ne 0 ; then no_result; fi chmod 777 $work/lib if test $? -ne 0 ; then no_result; fi cd $work if test $? -ne 0 ; then no_result; fi # # use the built-in error messages # AEGIS_MESSAGE_LIBRARY=$work/no-such-dir export AEGIS_MESSAGE_LIBRARY unset LANG unset LANGUAGE # # If the C compiler is called something other than ``cc'', as discovered # by the configure script, create a shell script called ``cc'' which # invokes the correct C compiler. Make sure the current directory is in # the path, so that it will be invoked. # if test "$CC" != "" -a "$CC" != "cc" then cat >> cc << fubar #!/bin/sh exec $CC \$* fubar if test $? -ne 0 ; then no_result; fi chmod a+rx cc if test $? -ne 0 ; then no_result; fi PATH=${work}:${PATH} export PATH fi # # make a new project # and check files it should have made # activity="new project 116" $bin/aegis -newpro foo -version "" -dir $workproj -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # change project attributes # activity="project attributes 123" cat > $tmp << 'end' description = "A bogus project created to test things."; developer_may_review = true; developer_may_integrate = true; reviewer_may_integrate = true; end if test $? -ne 0 ; then no_result; fi $bin/aegis -proatt -f $tmp -proj foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # create a new change # make sure it creates the files it should # activity="new change 137" cat > $tmp << 'end' brief_description = "This change is used to test the aegis functionality \ with respect to change descriptions."; cause = internal_bug; end if test $? -ne 0 ; then no_result; fi $bin/aegis -new_change 1 -f $tmp -project foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # create a second change # make sure it creates the files it should # activity="new change 150" cat > $tmp << 'end' brief_description = "This change was added to make the various listings \ much more interesting."; cause = internal_bug; end $bin/aegis -new_change 2 -f $tmp -project foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # create a third change # activity="new change 162" cat > $tmp << 'end' brief_description = "change three"; cause = internal_bug; end $bin/aegis -new_change 3 -f $tmp -project foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # add a new developer # activity="new developer 173" $bin/aegis -newdev $USER -p foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # begin development of a change # check it made the files it should # activity="develop begin 181" $bin/aegis -devbeg 1 -p foo -dir $workchan -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # add a new files to the change # activity="new file 188" $bin/aegis -new_file $workchan/main.c -nl -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi $bin/aegis -new_file $workchan/config -nl -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi cat > $workchan/main.c << 'end' void main() { exit(0); } end cat > $workchan/config << 'end' build_command = "rm -f foo; cc -o foo -D'VERSION=\"$version\"' main.c"; link_integration_directory = true; history_get_command = "co -u'$e' -p $h,v > $o"; history_create_command = "ci -f -u -m/dev/null -t/dev/null $i $h,v; rcs -U $h,v"; history_put_command = "ci -f -u -m/dev/null -t/dev/null $i $h,v; rcs -U $h,v"; history_query_command = "rlog -r $h,v | awk '/^head:/ {print $$2}'"; diff_command = "set +e; diff $orig $i > $out; test $$? -le 1"; diff3_command = "(diff3 -e $mr $orig $i | sed -e '/^w$$/d' -e '/^q$$/d'; \ echo '1,$$p' ) | ed - $mr > $out"; end if test $? -ne 0 ; then no_result; fi # # create a new test # activity="new test 222" $bin/aegis -nt -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi cat > $workchan/test/00/t0001a.sh << 'end' #!/bin/sh no_result() { echo WHIMPER 1>&2 exit 2 } fail() { echo SHUZBUTT 1>&2 exit 1 } pass() { exit 0 } trap "no_result" 1 2 3 15 # should not complain ./foo if test $? -ne 0; then fail; fi # it probably worked pass end if test $? -ne 0 ; then no_result; fi # # build the change # activity="build 260" $bin/aegis -build -nl -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # difference the change # this is not the diff variant we are testing # activity="diff 267" $bin/aegis -diff -nl -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # test the change # activity="test 274" $bin/aegis -test -nl -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # finish development of the change # activity="develop end 281" $bin/aegis -dev_end -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # add a new reviewer # activity="new reviewer 288" $bin/aegis -newrev $USER -p foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # pass the review # activity="review pass 295" $bin/aegis -review_pass -chan 1 -proj foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # add an integrator # activity="new integrator 302" $bin/aegis -newint $USER -p foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # start integrating # activity="integrate begin 309" $bin/aegis -intbeg 1 -p foo -v -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # integrate build # activity="build 316" $bin/aegis -build -nl -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi activity="test 319" $bin/aegis -test -nl -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # pass the integration # activity="integrate pass 326" $bin/aegis -intpass -nl -v -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # start work on change 2 # activity="develop begin 333" $bin/aegis -devbeg 2 -p foo -v -dir $workchan -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # start work on change 3 # activity="develop begin 340" $bin/aegis -devbeg 3 -p foo -v -dir $workchan3 -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # copy a file into change 2 # activity="copy file 347" $bin/aegis -cp $workchan/main.c -nl -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # copy a file into change 3 # activity="copy file 354" $bin/aegis -cp $workchan3/main.c -nl -v -lib $worklib -c 3 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # change the file # cat > $workchan/main.c << 'end' #include void main(argc, argv) int argc; char **argv; { if (argc != 1) { fprintf(stderr, "usage: %s\n", argv[0]); exit(1); } printf("hello, world\n"); exit(0); } end # # need another test # activity="new test 383" $bin/aegis -nt -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi cat > $workchan/test/00/t0002a.sh << 'end' #!/bin/sh no_result() { echo WHIMPER 1>&2 exit 2 } fail() { echo SHUZBUTT 1>&2 exit 1 } pass() { exit 0 } trap "no_result" 1 2 3 15 ./foo > /dev/null 2>&1 test $? -eq 0 || fail # should have complained ./foo ickky if test $? -ne 1; then fail; fi # it probably worked pass end # # build the change # diff the change (no the variant we are testing) # test the change # activity="build 423" $bin/aegis -b -nl -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi activity="diff 426" $bin/aegis -diff -nl -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi activity="test 429" $bin/aegis -test -nl -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi activity="test baseline 432" $bin/aegis -test -bl -nl -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # end development # review pass # start integrating # activity="develop end 441" $bin/aegis -devend -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi activity="review pass 444" $bin/aegis -revpass -v -c 2 -p foo -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi activity="integrate begin 447" $bin/aegis -intbeg -v -c 2 -p foo -lib $worklib > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # build the integration # test the integration # test the integration against the baseline # activity="build 456" $bin/aegis -b -nl -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi activity="test 459" $bin/aegis -t -nl -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi activity="test baseline 462" $bin/aegis -t -bl -nl -v -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # pass the integration # make sure it create the files, etc # activity="integrate pass 470" $bin/aegis -intpass -nl -lib $worklib -c 2 -p foo > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # difference change 3 # # This is what is being tested: the diff must detect the the file is out # of date, and run the diff3_command. # # should get an exit status of 0, # and the ,D file should have been created # activity="diff 480" $bin/aegis -diff -nl -c 3 -lib $worklib -p foo > log 2>&1 if test $? -ne 0 ; then cat log; fail; fi if test ! -r $workchan3/main.c,D ; then fail; fi # should be no automatic logging if test "`find $work -name 'aegis.log' -print`" != "" ; then no_result; fi # # the things tested in this test, worked # pass