From aaea533e70d4aefc2de3a2a62a3453a2a9034292 Mon Sep 17 00:00:00 2001 From: Richard Purdie Date: Wed, 22 Jul 2015 23:29:40 +0100 Subject: bitbake: tests/parse: Add BBCLASSEXTEND multiple data store corruption reproducer One data store changing a variable poked through into a different data store. This test case replicates that issue where the value 'B' would become unset/disappear. We also enhance parsehelper to generate files with an optional suffix such as bbclass. (Bitbake rev: 5c4179f58a4e04f1c354df5f17d1860eb403f0ac) Signed-off-by: Richard Purdie --- bitbake/lib/bb/tests/parse.py | 36 ++++++++++++++++++++++++++++++++++-- 1 file changed, 34 insertions(+), 2 deletions(-) (limited to 'bitbake/lib/bb/tests') diff --git a/bitbake/lib/bb/tests/parse.py b/bitbake/lib/bb/tests/parse.py index 21fd78a736..6beb76a48d 100644 --- a/bitbake/lib/bb/tests/parse.py +++ b/bitbake/lib/bb/tests/parse.py @@ -47,9 +47,9 @@ C = "3" self.d = bb.data.init() bb.parse.siggen = bb.siggen.init(self.d) - def parsehelper(self, content): + def parsehelper(self, content, suffix = ".bb"): - f = tempfile.NamedTemporaryFile(suffix = ".bb") + f = tempfile.NamedTemporaryFile(suffix = suffix) f.write(content) f.flush() os.chdir(os.path.dirname(f.name)) @@ -113,3 +113,35 @@ PN = "bc" d.setVar("OVERRIDES", "bc-dev") self.assertEqual(d.getVar("DESCRIPTION", True), "C D") + + classextend = """ +VAR_var_override1 = "B" +EXTRA = ":override1" +OVERRIDES = "nothing${EXTRA}" + +BBCLASSEXTEND = "###CLASS###" +""" + classextend_bbclass = """ +EXTRA = "" +python () { + d.renameVar("VAR_var", "VAR_var2") +} +""" + + # + # Test based upon a real world data corruption issue. One + # data store changing a variable poked through into a different data + # store. This test case replicates that issue where the value 'B' would + # become unset/disappear. + # + def test_parse_classextend_contamination(self): + cls = self.parsehelper(self.classextend_bbclass, suffix=".bbclass") + #clsname = os.path.basename(cls.name).replace(".bbclass", "") + self.classextend = self.classextend.replace("###CLASS###", cls.name) + f = self.parsehelper(self.classextend) + alldata = bb.parse.handle(f.name, self.d) + d1 = alldata[''] + d2 = alldata[cls.name] + self.assertEqual(d1.getVar("VAR_var", True), "B") + self.assertEqual(d2.getVar("VAR_var", True), None) + -- cgit v1.2.3-54-g00ecf