diff options
-rw-r--r-- | meta/lib/oeqa/selftest/cases/distrodata.py | 67 |
1 files changed, 62 insertions, 5 deletions
diff --git a/meta/lib/oeqa/selftest/cases/distrodata.py b/meta/lib/oeqa/selftest/cases/distrodata.py index 12540adc7d..7b2800464c 100644 --- a/meta/lib/oeqa/selftest/cases/distrodata.py +++ b/meta/lib/oeqa/selftest/cases/distrodata.py | |||
@@ -9,6 +9,11 @@ class Distrodata(OESelftestTestCase): | |||
9 | @classmethod | 9 | @classmethod |
10 | def setUpClass(cls): | 10 | def setUpClass(cls): |
11 | super(Distrodata, cls).setUpClass() | 11 | super(Distrodata, cls).setUpClass() |
12 | feature = 'INHERIT += "distrodata"\n' | ||
13 | feature += 'LICENSE_FLAGS_WHITELIST += " commercial"\n' | ||
14 | |||
15 | cls.write_config(cls, feature) | ||
16 | bitbake('-c checkpkg world') | ||
12 | 17 | ||
13 | @OETestID(1902) | 18 | @OETestID(1902) |
14 | def test_checkpkg(self): | 19 | def test_checkpkg(self): |
@@ -18,11 +23,6 @@ class Distrodata(OESelftestTestCase): | |||
18 | Product: oe-core | 23 | Product: oe-core |
19 | Author: Alexander Kanavin <alexander.kanavin@intel.com> | 24 | Author: Alexander Kanavin <alexander.kanavin@intel.com> |
20 | """ | 25 | """ |
21 | feature = 'INHERIT += "distrodata"\n' | ||
22 | feature += 'LICENSE_FLAGS_WHITELIST += " commercial"\n' | ||
23 | |||
24 | self.write_config(feature) | ||
25 | bitbake('-c checkpkg world') | ||
26 | checkpkg_result = open(os.path.join(get_bb_var("LOG_DIR"), "checkpkg.csv")).readlines()[1:] | 26 | checkpkg_result = open(os.path.join(get_bb_var("LOG_DIR"), "checkpkg.csv")).readlines()[1:] |
27 | regressed_failures = [pkg_data[0] for pkg_data in [pkg_line.split('\t') for pkg_line in checkpkg_result] if pkg_data[11] == 'UNKNOWN_BROKEN'] | 27 | regressed_failures = [pkg_data[0] for pkg_data in [pkg_line.split('\t') for pkg_line in checkpkg_result] if pkg_data[11] == 'UNKNOWN_BROKEN'] |
28 | regressed_successes = [pkg_data[0] for pkg_data in [pkg_line.split('\t') for pkg_line in checkpkg_result] if pkg_data[11] == 'KNOWN_BROKEN'] | 28 | regressed_successes = [pkg_data[0] for pkg_data in [pkg_line.split('\t') for pkg_line in checkpkg_result] if pkg_data[11] == 'KNOWN_BROKEN'] |
@@ -40,3 +40,60 @@ The following packages have been checked successfully for upstream versions, | |||
40 | but their recipes claim otherwise by setting UPSTREAM_VERSION_UNKNOWN. Please remove that line from the recipes. | 40 | but their recipes claim otherwise by setting UPSTREAM_VERSION_UNKNOWN. Please remove that line from the recipes. |
41 | """ + "\n".join(regressed_successes) | 41 | """ + "\n".join(regressed_successes) |
42 | self.assertTrue(len(regressed_failures) == 0 and len(regressed_successes) == 0, msg) | 42 | self.assertTrue(len(regressed_failures) == 0 and len(regressed_successes) == 0, msg) |
43 | |||
44 | def test_maintainers(self): | ||
45 | """ | ||
46 | Summary: Test that oe-core recipes have a maintainer | ||
47 | Expected: All oe-core recipes (except a few special static/testing ones) should have a maintainer listed in maintainers.inc file. | ||
48 | Product: oe-core | ||
49 | Author: Alexander Kanavin <alexander.kanavin@intel.com> | ||
50 | """ | ||
51 | def is_exception(pkg): | ||
52 | exceptions = ["packagegroup-", "initramfs-", "systemd-machine-units", "target-sdk-provides-dummy"] | ||
53 | for i in exceptions: | ||
54 | if i in pkg: | ||
55 | return True | ||
56 | return False | ||
57 | |||
58 | def is_in_oe_core(recipe, recipes): | ||
59 | self.assertTrue(recipe in recipes.keys(), "Recipe %s was not in 'bitbake-layers show-recipes' output" %(recipe)) | ||
60 | self.assertTrue(len(recipes[recipe]) > 0, "'bitbake-layers show-recipes' could not determine what layer(s) a recipe %s is in" %(recipe)) | ||
61 | try: | ||
62 | recipes[recipe].index('meta') | ||
63 | return True | ||
64 | except ValueError: | ||
65 | return False | ||
66 | |||
67 | def get_recipe_layers(): | ||
68 | import re | ||
69 | |||
70 | recipes = {} | ||
71 | recipe_regex = re.compile('^(?P<name>.*):$') | ||
72 | layer_regex = re.compile('^ (?P<name>\S*) +') | ||
73 | output = runCmd('bitbake-layers show-recipes').output | ||
74 | for line in output.split('\n'): | ||
75 | recipe_name_obj = recipe_regex.search(line) | ||
76 | if recipe_name_obj: | ||
77 | recipe_name = recipe_name_obj.group('name') | ||
78 | recipes[recipe_name] = [] | ||
79 | recipe_layer_obj = layer_regex.search(line) | ||
80 | if recipe_layer_obj: | ||
81 | layer_name = recipe_layer_obj.group('name') | ||
82 | recipes[recipe_name].append(layer_name) | ||
83 | return recipes | ||
84 | |||
85 | checkpkg_result = open(os.path.join(get_bb_var("LOG_DIR"), "checkpkg.csv")).readlines()[1:] | ||
86 | recipes_layers = get_recipe_layers() | ||
87 | no_maintainer_list = [pkg_data[0] for pkg_data in [pkg_line.split('\t') for pkg_line in checkpkg_result] \ | ||
88 | if pkg_data[14] == '' and is_in_oe_core(pkg_data[0], recipes_layers) and not is_exception(pkg_data[0])] | ||
89 | msg = """ | ||
90 | The following packages do not have a maintainer assigned to them. Please add an entry to meta/conf/distro/include/maintainers.inc file. | ||
91 | """ + "\n".join(no_maintainer_list) | ||
92 | self.assertTrue(len(no_maintainer_list) == 0, msg) | ||
93 | |||
94 | with_maintainer_list = [pkg_data[0] for pkg_data in [pkg_line.split('\t') for pkg_line in checkpkg_result] \ | ||
95 | if pkg_data[14] != '' and is_in_oe_core(pkg_data[0], recipes_layers) and not is_exception(pkg_data[0])] | ||
96 | msg = """ | ||
97 | The list of oe-core packages with maintainers is empty. This may indicate that the test has regressed and needs fixing. | ||
98 | """ | ||
99 | self.assertTrue(len(with_maintainer_list) > 0, msg) | ||