def clear(self):
self._dont_run = False
self._signal = None
- self.process = None
+ self._process = None
self.error_count = 0
def start(self):
assert self.process is None
def restart(self):
self.clear()
log.debug(u'ProcessInfo.restart(): executing %s', self.command)
- self.process = subprocess.Popen(self.command, *self.args, **self.kwargs)
+ self._process = subprocess.Popen(self.command,
+ *self.args, **self.kwargs)
def stop(self):
assert self.process is not None
self._dont_run = True
@property
def name(self):
return self._name
+ @property
+ def process(self):
+ return self._process
def __repr__(self):
pid = None
if self.process is not None:
if name in self.pidmap:
return self.pidmap[name]
raise KeyError, name
+ # Syntax sugar for self[name]
+ __getitem__ = get
def has(self, name):
if isinstance(name, basestring): # is a name
if name in self.pidmap:
return True
return False
-
- def __getitem__(self, name):
- return self.get(name)
-
- def __contains__(self, name):
- return self.has(name)
+ # Syntax sugar for name in self
+ __contains__ = has
if __name__ == '__main__':
assert 'test-service' in manager.services
assert 'test-service' not in manager.namemap
assert not get('test-service').running
+ assert manager['test-service'] == get('test-service')
+ assert has('test-service')
+ assert 'test-service' in manager
register('test-service-2', ('sleep', '3'), notify, False)
assert 'test-service-2' in manager.services