testing/conftest.py: Reintialize config._openfiles for each test
And no longer need getopenfiles or config._numfiles --HG-- branch : refactor_LsofFdLeakChecker
This commit is contained in:
		
							parent
							
								
									064e79761c
								
							
						
					
					
						commit
						e45a33f029
					
				|  | @ -38,7 +38,8 @@ def pytest_addoption(parser): | |||
|            action="store_true", dest="lsof", default=False, | ||||
|            help=("run FD checks if lsof is available")) | ||||
| 
 | ||||
| def pytest_configure(config): | ||||
| def pytest_runtest_setup(item): | ||||
|     config = item.config | ||||
|     config._basedir = py.path.local() | ||||
|     if config.getvalue("lsof"): | ||||
|         try: | ||||
|  | @ -46,18 +47,10 @@ def pytest_configure(config): | |||
|             config._openfiles = config._fd_leak_checker.get_open_files() | ||||
|         except py.process.cmdexec.Error: | ||||
|             pass | ||||
|         else: | ||||
|             config._numfiles = len(config._openfiles) | ||||
| 
 | ||||
| #def pytest_report_header(): | ||||
| #    return "pid: %s" % os.getpid() | ||||
| 
 | ||||
| def getopenfiles(out): | ||||
|     def isopen(line): | ||||
|         return ("REG" in line or "CHR" in line) and ( | ||||
|             "deleted" not in line and 'mem' not in line and "txt" not in line) | ||||
|     return [x for x in out.split("\n") if isopen(x)] | ||||
| 
 | ||||
| def check_open_files(config): | ||||
|     lines2 = config._fd_leak_checker.get_open_files() | ||||
|     new_fds = sorted(set([t[0] for t in lines2]) - set([t[0] for t in config._openfiles])) | ||||
|  | @ -71,13 +64,11 @@ def check_open_files(config): | |||
|         error.append("*** After:") | ||||
|         error.extend([str(f) for f in lines2]) | ||||
|         error.append(error[0]) | ||||
|         # update numfile so that the overall test run continuess | ||||
|         config._numfiles = len(lines2) | ||||
|         raise AssertionError("\n".join(error)) | ||||
| 
 | ||||
| def pytest_runtest_teardown(item, __multicall__): | ||||
|     item.config._basedir.chdir() | ||||
|     if hasattr(item.config, '_numfiles'): | ||||
|     if hasattr(item.config, '_openfiles'): | ||||
|         x = __multicall__.execute() | ||||
|         check_open_files(item.config) | ||||
|         return x | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue