diff options
author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2018-11-30 12:38:28 +1300 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2018-12-03 12:20:00 +0000 |
commit | 5cd79e81471ca392bb697c2161526423b5a5dc07 (patch) | |
tree | 6f5b7dd880e6fb96876ba56303d746f9929052cc /meta/lib | |
parent | 1c0a6cdf428f8a7378ac739ff5193bf8fb372264 (diff) | |
download | poky-5cd79e81471ca392bb697c2161526423b5a5dc07.tar.gz |
oe-selftest: add some tests for recipeutils module
Add some tests for functions in meta/lib/oe/recipeutils.py, in
particular for a few issues I've just fixed. I haven't added tests for
all of the functions - some of them are already being tested via devtool
in any case.
(From OE-Core rev: 72d0cb3f8f1e69aeef93ea0bc90db3e8b8d6f94c)
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/lib')
-rw-r--r-- | meta/lib/oeqa/selftest/cases/recipeutils.py | 137 |
1 files changed, 137 insertions, 0 deletions
diff --git a/meta/lib/oeqa/selftest/cases/recipeutils.py b/meta/lib/oeqa/selftest/cases/recipeutils.py new file mode 100644 index 0000000000..dd2f55839a --- /dev/null +++ b/meta/lib/oeqa/selftest/cases/recipeutils.py | |||
@@ -0,0 +1,137 @@ | |||
1 | import os | ||
2 | import re | ||
3 | import time | ||
4 | import logging | ||
5 | import bb.tinfoil | ||
6 | |||
7 | from oeqa.selftest.case import OESelftestTestCase | ||
8 | from oeqa.utils.commands import runCmd, get_test_layer | ||
9 | from oeqa.core.decorator.oeid import OETestID | ||
10 | |||
11 | |||
12 | def 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 | |||
20 | def tearDownModule(): | ||
21 | tinfoil.shutdown() | ||
22 | |||
23 | |||
24 | class 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']) | ||