diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-04-28 11:53:59 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-04-29 10:39:40 +0100 |
commit | 18160403427b2aab4207c939312fb0981c3f2d1b (patch) | |
tree | 5c4742c38ca8e7d867844c4fdcf85f85f95ba0ac /meta/lib/oeqa/sdk/gcc.py | |
parent | 79770ca14a0cc2f4112fb4d8dc2d8832701b6d5d (diff) | |
download | openembedded-core-18160403427b2aab4207c939312fb0981c3f2d1b.tar.gz openembedded-core-18160403427b2aab4207c939312fb0981c3f2d1b.tar.bz2 openembedded-core-18160403427b2aab4207c939312fb0981c3f2d1b.zip |
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.
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/lib/oeqa/sdk/gcc.py')
-rw-r--r-- | meta/lib/oeqa/sdk/gcc.py | 36 |
1 files changed, 36 insertions, 0 deletions
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 @@ +import unittest +import os +import shutil +from oeqa.oetest import oeSDKTest, skipModule +from oeqa.utils.decorators import * + +def setUpModule(): + machine = oeSDKTest.tc.d.getVar("MACHINE", True) + if not oeSDKTest.hasHostPackage("packagegroup-cross-canadian-" + machine): + skipModule("SDK doesn't contain a cross-canadian toolchain") + + +class GccCompileTest(oeSDKTest): + + @classmethod + def setUpClass(self): + for f in ['test.c', 'test.cpp', 'testmakefile']: + shutil.copyfile(os.path.join(self.tc.filesdir, f), self.tc.sdktestdir + f) + + def test_gcc_compile(self): + self._run('$CC %s/test.c -o %s/test -lm' % (self.tc.sdktestdir, self.tc.sdktestdir)) + + def test_gpp_compile(self): + self._run('$CXX %s/test.c -o %s/test -lm' % (self.tc.sdktestdir, self.tc.sdktestdir)) + + def test_gpp2_compile(self): + self._run('$CXX %s/test.cpp -o %s/test -lm' % (self.tc.sdktestdir, self.tc.sdktestdir)) + + def test_make(self): + self._run('cd %s; make -f testmakefile' % self.tc.sdktestdir) + + @classmethod + def tearDownClass(self): + files = [self.tc.sdktestdir + f for f in ['test.c', 'test.cpp', 'test.o', 'test', 'testmakefile']] + for f in files: + bb.utils.remove(f) |