cgroup_perf_recap: Check if user wants to write to files or not (#64988)

if user sets 'write_files' to False or does not set value, then
handle file write related operations.

Fixes: #64936

Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
Abhijeet Kasurde 2019-12-11 20:21:38 +05:30 committed by GitHub
parent 4da87fb3ee
commit e82b28a920
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 12 additions and 8 deletions

View file

@ -0,0 +1,2 @@
bugfixes:
- Handle write_files option in cgroup_perf_recap callback plugin (https://github.com/ansible/ansible/issues/64936).

View file

@ -277,6 +277,7 @@ class CallbackModule(CallbackBase):
self._file_per_task = False self._file_per_task = False
self._counter = 0 self._counter = 0
self.write_files = False
def _open_files(self, task_uuid=None): def _open_files(self, task_uuid=None):
output_format = self._output_format output_format = self._output_format
@ -296,13 +297,14 @@ class CallbackModule(CallbackBase):
except Exception: except Exception:
pass pass
filename = self._file_name_format % data if self.write_files:
filename = self._file_name_format % data
self._files[feature] = open(os.path.join(output_dir, filename), 'w+') self._files[feature] = open(os.path.join(output_dir, filename), 'w+')
if output_format == b'csv': if output_format == b'csv':
self._writers[feature] = partial(csv_writer, csv.writer(self._files[feature])) self._writers[feature] = partial(csv_writer, csv.writer(self._files[feature]))
elif output_format == b'json': elif output_format == b'json':
self._writers[feature] = partial(json_writer, self._files[feature]) self._writers[feature] = partial(json_writer, self._files[feature])
def set_options(self, task_keys=None, var_options=None, direct=None): def set_options(self, task_keys=None, var_options=None, direct=None):
super(CallbackModule, self).set_options(task_keys=task_keys, var_options=var_options, direct=direct) super(CallbackModule, self).set_options(task_keys=task_keys, var_options=var_options, direct=direct)
@ -355,7 +357,7 @@ class CallbackModule(CallbackBase):
'pids': partial(PidsProf, pid_current_file, poll_interval=pid_poll_interval), 'pids': partial(PidsProf, pid_current_file, poll_interval=pid_poll_interval),
} }
write_files = self.get_option('write_files') self.write_files = self.get_option('write_files')
file_per_task = self.get_option('file_per_task') file_per_task = self.get_option('file_per_task')
self._output_format = to_bytes(self.get_option('output_format')) self._output_format = to_bytes(self.get_option('output_format'))
output_dir = to_bytes(self.get_option('output_dir'), errors='surrogate_or_strict') output_dir = to_bytes(self.get_option('output_dir'), errors='surrogate_or_strict')
@ -368,7 +370,7 @@ class CallbackModule(CallbackBase):
file_name_format = to_bytes(self.get_option('file_name_format')) file_name_format = to_bytes(self.get_option('file_name_format'))
if write_files: if self.write_files:
if file_per_task: if file_per_task:
self._file_per_task = True self._file_per_task = True
if file_name_format == b'%(feature)s.%(ext)s': if file_name_format == b'%(feature)s.%(ext)s':