diff options
author | Markus Lehtonen <markus.lehtonen@linux.intel.com> | 2016-06-23 18:30:45 +0300 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-07-01 16:22:47 +0100 |
commit | da3b9242fcb308e9d135a0371dcb210e087ce96c (patch) | |
tree | 0cc2b2d0e6796e2c21fe7efdf71c26519688942f | |
parent | fe24b5a597ee723b917b392c7e1570e88c50991a (diff) | |
download | openembedded-core-contrib-da3b9242fcb308e9d135a0371dcb210e087ce96c.tar.gz |
oeqa.buildperf: add test Test4
Re-implement "test4" from build-perf-test.sh which measures eSDK metrics.
(From OE-Core rev: c449ca1b062426380a0572aed2da4ee4a83281f5)
Signed-off-by: Markus Lehtonen <markus.lehtonen@linux.intel.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/lib/oeqa/buildperf/basic_tests.py | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/meta/lib/oeqa/buildperf/basic_tests.py b/meta/lib/oeqa/buildperf/basic_tests.py index 4ebbb77574..ada5aba053 100644 --- a/meta/lib/oeqa/buildperf/basic_tests.py +++ b/meta/lib/oeqa/buildperf/basic_tests.py @@ -11,8 +11,10 @@ # """Basic set of build performance tests""" import os +import shutil from . import BuildPerfTest, perf_test_case +from oeqa.utils.commands import get_bb_vars @perf_test_case @@ -103,3 +105,29 @@ class Test3(BuildPerfTest): # Parse with fully cached data self.measure_cmd_resources(['bitbake', '-p'], 'parse_3', 'bitbake -p (cached)') + + +@perf_test_case +class Test4(BuildPerfTest): + name = "test4" + build_target = 'core-image-sato' + description = "eSDK metrics" + + def _run(self): + self.log_cmd_output("bitbake {} -c do_populate_sdk_ext".format( + self.build_target)) + self.bb_vars = get_bb_vars(None, self.build_target) + tmp_dir = self.bb_vars['TMPDIR'] + installer = os.path.join( + self.bb_vars['SDK_DEPLOY'], + self.bb_vars['TOOLCHAINEXT_OUTPUTNAME'] + '.sh') + # Measure installer size + self.measure_disk_usage(installer, 'installer_bin', 'eSDK installer') + # Measure deployment time and deployed size + deploy_dir = os.path.join(tmp_dir, 'esdk-deploy') + if os.path.exists(deploy_dir): + shutil.rmtree(deploy_dir) + self.sync() + self.measure_cmd_resources([installer, '-y', '-d', deploy_dir], + 'deploy', 'eSDK deploy') + self.measure_disk_usage(deploy_dir, 'deploy_dir', 'deploy dir') |