mirror of
https://git.yoctoproject.org/poky
synced 2026-06-01 00:59:48 +00:00
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 <richard.purdie@linuxfoundation.org>
This commit is contained in:
@@ -47,9 +47,9 @@ C = "3"
|
|||||||
self.d = bb.data.init()
|
self.d = bb.data.init()
|
||||||
bb.parse.siggen = bb.siggen.init(self.d)
|
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.write(content)
|
||||||
f.flush()
|
f.flush()
|
||||||
os.chdir(os.path.dirname(f.name))
|
os.chdir(os.path.dirname(f.name))
|
||||||
@@ -113,3 +113,35 @@ PN = "bc"
|
|||||||
d.setVar("OVERRIDES", "bc-dev")
|
d.setVar("OVERRIDES", "bc-dev")
|
||||||
self.assertEqual(d.getVar("DESCRIPTION", True), "C D")
|
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)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user