mirror of
https://github.com/bensuperpc/dockcross.git
synced 2024-12-22 16:24:27 +01:00
android-arm: Test and deploy with CircleCI.
Although adding --emulator /usr/bin/qemu-arm -b CMake --linker-flags="-static" To the test command works locally, the CMake tests fail on CircleCI. May this is due to a kernel difference? Will investigate adding again later after CircleCI updates in kernel (it is currently Ubuntu 12.04). The "-static" linker flag used during testing is explained here: https://www.kitware.com/blog/home/post/893
This commit is contained in:
parent
0e8478d1db
commit
609605b1c5
@ -6,11 +6,14 @@ dependencies:
|
|||||||
override:
|
override:
|
||||||
- docker info
|
- docker info
|
||||||
- docker pull thewtex/cross-compiler-base
|
- docker pull thewtex/cross-compiler-base
|
||||||
|
- docker pull thewtex/cross-compiler-android-arm
|
||||||
|
|
||||||
test:
|
test:
|
||||||
override:
|
override:
|
||||||
- make base
|
- make base
|
||||||
- docker run --rm -v ~/cross-compilers/test/:/usr/src/test:ro thewtex/cross-compiler-base python /usr/src/test/run.py --emulator 'sh -c'
|
- docker run --rm -v ~/cross-compilers/test/:/usr/src/test:ro thewtex/cross-compiler-base python /usr/src/test/run.py --emulator 'sh -c'
|
||||||
|
- make android-arm
|
||||||
|
- docker run --rm -v ~/cross-compilers/test/:/usr/src/test:ro thewtex/cross-compiler-android-arm python /usr/src/test/run.py
|
||||||
|
|
||||||
deployment:
|
deployment:
|
||||||
hub:
|
hub:
|
||||||
@ -18,3 +21,4 @@ deployment:
|
|||||||
commands:
|
commands:
|
||||||
- docker login -e $DOCKER_EMAIL -u $DOCKER_USER -p $DOCKER_PASS
|
- docker login -e $DOCKER_EMAIL -u $DOCKER_USER -p $DOCKER_PASS
|
||||||
- docker push thewtex/cross-compiler-base
|
- docker push thewtex/cross-compiler-base
|
||||||
|
- docker push thewtex/cross-compiler-android-arm
|
||||||
|
69
test/run.py
69
test/run.py
@ -14,21 +14,31 @@ import subprocess
|
|||||||
import sys
|
import sys
|
||||||
import tempfile
|
import tempfile
|
||||||
|
|
||||||
def test_none_build_system(build_dir, language, source):
|
def test_none_build_system(build_dir, language, source, linker_flags):
|
||||||
|
build_cmd = list()
|
||||||
if language == 'C':
|
if language == 'C':
|
||||||
compiler = os.getenv('CC', 'cc')
|
compiler = os.getenv('CC', 'cc')
|
||||||
elif language == 'C++':
|
elif language == 'C++':
|
||||||
compiler = os.getenv('C++', 'c++')
|
compiler = os.getenv('CXX', 'c++')
|
||||||
else:
|
else:
|
||||||
print('Unknown language: ' + language)
|
print('Unknown language: ' + language)
|
||||||
return 1
|
return 1
|
||||||
|
build_cmd.append(compiler)
|
||||||
|
if linker_flags:
|
||||||
|
build_cmd.extend(linker_flags)
|
||||||
|
build_cmd.append(source)
|
||||||
|
|
||||||
print('Building ' + source + ' by calling ' + compiler + '...')
|
print('Building ' + source + ' by calling ' + compiler + '...')
|
||||||
|
print(' '.join(build_cmd))
|
||||||
sys.stdout.flush()
|
sys.stdout.flush()
|
||||||
return subprocess.call([compiler, source])
|
|
||||||
|
return subprocess.call(build_cmd)
|
||||||
|
|
||||||
|
|
||||||
def test_cmake_build_system(build_dir, source, emulator):
|
def test_cmake_build_system(build_dir, language, source, emulator, linker_flags):
|
||||||
shutil.copy(source, build_dir)
|
shutil.copy(source, build_dir)
|
||||||
|
print('Building ' + source + ' with CMake...')
|
||||||
|
|
||||||
with open('CMakeLists.txt', 'w') as fp:
|
with open('CMakeLists.txt', 'w') as fp:
|
||||||
fp.write('cmake_minimum_required(VERSION 3.0)\n')
|
fp.write('cmake_minimum_required(VERSION 3.0)\n')
|
||||||
fp.write('project(test-compiler)\n')
|
fp.write('project(test-compiler)\n')
|
||||||
@ -36,13 +46,23 @@ def test_cmake_build_system(build_dir, source, emulator):
|
|||||||
if emulator:
|
if emulator:
|
||||||
fp.write('enable_testing()\n')
|
fp.write('enable_testing()\n')
|
||||||
fp.write('add_test(emulator-in-cmake a.out)\n')
|
fp.write('add_test(emulator-in-cmake a.out)\n')
|
||||||
|
|
||||||
os.mkdir('build')
|
os.mkdir('build')
|
||||||
os.chdir('build')
|
os.chdir('build')
|
||||||
print('Building ' + source + ' with CMake...')
|
|
||||||
|
cmake_configuration_cmd = ['cmake', '..']
|
||||||
|
if linker_flags:
|
||||||
|
cmake_configuration_cmd.insert(1,
|
||||||
|
'-DCMAKE_EXE_LINKER_FLAGS="{0}"'.format(' '.join(linker_flags)))
|
||||||
|
toolchain_file = os.getenv('CMAKE_TOOLCHAIN_FILE')
|
||||||
|
if toolchain_file:
|
||||||
|
cmake_configuration_cmd.insert(1,
|
||||||
|
'-DCMAKE_TOOLCHAIN_FILE={0}'.format(toolchain_file))
|
||||||
|
print(' '.join(cmake_configuration_cmd))
|
||||||
sys.stdout.flush()
|
sys.stdout.flush()
|
||||||
if subprocess.call(['cmake', '..']):
|
if subprocess.call(cmake_configuration_cmd):
|
||||||
return 1
|
return 1
|
||||||
if subprocess.call(['make']):
|
if subprocess.call(['make', 'VERBOSE=1']):
|
||||||
return 1
|
return 1
|
||||||
if emulator:
|
if emulator:
|
||||||
if subprocess.call(['ctest']):
|
if subprocess.call(['ctest']):
|
||||||
@ -51,16 +71,16 @@ def test_cmake_build_system(build_dir, source, emulator):
|
|||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
|
||||||
def test_source(source, language, build_system, emulator):
|
def test_source(source, language, build_system, emulator, linker_flags):
|
||||||
result = 0
|
result = 0
|
||||||
cwd = os.getcwd()
|
cwd = os.getcwd()
|
||||||
build_dir = tempfile.mkdtemp()
|
build_dir = tempfile.mkdtemp()
|
||||||
os.chdir(build_dir)
|
os.chdir(build_dir)
|
||||||
|
|
||||||
if build_system == 'None':
|
if build_system == 'None':
|
||||||
result += test_none_build_system(build_dir, language, source)
|
result += test_none_build_system(build_dir, language, source, linker_flags)
|
||||||
elif build_system == 'CMake':
|
elif build_system == 'CMake':
|
||||||
result += test_cmake_build_system(build_dir, source, emulator)
|
result += test_cmake_build_system(build_dir, language, source, emulator, linker_flags)
|
||||||
else:
|
else:
|
||||||
print('Unknown build system: ' + build_system)
|
print('Unknown build system: ' + build_system)
|
||||||
result += 1
|
result += 1
|
||||||
@ -78,44 +98,54 @@ def test_source(source, language, build_system, emulator):
|
|||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
def test_build_system(test_dir, language, build_system, emulator):
|
def test_build_system(test_dir, language, build_system, emulator, linker_flags):
|
||||||
print('\n\n--------------------------------------------------------')
|
print('\n\n--------------------------------------------------------')
|
||||||
print('Testing ' + build_system + ' build system with the ' +
|
print('Testing ' + build_system + ' build system with the ' +
|
||||||
language + ' language\n')
|
language + ' language\n')
|
||||||
sys.stdout.flush()
|
sys.stdout.flush()
|
||||||
result = 0
|
result = 0
|
||||||
for source in glob.glob(os.path.join(test_dir, language, '*')):
|
for source in glob.glob(os.path.join(test_dir, language, '*')):
|
||||||
result += test_source(source, language, build_system, emulator)
|
result += test_source(source, language, build_system, emulator, linker_flags)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
def test_language(test_dir, language, build_systems, emulator):
|
def test_language(test_dir, language, build_systems, emulator, linker_flags):
|
||||||
result = 0
|
result = 0
|
||||||
for build_system in build_systems:
|
for build_system in build_systems:
|
||||||
result += test_build_system(test_dir, language, build_system, emulator)
|
result += test_build_system(test_dir,
|
||||||
|
language,
|
||||||
|
build_system,
|
||||||
|
emulator,
|
||||||
|
linker_flags)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
def run_tests(test_dir, languages=('C', 'C++'), build_systems=('None', 'CMake'),
|
def run_tests(test_dir, languages=('C', 'C++'), build_systems=('None', 'CMake'),
|
||||||
emulator=None):
|
emulator=None, linker_flags=None):
|
||||||
"""Run the tests found in test_dir where each directory corresponds to an
|
"""Run the tests found in test_dir where each directory corresponds to an
|
||||||
entry in languages. Every source within a language directory is built. The
|
entry in languages. Every source within a language directory is built. The
|
||||||
output executable is also run with the emulator if provided."""
|
output executable is also run with the emulator if provided."""
|
||||||
result = 0
|
result = 0
|
||||||
for language in languages:
|
for language in languages:
|
||||||
result += test_language(test_dir, language, build_systems, emulator)
|
result += test_language(test_dir,
|
||||||
|
language,
|
||||||
|
build_systems,
|
||||||
|
emulator,
|
||||||
|
linker_flags)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
parser = argparse.ArgumentParser(
|
parser = argparse.ArgumentParser(
|
||||||
description='Test the cross-compiler toolchain.')
|
description='Test the cross-compiler toolchain.')
|
||||||
parser.add_argument('--languages', nargs='+', default=['C', 'C++'],
|
parser.add_argument('--languages', '-l', nargs='+', default=['C', 'C++'],
|
||||||
help='Languages to test. Options: C C++')
|
help='Languages to test. Options: C C++')
|
||||||
parser.add_argument('--build-systems', nargs='+', default=['None', 'CMake'],
|
parser.add_argument('--build-systems', '-b', nargs='+', default=['None', 'CMake'],
|
||||||
help='Build systems to test. Options: None CMake')
|
help='Build systems to test. Options: None CMake')
|
||||||
parser.add_argument('--emulator', '-e',
|
parser.add_argument('--emulator', '-e',
|
||||||
help='Emulator used to test generated executables')
|
help='Emulator used to test generated executables')
|
||||||
|
parser.add_argument('--linker-flags', '-w', nargs='+',
|
||||||
|
help='Extra compilation linker flags')
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
test_dir = os.path.dirname(os.path.abspath(__file__))
|
test_dir = os.path.dirname(os.path.abspath(__file__))
|
||||||
@ -123,4 +153,5 @@ if __name__ == '__main__':
|
|||||||
sys.exit(run_tests(test_dir,
|
sys.exit(run_tests(test_dir,
|
||||||
languages=args.languages,
|
languages=args.languages,
|
||||||
build_systems=args.build_systems,
|
build_systems=args.build_systems,
|
||||||
emulator=args.emulator) != 0)
|
emulator=args.emulator,
|
||||||
|
linker_flags=args.linker_flags) != 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user