summaryrefslogtreecommitdiffstats
path: root/meta/lib
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2015-04-28 11:53:59 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2015-04-29 10:58:55 +0100
commit26997d1d21453447e952c32ada2a7faa1a849db7 (patch)
tree6f34767d56f90733a26f3e23eea715a334649e0b /meta/lib
parent527b28c10955daf0387597020d69593ce24bcaa4 (diff)
downloadpoky-26997d1d21453447e952c32ada2a7faa1a849db7.tar.gz
lib/oeqa: Add sdk tests for gcc/perl/python
Enhance testing of the generated SDK tarballs by adding tests for gcc/perl/python based on the existing runtime tests. (From OE-Core rev: 18160403427b2aab4207c939312fb0981c3f2d1b) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/lib')
-rw-r--r--meta/lib/oeqa/oetest.py10
-rw-r--r--meta/lib/oeqa/sdk/gcc.py36
-rw-r--r--meta/lib/oeqa/sdk/perl.py28
-rw-r--r--meta/lib/oeqa/sdk/python.py32
4 files changed, 106 insertions, 0 deletions
diff --git a/meta/lib/oeqa/oetest.py b/meta/lib/oeqa/oetest.py
index da9556a6da..22d76b35e1 100644
--- a/meta/lib/oeqa/oetest.py
+++ b/meta/lib/oeqa/oetest.py
@@ -129,6 +129,16 @@ class oeSDKTest(oeTest):
129 self.sdktestdir = oeSDKTest.tc.sdktestdir 129 self.sdktestdir = oeSDKTest.tc.sdktestdir
130 super(oeSDKTest, self).__init__(methodName) 130 super(oeSDKTest, self).__init__(methodName)
131 131
132 @classmethod
133 def hasHostPackage(self, pkg):
134
135 if re.search(pkg, oeTest.tc.hostpkgmanifest):
136 return True
137 return False
138
139 def _run(self, cmd):
140 return subprocess.check_output(cmd, shell=True)
141
132def getmodule(pos=2): 142def getmodule(pos=2):
133 # stack returns a list of tuples containg frame information 143 # stack returns a list of tuples containg frame information
134 # First element of the list the is current frame, caller is 1 144 # First element of the list the is current frame, caller is 1
diff --git a/meta/lib/oeqa/sdk/gcc.py b/meta/lib/oeqa/sdk/gcc.py
new file mode 100644
index 0000000000..67994b9b5a
--- /dev/null
+++ b/meta/lib/oeqa/sdk/gcc.py
@@ -0,0 +1,36 @@
1import unittest
2import os
3import shutil
4from oeqa.oetest import oeSDKTest, skipModule
5from oeqa.utils.decorators import *
6
7def setUpModule():
8 machine = oeSDKTest.tc.d.getVar("MACHINE", True)
9 if not oeSDKTest.hasHostPackage("packagegroup-cross-canadian-" + machine):
10 skipModule("SDK doesn't contain a cross-canadian toolchain")
11
12
13class GccCompileTest(oeSDKTest):
14
15 @classmethod
16 def setUpClass(self):
17 for f in ['test.c', 'test.cpp', 'testmakefile']:
18 shutil.copyfile(os.path.join(self.tc.filesdir, f), self.tc.sdktestdir + f)
19
20 def test_gcc_compile(self):
21 self._run('$CC %s/test.c -o %s/test -lm' % (self.tc.sdktestdir, self.tc.sdktestdir))
22
23 def test_gpp_compile(self):
24 self._run('$CXX %s/test.c -o %s/test -lm' % (self.tc.sdktestdir, self.tc.sdktestdir))
25
26 def test_gpp2_compile(self):
27 self._run('$CXX %s/test.cpp -o %s/test -lm' % (self.tc.sdktestdir, self.tc.sdktestdir))
28
29 def test_make(self):
30 self._run('cd %s; make -f testmakefile' % self.tc.sdktestdir)
31
32 @classmethod
33 def tearDownClass(self):
34 files = [self.tc.sdktestdir + f for f in ['test.c', 'test.cpp', 'test.o', 'test', 'testmakefile']]
35 for f in files:
36 bb.utils.remove(f)
diff --git a/meta/lib/oeqa/sdk/perl.py b/meta/lib/oeqa/sdk/perl.py
new file mode 100644
index 0000000000..45f422ef0b
--- /dev/null
+++ b/meta/lib/oeqa/sdk/perl.py
@@ -0,0 +1,28 @@
1import unittest
2import os
3import shutil
4from oeqa.oetest import oeSDKTest, skipModule
5from oeqa.utils.decorators import *
6
7def setUpModule():
8 if not oeSDKTest.hasHostPackage("nativesdk-perl"):
9 skipModule("No perl package in the SDK")
10
11
12class PerlTest(oeSDKTest):
13
14 @classmethod
15 def setUpClass(self):
16 for f in ['test.pl']:
17 shutil.copyfile(os.path.join(self.tc.filesdir, f), self.tc.sdktestdir + f)
18 self.testfile = self.tc.sdktestdir + "test.pl"
19
20 def test_perl_exists(self):
21 self._run('which perl')
22
23 def test_perl_works(self):
24 self._run('perl %s/test.pl' % self.tc.sdktestdir)
25
26 @classmethod
27 def tearDownClass(self):
28 bb.utils.remove("%s/test.pl" % self.tc.sdktestdir)
diff --git a/meta/lib/oeqa/sdk/python.py b/meta/lib/oeqa/sdk/python.py
new file mode 100644
index 0000000000..896fab4dfb
--- /dev/null
+++ b/meta/lib/oeqa/sdk/python.py
@@ -0,0 +1,32 @@
1import unittest
2import os
3import shutil
4from oeqa.oetest import oeSDKTest, skipModule
5from oeqa.utils.decorators import *
6
7def setUpModule():
8 if not oeSDKTest.hasHostPackage("nativesdk-python"):
9 skipModule("No python package in the SDK")
10
11
12class PythonTest(oeSDKTest):
13
14 @classmethod
15 def setUpClass(self):
16 for f in ['test.py']:
17 shutil.copyfile(os.path.join(self.tc.filesdir, f), self.tc.sdktestdir + f)
18
19 def test_python_exists(self):
20 self._run('which python')
21
22 def test_python_stdout(self):
23 output = self._run('python %s/test.py' % self.tc.sdktestdir)
24 self.assertEqual(output.strip(), "the value of a is 0.01", msg="Incorrect output: %s" % output)
25
26 def test_python_testfile(self):
27 self._run('ls /tmp/testfile.python')
28
29 @classmethod
30 def tearDownClass(self):
31 bb.utils.remove("%s/test.py" % self.tc.sdktestdir)
32 bb.utils.remove("/tmp/testfile.python")