parse.py 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. # ex:ts=4:sw=4:sts=4:et
  2. # -*- tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*-
  3. #
  4. # BitBake Test for lib/bb/parse/
  5. #
  6. # Copyright (C) 2015 Richard Purdie
  7. #
  8. # This program is free software; you can redistribute it and/or modify
  9. # it under the terms of the GNU General Public License version 2 as
  10. # published by the Free Software Foundation.
  11. #
  12. # This program is distributed in the hope that it will be useful,
  13. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. # GNU General Public License for more details.
  16. #
  17. # You should have received a copy of the GNU General Public License along
  18. # with this program; if not, write to the Free Software Foundation, Inc.,
  19. # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  20. #
  21. import unittest
  22. import tempfile
  23. import logging
  24. import bb
  25. import os
  26. logger = logging.getLogger('BitBake.TestParse')
  27. import bb.parse
  28. import bb.data
  29. import bb.siggen
  30. class ParseTest(unittest.TestCase):
  31. testfile = """
  32. A = "1"
  33. B = "2"
  34. do_install() {
  35. echo "hello"
  36. }
  37. C = "3"
  38. """
  39. def setUp(self):
  40. self.d = bb.data.init()
  41. bb.parse.siggen = bb.siggen.init(self.d)
  42. def parsehelper(self, content, suffix = ".bb"):
  43. f = tempfile.NamedTemporaryFile(suffix = suffix)
  44. f.write(bytes(content, "utf-8"))
  45. f.flush()
  46. os.chdir(os.path.dirname(f.name))
  47. return f
  48. def test_parse_simple(self):
  49. f = self.parsehelper(self.testfile)
  50. d = bb.parse.handle(f.name, self.d)['']
  51. self.assertEqual(d.getVar("A"), "1")
  52. self.assertEqual(d.getVar("B"), "2")
  53. self.assertEqual(d.getVar("C"), "3")
  54. def test_parse_incomplete_function(self):
  55. testfileB = self.testfile.replace("}", "")
  56. f = self.parsehelper(testfileB)
  57. with self.assertRaises(bb.parse.ParseError):
  58. d = bb.parse.handle(f.name, self.d)['']
  59. unsettest = """
  60. A = "1"
  61. B = "2"
  62. B[flag] = "3"
  63. unset A
  64. unset B[flag]
  65. """
  66. def test_parse_unset(self):
  67. f = self.parsehelper(self.unsettest)
  68. d = bb.parse.handle(f.name, self.d)['']
  69. self.assertEqual(d.getVar("A"), None)
  70. self.assertEqual(d.getVarFlag("A","flag"), None)
  71. self.assertEqual(d.getVar("B"), "2")
  72. overridetest = """
  73. RRECOMMENDS_${PN} = "a"
  74. RRECOMMENDS_${PN}_libc = "b"
  75. OVERRIDES = "libc:${PN}"
  76. PN = "gtk+"
  77. """
  78. def test_parse_overrides(self):
  79. f = self.parsehelper(self.overridetest)
  80. d = bb.parse.handle(f.name, self.d)['']
  81. self.assertEqual(d.getVar("RRECOMMENDS"), "b")
  82. bb.data.expandKeys(d)
  83. self.assertEqual(d.getVar("RRECOMMENDS"), "b")
  84. d.setVar("RRECOMMENDS_gtk+", "c")
  85. self.assertEqual(d.getVar("RRECOMMENDS"), "c")
  86. overridetest2 = """
  87. EXTRA_OECONF = ""
  88. EXTRA_OECONF_class-target = "b"
  89. EXTRA_OECONF_append = " c"
  90. """
  91. def test_parse_overrides(self):
  92. f = self.parsehelper(self.overridetest2)
  93. d = bb.parse.handle(f.name, self.d)['']
  94. d.appendVar("EXTRA_OECONF", " d")
  95. d.setVar("OVERRIDES", "class-target")
  96. self.assertEqual(d.getVar("EXTRA_OECONF"), "b c d")
  97. overridetest3 = """
  98. DESCRIPTION = "A"
  99. DESCRIPTION_${PN}-dev = "${DESCRIPTION} B"
  100. PN = "bc"
  101. """
  102. def test_parse_combinations(self):
  103. f = self.parsehelper(self.overridetest3)
  104. d = bb.parse.handle(f.name, self.d)['']
  105. bb.data.expandKeys(d)
  106. self.assertEqual(d.getVar("DESCRIPTION_bc-dev"), "A B")
  107. d.setVar("DESCRIPTION", "E")
  108. d.setVar("DESCRIPTION_bc-dev", "C D")
  109. d.setVar("OVERRIDES", "bc-dev")
  110. self.assertEqual(d.getVar("DESCRIPTION"), "C D")
  111. classextend = """
  112. VAR_var_override1 = "B"
  113. EXTRA = ":override1"
  114. OVERRIDES = "nothing${EXTRA}"
  115. BBCLASSEXTEND = "###CLASS###"
  116. """
  117. classextend_bbclass = """
  118. EXTRA = ""
  119. python () {
  120. d.renameVar("VAR_var", "VAR_var2")
  121. }
  122. """
  123. #
  124. # Test based upon a real world data corruption issue. One
  125. # data store changing a variable poked through into a different data
  126. # store. This test case replicates that issue where the value 'B' would
  127. # become unset/disappear.
  128. #
  129. def test_parse_classextend_contamination(self):
  130. cls = self.parsehelper(self.classextend_bbclass, suffix=".bbclass")
  131. #clsname = os.path.basename(cls.name).replace(".bbclass", "")
  132. self.classextend = self.classextend.replace("###CLASS###", cls.name)
  133. f = self.parsehelper(self.classextend)
  134. alldata = bb.parse.handle(f.name, self.d)
  135. d1 = alldata['']
  136. d2 = alldata[cls.name]
  137. self.assertEqual(d1.getVar("VAR_var"), "B")
  138. self.assertEqual(d2.getVar("VAR_var"), None)