#!/bin/sh # # aegis - project change supervisor # Copyright (C) 2004 Walter Franzini; # All rights reserved. # Copyright (C) 2007, 2008 Peter Miller # # 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 3 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, see # . # unset AEGIS_PROJECT unset AEGIS_CHANGE unset AEGIS_PATH unset AEGIS umask 022 LINES=24 export LINES COLS=80 export COLS USER=${USER:-${LOGNAME:-`whoami`}} work=${AEGIS_TMP:-/tmp}/$$ 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=-1 export AEGIS_THROTTLE here=`pwd` if test $? -ne 0 ; then exit 2; fi if test "$1" != "" ; then bin="$here/$1/bin"; else bin="$here/bin"; fi # # set the path, so that the aegis command that aepatch/aedist invokes # is from the same test set as the aepatch/aedist command itself. # PATH=${bin}:$PATH export PATH # # We need fhist in order to try the ${basename} substitution. Using # RCS as the history tool does not require the ${basename} # substituition. # if fhist -version > /dev/null 2>&1 then : else echo '' echo ' The "fhist" program is not in your command search PATH.' echo ' This test is therefore -assumed- to pass.' echo '' exit 0 fi pass() { set +x echo PASSED 1>&2 cd $here find $work -type d -user $USER -exec chmod u+w {} \; rm -rf $work exit 0 } fail() { set +x echo "FAILED test of the basename functionality ($activity)" 1>&2 cd $here find $work -type d -user $USER -exec chmod u+w {} \; rm -rf $work echo $work exit 1 } no_result() { set +x echo "NO RESULT when testing the basename functionality ($activity)" 1>&2 cd $here find $work -type d -user $USER -exec chmod u+w {} \; rm -rf $work exit 2 } trap \"no_result\" 1 2 3 15 activity="create test directory 109" 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 "c++", as # discovered by the configure script, create a shell script called # "c++" which invokes the correct C++ compiler. Make sure the current # directory is in the path, so that it will be invoked. # if test "$CXX" != "c++" then cat >> $work/c++ << fubar #!/bin/sh exec ${CXX-g++} \$* fubar if test $? -ne 0 ; then no_result; fi chmod a+rx $work/c++ if test $? -ne 0 ; then no_result; fi PATH=${work}:${PATH} export PATH fi # # use the built-in error messages # AEGIS_MESSAGE_LIBRARY=$work/no-such-dir export AEGIS_MESSAGE_LIBRARY unset LANG unset LANGUAGE # # test the aedist/aemv functionality # workproj=$work/proj workchan=$work/chan AEGIS_PATH=$work/lib ; export AEGIS_PATH AEGIS_PROJECT=example ; export AEGIS_PROJECT # # make a new project # activity="new project 165" $bin/aegis -npr $AEGIS_PROJECT -vers "" -dir $workproj > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # change project attributes # activity="project attributes 172" cat > tmp << 'end' description = "A bogus project created to test the basename substitution " "functionality."; developer_may_review = true; developer_may_integrate = true; reviewer_may_integrate = true; default_test_exemption = true; end if test $? -ne 0 ; then no_result; fi $bin/aegis -pa -f tmp > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # add the staff # activity="staff 188" $bin/aegis -nd $USER > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi $bin/aegis -nrv $USER > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi $bin/aegis -ni $USER > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # -------------------------------------------------------------------------- # # create a new change # activity="new change 201" cat > tmp << 'end' brief_description = "The first change"; cause = internal_bug; end if test $? -ne 0 ; then no_result; fi $bin/aegis -nc 1 -f tmp -p example > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # begin development of a change # $bin/aegis -db 1 -dir $workchan > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # add a new files to the change # activity="new files 220" $bin/aegis -nf $workchan/bogus1 -nl \ --uuid aaaaaaaa-bbbb-4bbb-8ccc-ccccddddddd1 > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi $bin/aegis -nf $workchan/bogus2 -nl \ --uuid aaaaaaaa-bbbb-4bbb-8ccc-ccccddddddd2 > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi $bin/aegis -nf $workchan/aegis.conf -nl \ --uuid aaaaaaaa-bbbb-4bbb-8ccc-ccccddddddd3 > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi cat > $workchan/bogus1 << 'end' bogus1, line 1 end if test $? -ne 0 ; then no_result; fi cat > $workchan/bogus2 << 'end' line one line two line three end if test $? -ne 0 ; then no_result; fi cat > $workchan/aegis.conf << 'end' build_command = "exit 0"; link_integration_directory = true; history_create_command = "fhist ${quote ${basename $input}} -cr -cu -i ${quote $input} \ -p ${quote ${dirname $history}} -r"; history_get_command = "fhist ${quote ${basename $history}} -e ${quote $e} \ -o ${quote $output} -p ${quote ${dirname $history}}"; history_put_command = "fhist ${quote ${basename $input}} -cr -cu -i ${quote $input} \ -p ${quote ${dirname $history}} -r"; history_query_command = "fhist ${quote ${basename $history}} -l 0 \ -p ${quote ${dirname $history}} -q"; diff_command = "set +e; diff $orig $i > $out; test $$? -le 1"; merge_command = "(diff3 -e $i $orig $mr | sed -e '/^w$$/d' -e '/^q$$/d'; \ echo '1,$$p' ) | ed - $i > $out"; patch_diff_command = "set +e; diff -C0 -L $index -L $index $orig $i > $out; \ test $$? -le 1"; end if test $? -ne 0 ; then no_result; fi # # build the change # activity="build 269" $bin/aegis -build -nl -v > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # difference the change # activity="diff 276" $bin/aegis -diff > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # finish development of the change # activity="develop end 283" $bin/aegis -de > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # pass the review # activity="review pass 290" $bin/aegis -rpass -c 1 > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # start integrating # activity="integrate begin 297" $bin/aegis -ib 1 > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # integrate build # activity="build 304" $bin/aegis -b -c 1 -nl -v > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # integrate diff # activity="diff 311" $bin/aegis -diff -c 1 -nl -v > log 2>&1 if test $? -ne 0 ; then cat log; no_result; fi # # pass the integration # activity="integrate pass 318" $bin/aegis -intpass -c 1 \ -nl > log 2>&1 if test $? -ne 0 ; then cat log; fail; fi pass