diff options
Diffstat (limited to 'meta/lib/oeqa/runtime/cases/apt.py')
-rw-r--r-- | meta/lib/oeqa/runtime/cases/apt.py | 40 |
1 files changed, 33 insertions, 7 deletions
diff --git a/meta/lib/oeqa/runtime/cases/apt.py b/meta/lib/oeqa/runtime/cases/apt.py index 53745df93f..8000645843 100644 --- a/meta/lib/oeqa/runtime/cases/apt.py +++ b/meta/lib/oeqa/runtime/cases/apt.py | |||
@@ -1,4 +1,6 @@ | |||
1 | # | 1 | # |
2 | # Copyright OpenEmbedded Contributors | ||
3 | # | ||
2 | # SPDX-License-Identifier: MIT | 4 | # SPDX-License-Identifier: MIT |
3 | # | 5 | # |
4 | 6 | ||
@@ -21,7 +23,7 @@ class AptRepoTest(AptTest): | |||
21 | 23 | ||
22 | @classmethod | 24 | @classmethod |
23 | def setUpClass(cls): | 25 | def setUpClass(cls): |
24 | service_repo = os.path.join(cls.tc.td['DEPLOY_DIR_DEB'], 'all') | 26 | service_repo = os.path.join(cls.tc.td['DEPLOY_DIR_DEB'], '') |
25 | cls.repo_server = HTTPService(service_repo, | 27 | cls.repo_server = HTTPService(service_repo, |
26 | '0.0.0.0', port=cls.tc.target.server_port, | 28 | '0.0.0.0', port=cls.tc.target.server_port, |
27 | logger=cls.tc.logger) | 29 | logger=cls.tc.logger) |
@@ -34,20 +36,44 @@ class AptRepoTest(AptTest): | |||
34 | def setup_source_config_for_package_install(self): | 36 | def setup_source_config_for_package_install(self): |
35 | apt_get_source_server = 'http://%s:%s/' % (self.tc.target.server_ip, self.repo_server.port) | 37 | apt_get_source_server = 'http://%s:%s/' % (self.tc.target.server_ip, self.repo_server.port) |
36 | apt_get_sourceslist_dir = '/etc/apt/' | 38 | apt_get_sourceslist_dir = '/etc/apt/' |
37 | self.target.run('cd %s; echo deb [ allow-insecure=yes ] %s ./ > sources.list' % (apt_get_sourceslist_dir, apt_get_source_server)) | 39 | self.target.run('cd %s; echo deb [ allow-insecure=yes ] %s/all ./ > sources.list' % (apt_get_sourceslist_dir, apt_get_source_server)) |
40 | |||
41 | def setup_source_config_for_package_install_signed(self): | ||
42 | apt_get_source_server = 'http://%s:%s' % (self.tc.target.server_ip, self.repo_server.port) | ||
43 | apt_get_sourceslist_dir = '/etc/apt/' | ||
44 | self.target.run("cd %s; cp sources.list sources.list.bak; sed -i 's|\[trusted=yes\] http://bogus_ip:bogus_port|%s|g' sources.list" % (apt_get_sourceslist_dir, apt_get_source_server)) | ||
38 | 45 | ||
39 | def cleanup_source_config_for_package_install(self): | 46 | def cleanup_source_config_for_package_install(self): |
40 | apt_get_sourceslist_dir = '/etc/apt/' | 47 | apt_get_sourceslist_dir = '/etc/apt/' |
41 | self.target.run('cd %s; rm sources.list' % (apt_get_sourceslist_dir)) | 48 | self.target.run('cd %s; rm sources.list' % (apt_get_sourceslist_dir)) |
42 | 49 | ||
50 | def cleanup_source_config_for_package_install_signed(self): | ||
51 | apt_get_sourceslist_dir = '/etc/apt/' | ||
52 | self.target.run('cd %s; mv sources.list.bak sources.list' % (apt_get_sourceslist_dir)) | ||
53 | |||
54 | def setup_key(self): | ||
55 | # the key is found on the target /etc/pki/packagefeed-gpg/ | ||
56 | # named PACKAGEFEED-GPG-KEY-poky-branch | ||
57 | self.target.run('cd %s; apt-key add P*' % ('/etc/pki/packagefeed-gpg')) | ||
58 | |||
43 | @skipIfNotFeature('package-management', | 59 | @skipIfNotFeature('package-management', |
44 | 'Test requires package-management to be in IMAGE_FEATURES') | 60 | 'Test requires package-management to be in IMAGE_FEATURES') |
45 | @skipIfNotDataVar('IMAGE_PKGTYPE', 'deb', | 61 | @skipIfNotDataVar('IMAGE_PKGTYPE', 'deb', |
46 | 'DEB is not the primary package manager') | 62 | 'DEB is not the primary package manager') |
47 | @OEHasPackage(['apt']) | 63 | @OEHasPackage(['apt']) |
48 | def test_apt_install_from_repo(self): | 64 | def test_apt_install_from_repo(self): |
49 | self.setup_source_config_for_package_install() | 65 | if not self.tc.td.get('PACKAGE_FEED_GPG_NAME'): |
50 | self.pkg('update') | 66 | self.setup_source_config_for_package_install() |
51 | self.pkg('remove --yes run-postinsts-dev') | 67 | self.pkg('update') |
52 | self.pkg('install --yes --allow-unauthenticated run-postinsts-dev') | 68 | self.pkg('remove --yes run-postinsts-dev') |
53 | self.cleanup_source_config_for_package_install() | 69 | self.pkg('install --yes --allow-unauthenticated run-postinsts-dev') |
70 | self.cleanup_source_config_for_package_install() | ||
71 | else: | ||
72 | # when we are here a key has been set to sign the package feed and | ||
73 | # public key and gnupg installed on the image by test_testimage_apt | ||
74 | self.setup_source_config_for_package_install_signed() | ||
75 | self.setup_key() | ||
76 | self.pkg('update') | ||
77 | self.pkg('install --yes run-postinsts-dev') | ||
78 | self.pkg('remove --yes run-postinsts-dev') | ||
79 | self.cleanup_source_config_for_package_install_signed() | ||