Difference between revisions of "Testsuite Machines"
Line 1: | Line 1: | ||
− | This page contains notes and instructions for people running the ET testsuites on various different machines. If you have experience running testsuites on a machine which is not listed here, please consider adding some information which might help others (or yourself!) in future. | + | This page contains notes and instructions for people running the ET testsuites on various different machines. If you have experience running testsuites on a machine which is not listed here, please consider adding some information which might help others (or yourself!) in future. |
=General= | =General= | ||
Line 10: | Line 10: | ||
chmod a+x GetComponents | chmod a+x GetComponents | ||
./GetComponents --root=. -a https://svn.einsteintoolkit.org/manifest/trunk/einsteintoolkit.th | ./GetComponents --root=. -a https://svn.einsteintoolkit.org/manifest/trunk/einsteintoolkit.th | ||
− | |||
cp udb.example.pm udb.pm | cp udb.example.pm udb.pm | ||
− | + | Replace "redshift" with the name of your local machine, unless you are running on one of the supported machines. | |
− | + | Replace YOUR_LOGIN, YOUR_EMAIL_ADDRESS and YOUR_ALLOCATION as appropriate. | |
− | + | Set sourcebasedir for your local machine to be the directory containing etrelease (do not set it to etrelease itself). | |
− | + | Set your username on each machine: | |
set_option 'MACHINE' , 'user', 'USERNAME'; | set_option 'MACHINE' , 'user', 'USERNAME'; | ||
+ | |||
+ | See the machine-specific notes below for any additional steps for each machine. | ||
+ | |||
+ | touch par/testsuite.par | ||
+ | sim sync <machine> | ||
+ | sim build --thornlist manifest/einsteintoolkit.th --scriptfile <machine>-testsuite.sh | ||
+ | |||
+ | sim remote <machine> create-submit par/testsuite.par NSLOTS 6:00:00 | ||
+ | |||
+ | This is a dummy parameter file. | ||
+ | |||
+ | When the job is finished, you should have the required <machine>_i_j.log files in machine:etrelease/*.log. The testsuite output will also be stored in machine:TEST_XXX, where XXX is constructed from the date at which the job was run. | ||
+ | |||
+ | Update the testsuite status page by adding the log files to the release-info repository: | ||
+ | |||
+ | svn co https://svn.einsteintoolkit.org/www/release-info | ||
+ | cd release-info | ||
+ | scp machine:etrelease/*.log . | ||
+ | |||
+ | Then commit the new/updated files. | ||
=Machines= | =Machines= | ||
Line 40: | Line 59: | ||
Copy kraken.sh as kraken-testsuite.sh in simfactory/scriptfiles. Replace the aprun command with the following: | Copy kraken.sh as kraken-testsuite.sh in simfactory/scriptfiles. Replace the aprun command with the following: | ||
+ | <pre> | ||
cd @SOURCEDIR@ | cd @SOURCEDIR@ | ||
Line 65: | Line 85: | ||
mv TEST $test_dir/TEST.$i | mv TEST $test_dir/TEST.$i | ||
done | done | ||
− | + | </pre> | |
− | |||
==Datura== | ==Datura== | ||
Line 72: | Line 91: | ||
Copy datura.sh as datura-testsuite.sh in simfactory/scriptfiles. Replace the mpirun command with the following: | Copy datura.sh as datura-testsuite.sh in simfactory/scriptfiles. Replace the mpirun command with the following: | ||
− | + | <pre> | |
cd @SOURCEDIR@ | cd @SOURCEDIR@ | ||
Line 99: | Line 118: | ||
mv TEST $test_dir/TEST.$i | mv TEST $test_dir/TEST.$i | ||
done | done | ||
+ | </pre> |
Revision as of 20:27, 5 April 2011
This page contains notes and instructions for people running the ET testsuites on various different machines. If you have experience running testsuites on a machine which is not listed here, please consider adding some information which might help others (or yourself!) in future.
Contents
General
To check out the ET:
mkdir etrelease cd etrelease curl -O https://github.com/gridaphobe/CRL/raw/master/GetComponents chmod a+x GetComponents ./GetComponents --root=. -a https://svn.einsteintoolkit.org/manifest/trunk/einsteintoolkit.th cp udb.example.pm udb.pm
Replace "redshift" with the name of your local machine, unless you are running on one of the supported machines.
Replace YOUR_LOGIN, YOUR_EMAIL_ADDRESS and YOUR_ALLOCATION as appropriate.
Set sourcebasedir for your local machine to be the directory containing etrelease (do not set it to etrelease itself).
Set your username on each machine:
set_option 'MACHINE' , 'user', 'USERNAME';
See the machine-specific notes below for any additional steps for each machine.
touch par/testsuite.par sim sync <machine> sim build --thornlist manifest/einsteintoolkit.th --scriptfile <machine>-testsuite.sh
sim remote <machine> create-submit par/testsuite.par NSLOTS 6:00:00
This is a dummy parameter file.
When the job is finished, you should have the required <machine>_i_j.log files in machine:etrelease/*.log. The testsuite output will also be stored in machine:TEST_XXX, where XXX is constructed from the date at which the job was run.
Update the testsuite status page by adding the log files to the release-info repository:
svn co https://svn.einsteintoolkit.org/www/release-info cd release-info scp machine:etrelease/*.log .
Then commit the new/updated files.
Machines
Kraken
Edit simfactory/mdb.pm
- myproxy-logon -p 7514 -s myproxy.teragrid.org -T -l @USER@ -o @SOURCEDIR@/.globus/proxy-teragrid + myproxy-logon -p 7514 -s myproxy.teragrid.org -T -l <username> -o @SOURCEDIR@/.globus/proxy-teragrid
where <username> is your user name on Kraken. This is related to Ticket #381
Change the sourcebasedir in simfactory/udb.pm to be under /lustre/scratch. This is necessary because the Cactus directory must be visible from the compute node when running the tests (to see the parameter files, testsuite reference output and test.ccl files).
set_option 'kraken', 'sourcebasedir', '/lustre/scratch/USERNAME';
Copy kraken.sh as kraken-testsuite.sh in simfactory/scriptfiles. Replace the aprun command with the following:
cd @SOURCEDIR@ export CCTK_TESTSUITE_RUN_COMMAND="aprun -n \$nprocs -d 1 \$exe \$parfile" test_dir=TEST_$(date +%Y-%m-%d-%H%M%S) mkdir $test_dir CONFIGNAME=$(ls configs|tail) # SimFactory should provide the configuration name for i in 1 2 3; do case $i in 1 ) export CCTK_TESTSUITE_RUN_PROCESSORS=1 export OMP_NUM_THREADS=1;; 2 ) export CCTK_TESTSUITE_RUN_PROCESSORS=2 export OMP_NUM_THREADS=1;; 3 ) export CCTK_TESTSUITE_RUN_PROCESSORS=2 export OMP_NUM_THREADS=2;; esac make $CONFIGNAME-testsuite PROMPT=no cp TEST/$CONFIGNAME/summary.log kraken__${CCTK_TESTSUITE_RUN_PROCESSORS}_${OMP_NUM_THREADS}.log mv TEST $test_dir/TEST.$i done
Datura
Copy datura.sh as datura-testsuite.sh in simfactory/scriptfiles. Replace the mpirun command with the following:
cd @SOURCEDIR@ test_dir=TEST_$(date +%Y-%m-%d-%H%M%S) mkdir $test_dir CONFIGNAME=$(ls configs|tail) # SimFactory should provide the configuration name export CACTUS_STARTTIME=$(date +%s) for i in 1 2 3; do case $i in 1 ) export CCTK_TESTSUITE_RUN_PROCESSORS=1 export OMP_NUM_THREADS=1;; 2 ) export CCTK_TESTSUITE_RUN_PROCESSORS=2 export OMP_NUM_THREADS=1;; 3 ) export CCTK_TESTSUITE_RUN_PROCESSORS=2 export OMP_NUM_THREADS=2;; esac export CCTK_TESTSUITE_RUN_COMMAND="${MPIDIR}/bin/mpirun -v --mca btl openib,self --mca mpi_leave_pinned 0 -np \$nprocs -npernode $CCTK_TESTSUITE_RUN_PROCESSORS \$exe -L 3 \$parfile" make $CONFIGNAME-testsuite PROMPT=no cp TEST/$CONFIGNAME/summary.log datura__${CCTK_TESTSUITE_RUN_PROCESSORS}_${OMP_NUM_THREADS}.log mv TEST $test_dir/TEST.$i done