Skip to content
This repository has been archived by the owner on Oct 10, 2019. It is now read-only.

Commit

Permalink
Merge pull request #57 from brianhlin/v1_18_bosco
Browse files Browse the repository at this point in the history
Fix bug that broke shell parsing of *_binpath
  • Loading branch information
brianhlin authored Jul 25, 2017
2 parents 1f3b79e + 429a2d5 commit f17ecbc
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 30 deletions.
6 changes: 3 additions & 3 deletions config/blah.config.template
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ blah_require_proxy_on_submit=

#Path where PBS executables are located
# NOTE: this path is computed many times; I worry about the overhead here. -BB, 12-13-2012
pbs_binpath=`which qsub 2>/dev/null|sed 's|/[^/]*$||'`
pbs_binpath=/usr/bin

#Path where the PBS logs are located ($pbs_spoolpath/server_logs)
#pbs_spoolpath=
Expand All @@ -105,7 +105,7 @@ pbs_pro=no
##LSF common variables

#Path where LSF executables are located
lsf_binpath=`which bsub 2>/dev/null|sed 's|/[^/]*$||'`
lsf_binpath=/usr/bin

#Path where the LSF conf file is located ($lsf_confpath/lsf.conf)
lsf_confpath=
Expand Down Expand Up @@ -285,7 +285,7 @@ tracejob_max_output=
##Condor

#condor bin location
condor_binpath=`which condor_submit 2>/dev/null|sed 's|/[^/]*$||'`
condor_binpath=/usr/bin

#path to condor_config
#export CONDOR_CONFIG="/etc/condor/condor_config"
Expand Down
5 changes: 5 additions & 0 deletions src/scripts/blah.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,3 +27,8 @@ def get(self, option):
# paths, for example.
return super(BlahConfigParser, self).get(self.header, option).strip('"\'')

def set(self, option, value):
return super(BlahConfigParser, self).set(self.header, option, value)

def has_option(self, option):
return super(BlahConfigParser, self).has_option(self.header, option)
24 changes: 11 additions & 13 deletions src/scripts/pbs_status.py
Original file line number Diff line number Diff line change
Expand Up @@ -358,18 +358,17 @@ def get_qstat_location():
if _qstat_location_cache != None:
return _qstat_location_cache

try:
location = os.path.join(config.get('pbs_binpath'), 'qstat')
except KeyError:
cmd = 'which qstat'
child_stdout = os.popen(cmd)
output = child_stdout.read()
location = output.split("\n")[0].strip()
if child_stdout.close():
raise Exception("Unable to determine qstat location: %s" % output)

_qstat_location_cache = location
return location
if not (config.has_option('pbs_binpath') and config.get('pbs_binpath')):
config.set('pbs_binpath', '/usr/bin')
cmd = 'echo "%s/%s"' % (config.get('pbs_binpath'), 'qstat')

child_stdout = os.popen(cmd)
output = child_stdout.read().split("\n")[0].strip()
if child_stdout.close():
raise Exception("Unable to determine qstat location: %s" % output)

_qstat_location_cache = output
return output

job_id_re = re.compile("\s*Job Id:\s([0-9]+)([\w\-\/.]*)")
exec_host_re = re.compile("\s*exec_host = ([\w\-\/.]+)")
Expand Down Expand Up @@ -528,7 +527,6 @@ def main():
return 1
jobid = jobid_arg.split("/")[-1].split(".")[0]

config_dir = os.path.dirname(os.path.abspath(__file__))
global config
config = blah.BlahConfigParser()

Expand Down
28 changes: 14 additions & 14 deletions src/scripts/slurm_status.py
Original file line number Diff line number Diff line change
Expand Up @@ -335,18 +335,18 @@ def get_slurm_location(program):
global _slurm_location_cache
if _slurm_location_cache != None:
return os.path.join(_slurm_location_cache, program)
try:
location = os.path.join(config.get('slurm_binpath'), program)
except KeyError:
cmd = 'which %s' % program
child_stdout = os.popen(cmd)
output = child_stdout.read()
location = output.split("\n")[0].strip()
if child_stdout.close():
raise Exception("Unable to determine scontrol location: %s" % output)

_slurm_location_cache = os.path.dirname(location)
return location

if not (config.has_option('slurm_binpath') and config.get('slurm_binpath')):
config.set('slurm_binpath', '/usr/bin')
cmd = 'echo "%s/%s"' % (config.get('slurm_binpath'), 'scontrol')

child_stdout = os.popen(cmd)
output = child_stdout.read().split("\n")[0].strip()
if child_stdout.close():
raise Exception("Unable to determine scontrol location: %s" % output)

_slurm_location_cache = os.path.dirname(output)
return output

job_id_re = re.compile("JobId=([0-9]+) .*")
exec_host_re = re.compile("\s*BatchHost=([\w\-.]+)")
Expand Down Expand Up @@ -490,8 +490,8 @@ def main():
return 1
jobid = jobid_arg.split("/")[-1].split(".")[0]

config_dir = os.path.dirname(os.path.abspath(__file__))
blah.load_env(config_dir)
global config
config = blah.BlahConfigParser()

log("Checking cache for jobid %s" % jobid)
cache_contents = None
Expand Down

0 comments on commit f17ecbc

Please sign in to comment.