When not using file_per_task, make sure we don't prematurely close the perf files (#56477)

* When not using file_per_task, make sure we don't prematurely close the perf files

* add changelog fragment
This commit is contained in:
Matt Martz 2019-05-16 15:38:36 -05:00 committed by GitHub
parent 98246f6032
commit 867e357eb1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 8 deletions

View file

@ -0,0 +1,2 @@
bugfixes:
- cgroup_perf_recap - When not using file_per_task, make sure we don't prematurely close the perf files

View file

@ -394,13 +394,14 @@ class CallbackModule(CallbackBase):
def _profile(self, obj=None): def _profile(self, obj=None):
prev_task = None prev_task = None
results = dict.fromkeys(self._features) results = dict.fromkeys(self._features)
for dummy, f in self._files.items(): if not obj or self._file_per_task:
if f is None: for dummy, f in self._files.items():
continue if f is None:
try: continue
f.close() try:
except Exception: f.close()
pass except Exception:
pass
try: try:
for name, prof in self._profilers.items(): for name, prof in self._profilers.items():
@ -420,7 +421,7 @@ class CallbackModule(CallbackBase):
pass pass
if obj is not None: if obj is not None:
if self._file_per_task: if self._file_per_task or self._counter == 0:
self._open_files(task_uuid=obj._uuid) self._open_files(task_uuid=obj._uuid)
for feature in self._features: for feature in self._features: