blob: dd2f55839ae9037be98a78f2800931753c377b69 [file] [log] [blame]
Brad Bishop19323692019-04-05 15:28:33 -04001import os
2import re
3import time
4import logging
5import bb.tinfoil
6
7from oeqa.selftest.case import OESelftestTestCase
8from oeqa.utils.commands import runCmd, get_test_layer
9from oeqa.core.decorator.oeid import OETestID
10
11
12def setUpModule():
13 global tinfoil
14 global metaselftestpath
15 metaselftestpath = get_test_layer()
16 tinfoil = bb.tinfoil.Tinfoil(tracking=True)
17 tinfoil.prepare(config_only=False, quiet=2)
18
19
20def tearDownModule():
21 tinfoil.shutdown()
22
23
24class RecipeUtilsTests(OESelftestTestCase):
25 """ Tests for the recipeutils module functions """
26
27 def test_patch_recipe_varflag(self):
28 import oe.recipeutils
29 rd = tinfoil.parse_recipe('python3-async-test')
30 vals = {'SRC_URI[md5sum]': 'aaaaaa', 'LICENSE': 'something'}
31 patches = oe.recipeutils.patch_recipe(rd, rd.getVar('FILE'), vals, patch=True, relpath=metaselftestpath)
32
33 expected_patch = """
34--- a/recipes-devtools/python/python-async-test.inc
35+++ b/recipes-devtools/python/python-async-test.inc
36@@ -1,14 +1,14 @@
37 SUMMARY = "Python framework to process interdependent tasks in a pool of workers"
38 HOMEPAGE = "http://github.com/gitpython-developers/async"
39 SECTION = "devel/python"
40-LICENSE = "BSD"
41+LICENSE = "something"
42 LIC_FILES_CHKSUM = "file://PKG-INFO;beginline=8;endline=8;md5=88df8e78b9edfd744953862179f2d14e"
43
44 inherit pypi
45
46 PYPI_PACKAGE = "async"
47
48-SRC_URI[md5sum] = "9b06b5997de2154f3bc0273f80bcef6b"
49+SRC_URI[md5sum] = "aaaaaa"
50 SRC_URI[sha256sum] = "ac6894d876e45878faae493b0cf61d0e28ec417334448ac0a6ea2229d8343051"
51
52 RDEPENDS_${PN} += "${PYTHON_PN}-threading"
53"""
54 patchlines = []
55 for f in patches:
56 for line in f:
57 patchlines.append(line)
58 self.maxDiff = None
59 self.assertEqual(''.join(patchlines).strip(), expected_patch.strip())
60
61
62 def test_patch_recipe_singleappend(self):
63 import oe.recipeutils
64 rd = tinfoil.parse_recipe('recipeutils-test')
65 val = rd.getVar('SRC_URI', False).split()
66 del val[1]
67 val = ' '.join(val)
68 vals = {'SRC_URI': val}
69 patches = oe.recipeutils.patch_recipe(rd, rd.getVar('FILE'), vals, patch=True, relpath=metaselftestpath)
70
71 expected_patch = """
72--- a/recipes-test/recipeutils/recipeutils-test_1.2.bb
73+++ b/recipes-test/recipeutils/recipeutils-test_1.2.bb
74@@ -8,6 +8,4 @@
75
76 BBCLASSEXTEND = "native nativesdk"
77
78-SRC_URI += "file://somefile"
79-
80 SRC_URI_append = " file://anotherfile"
81"""
82 patchlines = []
83 for f in patches:
84 for line in f:
85 patchlines.append(line)
86 self.assertEqual(''.join(patchlines).strip(), expected_patch.strip())
87
88
89 def test_patch_recipe_appends(self):
90 import oe.recipeutils
91 rd = tinfoil.parse_recipe('recipeutils-test')
92 val = rd.getVar('SRC_URI', False).split()
93 vals = {'SRC_URI': val[0]}
94 patches = oe.recipeutils.patch_recipe(rd, rd.getVar('FILE'), vals, patch=True, relpath=metaselftestpath)
95
96 expected_patch = """
97--- a/recipes-test/recipeutils/recipeutils-test_1.2.bb
98+++ b/recipes-test/recipeutils/recipeutils-test_1.2.bb
99@@ -8,6 +8,3 @@
100
101 BBCLASSEXTEND = "native nativesdk"
102
103-SRC_URI += "file://somefile"
104-
105-SRC_URI_append = " file://anotherfile"
106"""
107 patchlines = []
108 for f in patches:
109 for line in f:
110 patchlines.append(line)
111 self.assertEqual(''.join(patchlines).strip(), expected_patch.strip())
112
113
114 def test_validate_pn(self):
115 import oe.recipeutils
116 expected_results = {
117 'test': '',
118 'glib-2.0': '',
119 'gtk+': '',
120 'forcevariable': 'reserved',
121 'pn-something': 'reserved',
122 'test.bb': 'file',
123 'test_one': 'character',
124 'test!': 'character',
125 }
126
127 for pn, expected in expected_results.items():
128 result = oe.recipeutils.validate_pn(pn)
129 if expected:
130 self.assertIn(expected, result)
131 else:
132 self.assertEqual(result, '')
133
134 def test_split_var_value(self):
135 import oe.recipeutils
136 res = oe.recipeutils.split_var_value('test.1 test.2 ${@call_function("hi there world", false)} test.4')
137 self.assertEqual(res, ['test.1', 'test.2', '${@call_function("hi there world", false)}', 'test.4'])