mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-19 21:09:03 +02:00
oeqa.buildperf: include buildstats file name in results.json
No need to do lsdir magic for finding buildstats when reading results. (From OE-Core rev: 4502f0979bf2e8698bb196345b89b170641fd43f) Signed-off-by: Markus Lehtonen <markus.lehtonen@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
c5d1301245
commit
c39db4bc45
|
@ -141,7 +141,7 @@ class BuildPerfTestResult(unittest.TextTestResult):
|
||||||
|
|
||||||
def startTest(self, test):
|
def startTest(self, test):
|
||||||
"""Pre-test hook"""
|
"""Pre-test hook"""
|
||||||
test.out_dir = os.path.join(self.out_dir, test.name)
|
test.base_dir = self.out_dir
|
||||||
os.mkdir(test.out_dir)
|
os.mkdir(test.out_dir)
|
||||||
log.info("Executing test %s: %s", test.name, test.shortDescription())
|
log.info("Executing test %s: %s", test.name, test.shortDescription())
|
||||||
self.stream.write(datetime.now().strftime("[%Y-%m-%d %H:%M:%S] "))
|
self.stream.write(datetime.now().strftime("[%Y-%m-%d %H:%M:%S] "))
|
||||||
|
@ -298,7 +298,7 @@ class BuildPerfTestCase(unittest.TestCase):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(BuildPerfTestCase, self).__init__(*args, **kwargs)
|
super(BuildPerfTestCase, self).__init__(*args, **kwargs)
|
||||||
self.name = self._testMethodName
|
self.name = self._testMethodName
|
||||||
self.out_dir = None
|
self.base_dir = None
|
||||||
self.start_time = None
|
self.start_time = None
|
||||||
self.elapsed_time = None
|
self.elapsed_time = None
|
||||||
self.measurements = []
|
self.measurements = []
|
||||||
|
@ -308,6 +308,10 @@ class BuildPerfTestCase(unittest.TestCase):
|
||||||
self.times = []
|
self.times = []
|
||||||
self.sizes = []
|
self.sizes = []
|
||||||
|
|
||||||
|
@property
|
||||||
|
def out_dir(self):
|
||||||
|
return os.path.join(self.base_dir, self.name)
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
"""Set-up fixture for each test"""
|
"""Set-up fixture for each test"""
|
||||||
if self.build_target:
|
if self.build_target:
|
||||||
|
@ -332,7 +336,7 @@ class BuildPerfTestCase(unittest.TestCase):
|
||||||
log.error("Command failed: %s", err.retcode)
|
log.error("Command failed: %s", err.retcode)
|
||||||
raise
|
raise
|
||||||
|
|
||||||
def measure_cmd_resources(self, cmd, name, legend):
|
def measure_cmd_resources(self, cmd, name, legend, save_bs=False):
|
||||||
"""Measure system resource usage of a command"""
|
"""Measure system resource usage of a command"""
|
||||||
def _worker(data_q, cmd, **kwargs):
|
def _worker(data_q, cmd, **kwargs):
|
||||||
"""Worker process for measuring resources"""
|
"""Worker process for measuring resources"""
|
||||||
|
@ -387,6 +391,11 @@ class BuildPerfTestCase(unittest.TestCase):
|
||||||
'elapsed_time': etime,
|
'elapsed_time': etime,
|
||||||
'rusage': data['rusage'],
|
'rusage': data['rusage'],
|
||||||
'iostat': data['iostat']}
|
'iostat': data['iostat']}
|
||||||
|
if save_bs:
|
||||||
|
bs_file = self.save_buildstats(legend)
|
||||||
|
measurement['values']['buildstats_file'] = \
|
||||||
|
os.path.relpath(bs_file, self.base_dir)
|
||||||
|
|
||||||
self.measurements.append(measurement)
|
self.measurements.append(measurement)
|
||||||
|
|
||||||
# Append to 'times' array for globalres log
|
# Append to 'times' array for globalres log
|
||||||
|
@ -474,12 +483,13 @@ class BuildPerfTestCase(unittest.TestCase):
|
||||||
buildstats.append(recipe_bs)
|
buildstats.append(recipe_bs)
|
||||||
|
|
||||||
# Write buildstats into json file
|
# Write buildstats into json file
|
||||||
postfix = '.' + label if label else ''
|
postfix = '.' + str_to_fn(label) if label else ''
|
||||||
postfix += '.json'
|
postfix += '.json'
|
||||||
outfile = os.path.join(self.out_dir, 'buildstats' + postfix)
|
outfile = os.path.join(self.out_dir, 'buildstats' + postfix)
|
||||||
with open(outfile, 'w') as fobj:
|
with open(outfile, 'w') as fobj:
|
||||||
json.dump(buildstats, fobj, indent=4, sort_keys=True,
|
json.dump(buildstats, fobj, indent=4, sort_keys=True,
|
||||||
cls=ResultsJsonEncoder)
|
cls=ResultsJsonEncoder)
|
||||||
|
return outfile
|
||||||
|
|
||||||
def rm_tmp(self):
|
def rm_tmp(self):
|
||||||
"""Cleanup temporary/intermediate files and directories"""
|
"""Cleanup temporary/intermediate files and directories"""
|
||||||
|
|
|
@ -28,9 +28,8 @@ class Test1P1(BuildPerfTestCase):
|
||||||
self.rm_cache()
|
self.rm_cache()
|
||||||
self.sync()
|
self.sync()
|
||||||
self.measure_cmd_resources(['bitbake', self.build_target], 'build',
|
self.measure_cmd_resources(['bitbake', self.build_target], 'build',
|
||||||
'bitbake ' + self.build_target)
|
'bitbake ' + self.build_target, save_bs=True)
|
||||||
self.measure_disk_usage(self.bb_vars['TMPDIR'], 'tmpdir', 'tmpdir')
|
self.measure_disk_usage(self.bb_vars['TMPDIR'], 'tmpdir', 'tmpdir')
|
||||||
self.save_buildstats()
|
|
||||||
|
|
||||||
|
|
||||||
class Test1P2(BuildPerfTestCase):
|
class Test1P2(BuildPerfTestCase):
|
||||||
|
@ -62,11 +61,11 @@ class Test1P3(BuildPerfTestCase):
|
||||||
self.sync()
|
self.sync()
|
||||||
cmd = ['bitbake', '-R', postfile, self.build_target]
|
cmd = ['bitbake', '-R', postfile, self.build_target]
|
||||||
self.measure_cmd_resources(cmd, 'build',
|
self.measure_cmd_resources(cmd, 'build',
|
||||||
'bitbake' + self.build_target)
|
'bitbake' + self.build_target,
|
||||||
|
save_bs=True)
|
||||||
self.measure_disk_usage(self.bb_vars['TMPDIR'], 'tmpdir', 'tmpdir')
|
self.measure_disk_usage(self.bb_vars['TMPDIR'], 'tmpdir', 'tmpdir')
|
||||||
finally:
|
finally:
|
||||||
os.unlink(postfile)
|
os.unlink(postfile)
|
||||||
self.save_buildstats()
|
|
||||||
|
|
||||||
|
|
||||||
class Test2(BuildPerfTestCase):
|
class Test2(BuildPerfTestCase):
|
||||||
|
|
Loading…
Reference in New Issue
Block a user