summaryrefslogtreecommitdiff
path: root/meta/lib/oeqa
diff options
context:
space:
mode:
authorMarkus Lehtonen <markus.lehtonen@linux.intel.com>2016-06-23 18:30:45 +0300
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-07-01 16:08:51 +0100
commitc449ca1b062426380a0572aed2da4ee4a83281f5 (patch)
treea44f276e144b06aaa19cd35ab564efa398c58a3c /meta/lib/oeqa
parent388c7160b90247df9c78d8803083821402c13af5 (diff)
downloadopenembedded-core-c449ca1b062426380a0572aed2da4ee4a83281f5.tar.gz
openembedded-core-c449ca1b062426380a0572aed2da4ee4a83281f5.tar.bz2
openembedded-core-c449ca1b062426380a0572aed2da4ee4a83281f5.zip
oeqa.buildperf: add test Test4
Re-implement "test4" from build-perf-test.sh which measures eSDK metrics. Signed-off-by: Markus Lehtonen <markus.lehtonen@linux.intel.com> Signed-off-by: Ross Burton <ross.burton@intel.com>
Diffstat (limited to 'meta/lib/oeqa')
-rw-r--r--meta/lib/oeqa/buildperf/basic_tests.py28
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')