Commit 08c3d445 authored by Rafael Monnerat's avatar Rafael Monnerat

Merge branch 'tristan' into 'master'

add is-process-older-than-dependency-set script

I was waiting for my instance to be built to test it, but still not ready.

So during the build, please @vpelletier, can you review this merge request?


See merge request !4
......@@ -69,6 +69,7 @@ setup(name=name,
'equeue = slapos.equeue:main',
'htpasswd = slapos.htpasswd:main',
'is-local-tcp-port-opened = slapos.promise.is_local_tcp_port_opened:main',
'is-process-older-than-dependency-set = slapos.promise.is_process_older_than_dependency_set:main',
'killpidfromfile = slapos.systool:killpidfromfile', # BBB
'runResiliencyUnitTestTestNode = slapos.resiliencytest:runUnitTest',
'runResiliencyScalabilityTestNode = slapos.resiliencytest:runResiliencyTest',
......
#!/usr/bin/env python
"""
Check if a process is running with an old version of the modules
found in the running python paths + optional additional python paths.
It parses all folders containing an `__init__.py` file and checks if
a file modification date is greater than the start date of the
process.
"""
import sys
import os
import errno
import psutil
ignored_extension_set = set([".pyc"])
def moduleIsModifiedSince(top, since, followlinks=False):
for root, dir_list, file_list in os.walk(top, followlinks=followlinks):
if root == top:
continue
if "__init__.py" not in file_list:
del dir_list[:]
continue
for name in file_list:
_, ext = os.path.splitext(name)
if ext in ignored_extension_set:
continue
if since < os.stat(os.path.join(root, name)).st_mtime:
return True
return False
def isProcessOlderThanDependencySet(pid, python_path_list):
start_time = psutil.Process(pid).create_time()
return any(moduleIsModifiedSince(product_path, start_time) for product_path in python_path_list)
def isProcessFromPidFileOlderThanDependencySet(pid_file_path, python_path_list):
with open(pid_file_path, "r") as f:
pid = int(f.readline())
return isProcessOlderThanDependencySet(pid, python_path_list)
def main():
pid_file_path, additional_python_path = sys.argv[1], sys.argv[2:] if len(sys.argv) > 2 else []
try:
if isProcessFromPidFileOlderThanDependencySet(pid_file_path, sys.path + additional_python_path):
return 1
return 0
except (OSError, IOError) as err:
if err.errno == errno.ENOENT:
return 0
raise
except psutil.NoSuchProcess:
return 0
if __name__ == "__main__":
sys.exit(main())
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment