[Kimchi-devel] [PATCH] Fix host debug report for Fedora 20

Rodrigo Trujillo rodrigo.trujillo at linux.vnet.ibm.com
Thu Feb 6 02:29:38 UTC 2014


On 02/05/2014 05:40 PM, Aline Manera wrote:
> On 02/05/2014 03:21 PM, Rodrigo Trujillo wrote:
>> The tool sosreport does not save the report file in /tmp in F20, which
>> causes a error in Kimchi, which has /tmp hardcoded. This patch fetches
>> the report file location from the output.
>> Notice that is possible to pass --tmp-dir as the directory to save the
>> report file, but this option is crashing in Fedora 20, so the code is
>> not using it.
>
> I don't like the idea to parse the output to know where the file was 
> saved.
> Isn't there a config file or other way to get the directory used by 
> sosreport?
No, according to my tests.
I am sending V2 with a new approach. Let me know what you think.
Thanks

>
>> Signed-off-by: Rodrigo Trujillo <rodrigo.trujillo at linux.vnet.ibm.com>
>> ---
>>   src/kimchi/model/debugreports.py | 40 
>> +++++++++++++++++-----------------------
>>   1 file changed, 17 insertions(+), 23 deletions(-)
>>
>> diff --git a/src/kimchi/model/debugreports.py 
>> b/src/kimchi/model/debugreports.py
>> index a1cb19c..0db9f85 100644
>> --- a/src/kimchi/model/debugreports.py
>> +++ b/src/kimchi/model/debugreports.py
>> @@ -32,6 +32,7 @@ from kimchi import config
>>   from kimchi.exception import NotFoundError, OperationFailed
>>   from kimchi.model.tasks import TaskModel
>>   from kimchi.utils import add_task, kimchi_log
>> +from kimchi.utils import run_command
>>
>>
>>   class DebugReportsModel(object):
>> @@ -63,36 +64,29 @@ class DebugReportsModel(object):
>>
>>       @staticmethod
>>       def sosreport_generate(cb, name):
>> -        command = 'sosreport --batch --name "%s"' % name
>>           try:
>> -            retcode = subprocess.call(command, shell=True,
>> -                                      stdout=subprocess.PIPE)
>> +            command = ['sosreport', '--batch', '--name=%s' % name]
>> +            output, error, retcode = run_command(command)
>> +
>>               if retcode < 0:
>>                   raise OperationFailed('Command terminated with 
>> signal')
>>               elif retcode > 0:
>>                   raise OperationFailed('Command failed: rc = %i' % 
>> retcode)
>> -            pattern = '/tmp/sosreport-%s-*' % name
>> -            for reportFile in glob.glob(pattern):
>> -                if not fnmatch.fnmatch(reportFile, '*.md5'):
>> -                    output = reportFile
>> -                    break
>> -            else:
>> -                # sosreport tends to change the name mangling rule and
>> -                # compression file format between different releases.
>> -                # It's possible to fail to match a report file even 
>> sosreport
>> -                # runs successfully. In future we might have a 
>> general name
>> -                # mangling function in kimchi to format the name 
>> before passing
>> -                # it to sosreport. Then we can delete this exception.
>> -                raise OperationFailed('Can not find generated debug 
>> report '
>> -                                      'named by %s' % pattern)
>> -            ext = output.split('.', 1)[1]
>> +
>> +            # SOSREPORT outputs the name of the file in the text block
>> +            # The right way should be passing the tar.xz file 
>> directory though
>> +            # the parameter '--tmp-dir', but this is failing in 
>> Fedora 20
>> +            rep_f = [line for line in output.split()
>> +                     if line.endswith('tar.xz')][0]
>> +            rep_name = os.path.basename(rep_f)
>>               path = config.get_debugreports_path()
>> -            target = os.path.join(path, name)
>> -            target_file = '%s.%s' % (target, ext)
>> -            shutil.move(output, target_file)
>> -            os.remove('%s.md5' % output)
>> -            cb('OK', True)
>> +            target = os.path.join(path, rep_name)
>>
>> +            msg = 'Moving debug report file "%s" to "%s"' % (rep_f, 
>> target)
>> +            kimchi_log.info(msg)
>> +            shutil.move(rep_f, target)
>> +            os.remove('%s.md5' % rep_f)
>> +            cb('OK', True)
>>               return
>>
>>           except OSError:
>
> _______________________________________________
> Kimchi-devel mailing list
> Kimchi-devel at ovirt.org
> http://lists.ovirt.org/mailman/listinfo/kimchi-devel
>




More information about the Kimchi-devel mailing list