summaryrefslogtreecommitdiffstats
path: root/meta/lib/oeqa/selftest/buildhistory.py
diff options
context:
space:
mode:
authorDaniel Istrate <daniel.alexandrux.istrate@intel.com>2016-01-04 15:26:08 +0200
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-01-07 13:40:16 +0000
commit4ec2da71db78c16aedad2156a68b2e244ee2ccea (patch)
tree4130124b1375d60dcbc18872d62036824676741e /meta/lib/oeqa/selftest/buildhistory.py
parent02d259c1f4d9cf19636867ebcabf8695cd79f797 (diff)
downloadpoky-4ec2da71db78c16aedad2156a68b2e244ee2ccea.tar.gz
selftest: moved tc test_buildhistory_does_not_change_signatures
Moved test_buildhistory_does_not_change_signatures from buildhistory/BuildhistoryBase to buildoptions/BuildhistoryTests. The test being in the base class was causing it to run multiple times. Fix for [YOCTO #8867] (From OE-Core rev: 975e67e28ccba5dcb0fced43c1f9e7da183dc201) Signed-off-by: Daniel Istrate <daniel.alexandrux.istrate@intel.com> Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/lib/oeqa/selftest/buildhistory.py')
-rw-r--r--meta/lib/oeqa/selftest/buildhistory.py64
1 files changed, 2 insertions, 62 deletions
diff --git a/meta/lib/oeqa/selftest/buildhistory.py b/meta/lib/oeqa/selftest/buildhistory.py
index e8aa05df7a..38bcd72cb4 100644
--- a/meta/lib/oeqa/selftest/buildhistory.py
+++ b/meta/lib/oeqa/selftest/buildhistory.py
@@ -42,65 +42,5 @@ class BuildhistoryBase(oeSelfTest):
42 else: 42 else:
43 self.assertEqual(result.status, 0, msg="Command 'bitbake %s' has failed unexpectedly: %s" % (target, result.output)) 43 self.assertEqual(result.status, 0, msg="Command 'bitbake %s' has failed unexpectedly: %s" % (target, result.output))
44 44
45 @testcase(1386) 45 # No tests should be added to the base class.
46 def test_buildhistory_does_not_change_signatures(self): 46 # Please create a new class that inherit this one, or use one of those already available for adding tests.
47 """
48 Summary: Ensure that buildhistory does not change signatures
49 Expected: Only 'do_rootfs' and 'do_build' tasks are rerun
50 Product: oe-core
51 Author: Daniel Istrate <daniel.alexandrux.istrate@intel.com>
52 AutomatedBy: Daniel Istrate <daniel.alexandrux.istrate@intel.com>
53 """
54
55 tmpdir1_name = 'tmpsig1'
56 tmpdir2_name = 'tmpsig2'
57 builddir = os.environ.get('BUILDDIR')
58 tmpdir1 = os.path.join(builddir, tmpdir1_name)
59 tmpdir2 = os.path.join(builddir, tmpdir2_name)
60
61 self.track_for_cleanup(tmpdir1)
62 self.track_for_cleanup(tmpdir2)
63
64 features = 'TMPDIR = "%s"\n' % tmpdir1
65 self.write_config(features)
66 bitbake('core-image-sato -S none')
67
68 features = 'TMPDIR = "%s"\n' % tmpdir2
69 features += 'INHERIT += "buildhistory"\n'
70 self.write_config(features)
71 bitbake('core-image-sato -S none')
72
73 def get_files(d):
74 f = []
75 for root, dirs, files in os.walk(d):
76 for name in files:
77 f.append(os.path.join(root, name))
78 return f
79
80 files1 = get_files(tmpdir1 + '/stamps')
81 files2 = get_files(tmpdir2 + '/stamps')
82 files2 = [x.replace(tmpdir2_name, tmpdir1_name) for x in files2]
83
84 f1 = set(files1)
85 f2 = set(files2)
86 sigdiff = f1 - f2
87
88 self.assertEqual(len(sigdiff), 2, 'Expected 2 signature differences. Out: %s' % list(sigdiff))
89
90 unexpected_diff = []
91
92 # No new signatures should appear apart from do_rootfs and do_build
93 found_do_rootfs_flag = False
94 found_do_build_flag = False
95
96 for sig in sigdiff:
97 if 'do_rootfs' in sig:
98 found_do_rootfs_flag = True
99 elif 'do_build' in sig:
100 found_do_build_flag = True
101 else:
102 unexpected_diff.append(sig)
103
104 self.assertTrue(found_do_rootfs_flag, 'Task do_rootfs did not rerun.')
105 self.assertTrue(found_do_build_flag, 'Task do_build did not rerun')
106 self.assertFalse(unexpected_diff, 'Found unexpected signature differences. Out: %s' % unexpected_diff)