forked from AlexanderFlesher/Ar39Study
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsubmitJobs.py
executable file
·113 lines (84 loc) · 3.71 KB
/
submitJobs.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#!/usr/bin/env python
import argparse
import os.path
import sys
import tarfile
import re
import subprocess
parser = argparse.ArgumentParser(description='Submit beam data jobs.')
parser.add_argument("-f", "--first-run", dest="firstrun",
required=True,
help="First run.")
parser.add_argument("-l", "--last-run", dest="lastrun",
required=True,
help="Last run.")
parser.add_argument("-i", "--input-filelist", dest="inputlist",
default="bnbcos.list",
help="Path to input file list. (default=bnbcos.list)")
parser.add_argument("-p", "--parameter-file", dest="param",
default="param.txt",
help="Path to parameter file. (default=param.txt)")
parser.add_argument("-o", "--output-path", dest="outputpath",
required=True,
help="Path where to copy final output.")
parser.add_argument("-d", "--debug",action='store_true',
help="Will not delete submission files in the end. Useful for debugging and will only print the submission command on screen.")
args = parser.parse_args()
#now create jobfiles_*.tar that is shipped with the job
#this includes the executable
#tar -cf jobfiles.tar --transform '!^[^/]*/!!' file1 file2 file3
tarfilename="jobfiles_%i.tar.bz2"%os.getpid()
outtar = tarfile.open(tarfilename, mode='w:bz2')
outtar.add("Ar39Study",arcname="Ar39Study")
outtar.add("CollectionIntersection.txt",arcname="CollectionIntersection.txt")
outtar.add("ChannelWireGeometry_v2.txt",arcname="ChannelWireGeometry_v2.txt")
outtar.add(args.inputlist,arcname=args.inputlist)
outtar.add(args.param,arcname=args.param)
outtar.close()
ofstr='''
#!/bin/bash
export _RUN_NUMBER=$((PROCESS+%(firstrun)s))
echo "Running $0 on "$HOSTNAME >>${_RUN_NUMBER}.out 2>&1
echo "Cluster: " ${CLUSTER} >>${_RUN_NUMBER}.out 2>&1
echo "Process: " ${PROCESS} >>${_RUN_NUMBER}.out 2>&1
echo " Sourcing everything...." >>${_RUN_NUMBER}.out 2>&1
source /cvmfs/fermilab.opensciencegrid.org/products/common/etc/setup >>${_RUN_NUMBER}.out 2>&1
source /cvmfs/dune.opensciencegrid.org/products/dune/setup_dune.sh >>${_RUN_NUMBER}.out 2>&1
source /cvmfs/fermilab.opensciencegrid.org/products/larsoft/setup >>${_RUN_NUMBER}.out 2>&1
setup dunetpc v07_07_01 -q e17:prof >>${_RUN_NUMBER}.out 2>&1
setup gallery v1_08_03 -q e17:prof
mv ${_RUN_NUMBER}.out ${_CONDOR_SCRATCH_DIR}/.
cd ${_CONDOR_SCRATCH_DIR}
cp $INPUT_TAR_FILE .
tar -jvxf `basename ${INPUT_TAR_FILE}` >>${_RUN_NUMBER}.out 2>&1
fullpath=`head -n ${_RUN_NUMBER} %(inputfile)s | tail -n 1`
echo $fullpath >>${_RUN_NUMBER}.out 2>&1
echo " Copying File...." >>${_RUN_NUMBER}.out 2>&1
ifdh cp $fullpath ${PWD}/test.root >>${_RUN_NUMBER}.out 2>&1
echo "What's in here? "
ls >>${_RUN_NUMBER}.out 2>&1
echo " Run time! " >>${_RUN_NUMBER}.out 2>&1
./Ar39Study test.root >>${_RUN_NUMBER}.out 2>&1
mkdir ${_RUN_NUMBER}
cp ${_RUN_NUMBER}.out ${_RUN_NUMBER}/.
cp output.root ${_RUN_NUMBER}/.
ifdh mkdir %(outputdir)s/
ifdh mkdir %(outputdir)s/${_RUN_NUMBER}
ifdh cp -r ${_RUN_NUMBER} %(outputdir)s/${_RUN_NUMBER}/
'''%{'inputfile':args.inputlist,'firstrun':args.firstrun,'outputdir':args.outputpath}
runjobfname="runjob_%i.sh"%os.getpid()
of=open(runjobfname,'w')
of.write(ofstr)
of.close()
cmd="jobsub_submit --disk=150GB --memory=3500MB --group=dune -N %i --tar_file_name=dropbox://%s file://%s"%(int(args.lastrun)-int(args.firstrun)+1,os.path.abspath(tarfilename),os.path.abspath(runjobfname))
if (not args.debug):
print "Running submit cmd:"
print cmd
os.system(cmd)
else:
print "Would have ran:"
print cmd
#Delete temp files unless debugging
if (not args.debug):
os.remove(tarfilename)
os.remove(runjobfname)