diff options
author | Randy Witt <randy.e.witt@linux.intel.com> | 2017-01-30 13:16:28 -0800 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2017-02-19 06:49:00 -0800 |
commit | 23bd7e100adb6dc06c4992ff5863f01d0b39e75b (patch) | |
tree | 67b6f295aa249b9ff6801d519bc09b2e1e2598f8 /meta | |
parent | 5da9c1c38b31c5edb957ad22fd093c9bc3a2ecd7 (diff) | |
download | poky-23bd7e100adb6dc06c4992ff5863f01d0b39e75b.tar.gz |
selftest/containerimage.py: Add container IMAGE_FSTYPES test
This test checks to make sure only the files expected exist in a
container image. Currently only ROOTFS_BOOTSTRAP_INSTALL, gets added to
all images without the user specifying it.
But this test should help if a developer in the future ever silently
adds more than just ROOTFS_BOOTSTRAP_INSTALL, and that the developer can
make sure it also gets removed from a container image.
[YOCTO #9502]
(From OE-Core rev: 4f5e5321fafe491f91d78a35d11afc0dc0527d4b)
Signed-off-by: Randy Witt <randy.e.witt@linux.intel.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta')
-rw-r--r-- | meta/lib/oeqa/selftest/containerimage.py | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/meta/lib/oeqa/selftest/containerimage.py b/meta/lib/oeqa/selftest/containerimage.py new file mode 100644 index 0000000000..def481f144 --- /dev/null +++ b/meta/lib/oeqa/selftest/containerimage.py | |||
@@ -0,0 +1,83 @@ | |||
1 | import os | ||
2 | |||
3 | from oeqa.selftest.base import oeSelfTest | ||
4 | from oeqa.utils.commands import bitbake, get_bb_vars, runCmd | ||
5 | |||
6 | # This test builds an image with using the "container" IMAGE_FSTYPE, and | ||
7 | # ensures that then files in the image are only the ones expected. | ||
8 | # | ||
9 | # The only package added to the image is container_image_testpkg, which | ||
10 | # contains one file. However, due to some other things not cleaning up during | ||
11 | # rootfs creation, there is some cruft. Ideally bugs will be filed and the | ||
12 | # cruft removed, but for now we whitelist some known set. | ||
13 | # | ||
14 | # Also for performance reasons we're only checking the cruft when using ipk. | ||
15 | # When using deb, and rpm it is a bit different and we could test all | ||
16 | # of them, but this test is more to catch if other packages get added by | ||
17 | # default other than what is in ROOTFS_BOOTSTRAP_INSTALL. | ||
18 | # | ||
19 | class ContainerImageTests(oeSelfTest): | ||
20 | |||
21 | # Verify that when specifying a IMAGE_TYPEDEP_ of the form "foo.bar" that | ||
22 | # the conversion type bar gets added as a dep as well | ||
23 | def test_expected_files(self): | ||
24 | |||
25 | def get_each_path_part(path): | ||
26 | if path: | ||
27 | part = [ '.' + path + '/' ] | ||
28 | result = get_each_path_part(path.rsplit('/', 1)[0]) | ||
29 | if result: | ||
30 | return part + result | ||
31 | else: | ||
32 | return part | ||
33 | else: | ||
34 | return None | ||
35 | |||
36 | self.write_config("""PREFERRED_PROVIDER_virtual/kernel = "linux-dummy" | ||
37 | IMAGE_FSTYPES = "container" | ||
38 | PACKAGE_CLASSES = "package_ipk" | ||
39 | IMAGE_FEATURES = "" | ||
40 | """) | ||
41 | |||
42 | bbvars = get_bb_vars(['bindir', 'sysconfdir', 'localstatedir', | ||
43 | 'DEPLOY_DIR_IMAGE', 'IMAGE_LINK_NAME'], | ||
44 | target='container-test-image') | ||
45 | expected_files = [ | ||
46 | './', | ||
47 | '.{bindir}/theapp', | ||
48 | '.{sysconfdir}/default/', | ||
49 | '.{sysconfdir}/default/postinst', | ||
50 | '.{sysconfdir}/ld.so.cache', | ||
51 | '.{sysconfdir}/timestamp', | ||
52 | '.{sysconfdir}/version', | ||
53 | './run/', | ||
54 | '.{localstatedir}/cache/', | ||
55 | '.{localstatedir}/cache/ldconfig/', | ||
56 | '.{localstatedir}/cache/ldconfig/aux-cache', | ||
57 | '.{localstatedir}/cache/opkg/', | ||
58 | '.{localstatedir}/lib/', | ||
59 | '.{localstatedir}/lib/opkg/' | ||
60 | ] | ||
61 | |||
62 | expected_files = [ x.format(bindir=bbvars['bindir'], | ||
63 | sysconfdir=bbvars['sysconfdir'], | ||
64 | localstatedir=bbvars['localstatedir']) | ||
65 | for x in expected_files ] | ||
66 | |||
67 | # Since tar lists all directories individually, make sure each element | ||
68 | # from bindir, sysconfdir, etc is added | ||
69 | expected_files += get_each_path_part(bbvars['bindir']) | ||
70 | expected_files += get_each_path_part(bbvars['sysconfdir']) | ||
71 | expected_files += get_each_path_part(bbvars['localstatedir']) | ||
72 | |||
73 | expected_files = sorted(expected_files) | ||
74 | |||
75 | # Build the image of course | ||
76 | bitbake('container-test-image') | ||
77 | |||
78 | image = os.path.join(bbvars['DEPLOY_DIR_IMAGE'], | ||
79 | bbvars['IMAGE_LINK_NAME'] + '.tar.bz2') | ||
80 | |||
81 | # Ensure the files in the image are what we expect | ||
82 | result = runCmd("tar tf {} | sort".format(image), shell=True) | ||
83 | self.assertEqual(result.output.split('\n'), expected_files) | ||