diff options
author | Lars Wirzenius <liw@liw.fi> | 2013-04-11 20:47:37 +0100 |
---|---|---|
committer | Lars Wirzenius <liw@liw.fi> | 2013-04-11 20:47:37 +0100 |
commit | bcdbf46c8ec8f3daf60550c059693595cc4cff79 (patch) | |
tree | ea7d8623c12be6eb5a49e5fdeb11a69ba2414790 /desktop-cronish | |
parent | dccfdbe5bf7233cc369a4a4994e473f0869a5f15 (diff) | |
download | desktop-cronish-bcdbf46c8ec8f3daf60550c059693595cc4cff79.tar.gz |
Add timeout feature
Diffstat (limited to 'desktop-cronish')
-rwxr-xr-x | desktop-cronish | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/desktop-cronish b/desktop-cronish index f69d16e..738d29c 100755 --- a/desktop-cronish +++ b/desktop-cronish @@ -17,6 +17,7 @@ import cliapp import time +import sys import yaml @@ -68,9 +69,15 @@ class DesktopCronish(cliapp.Application): def execute_job(self, job_name): job = self.jobs[job_name] - exit, out, err = cliapp.runcmd_unchecked(['sh', '-c', job['command']]) + argv = ['sh', '-c', job['command']] + if 'timeout' in job: + argv = ['timeout', str(job['timeout'])] + argv + exit, out, err = cliapp.runcmd_unchecked(argv) self.output.write(out) if exit != 0: + sys.stderr.write( + 'ERROR: Job %s: Command failed: %s\n' % + (job_name, ' '.join(argv))) sys.stderr.write(err) self.previously[job_name] = self.now() |