-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathwd.py
102 lines (72 loc) · 1.93 KB
/
wd.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
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import os
import subprocess
import socket
import signal
import time
import sys
HOSTNAME=socket.gethostname()
HOME=os.environ['HOME']
# ROBOT=`hostname`
# cd $HOME/Environments/$ROBOT/
# $HOME/Code/build/RhobanServer
WATCHDOG_TIME = 10
processFile = '/tmp/processIsAlive'
pid = ''
# global logfile = '/tmp/out.log'
#cmd = ['./test_wd', 'test']
cmd=sys.argv[1:]
# rhioinit = ['rhio', 'localhost', 'init']
# rhiorobocup = ['rhio', 'localhost', 'robocup']
done = 0
def watchdog(sig, stack):
global pid
# print "Watchdog"
if(pid.poll() is not None):
print "Process has terminated. Rerun."
run()
# elif(not os.path.isfile(processFile)):
# print processFile
# print os.path.isfile(processFile)
# print "Process has frozen? Rerun."
# # kill and restart
# if(pid.poll() is None):
# os.kill(pid.pid, signal.SIGTERM)
# time.sleep(3)
# if(pid.poll() is None):
# print "Still not dead?"
# os.kill(pid.pid, signal.SIGKILL)
# run()
# else:
# os.remove(processFile)
signal.alarm(WATCHDOG_TIME)
def sigint(sig, stack):
# signal.signal(signal.SIGINT, original_sigint)
global pid
global done
print "CTRL-C"
if(done < 5):
done += 1
if(pid.poll() is None):
print "Killing process"
os.kill(pid.pid, signal.SIGINT)
else:
print "Ok we quit."
sys.exit()
def run():
global pid
global logfile
global cmd
print "Launching ", cmd
# pid = subprocess.Popen(cmd, stdout=logfile)
pid = subprocess.Popen(cmd)
time.sleep(5)
if __name__ == '__main__':
signal.signal(signal.SIGALRM, watchdog)
# original_sigint = signal.getsignal(signal.SIGINT)
signal.signal(signal.SIGINT, sigint)
signal.alarm(WATCHDOG_TIME)
run()
while(1):
time.sleep(1)