summaryrefslogtreecommitdiffstats
path: root/meta/lib/oeqa/sdk/case.py
blob: 1fd3b3b5695dd5fac32c7d96e29785fbab467907 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
#
# Copyright (C) 2016 Intel Corporation
#
# SPDX-License-Identifier: MIT
#

import os
import subprocess
import shutil
import unittest

from oeqa.core.case import OETestCase
from oeqa.sdkext.context import OESDKExtTestContext

class OESDKTestCase(OETestCase):
    def _run(self, cmd):
        return subprocess.check_output(". %s > /dev/null; %s;" % \
                (self.tc.sdk_env, cmd), shell=True, executable="/bin/bash",
                stderr=subprocess.STDOUT, universal_newlines=True)

    def ensure_host_package(self, *packages, recipe=None):
        """
        Check that the host variation of one of the packages listed is available
        in the SDK (nativesdk-foo for SDK, foo-native for eSDK). The package is
        a list for the case where debian-renaming may have occured, and the
        manifest could contain 'foo' or 'libfoo'.

        If testing an eSDK and the package is not found, then try to install the
        specified recipe to install it from sstate.
        """

        # In a SDK the manifest is correct. In an eSDK the manifest may be
        # correct (type=full) or not include packages that exist in sstate but
        # not installed yet (minimal) so we should try to install the recipe.
        for package in packages:
            if isinstance(self.tc, OESDKExtTestContext):
                package = package + "-native"
            else:
                package = "nativesdk-" + package

            if self.tc.hasHostPackage(package):
                break
        else:
            if isinstance(self.tc, OESDKExtTestContext):
                recipe = (recipe or packages[0]) + "-native"
                print("Trying to install %s..." % recipe)
                self._run('devtool sdk-install %s' % recipe)
            else:
                raise unittest.SkipTest("Test %s needs one of %s" % (self.id(), ", ".join(packages)))

    def ensure_target_package(self, *packages, multilib=False, recipe=None):
        """
        Check that at least one of the packages listed is available in the SDK,
        adding the multilib prefix if required. The target package is a list for
        the case where debian-renaming may have occured, and the manifest could
        contain 'foo' or 'libfoo'.

        If testing an eSDK and the package is not found, then try to install the
        specified recipe to install it from sstate.
        """

        # In a SDK the manifest is correct. In an eSDK the manifest may be
        # correct (type=full) or not include packages that exist in sstate but
        # not installed yet (minimal) so we should try to install the recipe.
        for package in packages:
            if self.tc.hasTargetPackage(package, multilib=multilib):
                break
        else:
            if isinstance(self.tc, OESDKExtTestContext):
                recipe = recipe or packages[0]
                print("Trying to install %s..." % recipe)
                self._run('devtool sdk-install %s' % recipe)
            else:
                raise unittest.SkipTest("Test %s needs one of %s" % (self.id(), ", ".join(packages)))


    def fetch(self, workdir, dl_dir, url, archive=None):
        if not archive:
            from urllib.parse import urlparse
            archive = os.path.basename(urlparse(url).path)

        if dl_dir:
            archive_tarball = os.path.join(dl_dir, archive)
            if os.path.exists(archive_tarball):
                return archive_tarball

        tarball = os.path.join(workdir, archive)
        subprocess.check_output(["wget", "-O", tarball, url], stderr=subprocess.STDOUT)
        if dl_dir and not os.path.exists(archive_tarball):
            shutil.copyfile(tarball, archive_tarball)
        return tarball

    def check_elf(self, path, target_os=None, target_arch=None):
        """
        Verify that the ELF binary $path matches the specified target
        OS/architecture, or if not specified the currently configured MACHINE's
        OS/architecture.
        """
        import oe.qa, oe.elf

        if not target_os or not target_arch:
            output = self._run("echo $OECORE_TARGET_OS:$OECORE_TARGET_ARCH")
            target_os, target_arch = output.strip().split(":")

        machine_data = oe.elf.machine_dict(None)[target_os][target_arch]
        (machine, osabi, abiversion, endian, bits) = machine_data

        elf = oe.qa.ELFFile(path)
        elf.open()

        self.assertEqual(machine, elf.machine(),
                         "Binary was %s but expected %s" %
                         (oe.qa.elf_machine_to_string(elf.machine()), oe.qa.elf_machine_to_string(machine)))
        self.assertEqual(bits, elf.abiSize())
        self.assertEqual(endian, elf.isLittleEndian())