aboutsummaryrefslogtreecommitdiff
path: root/run_project_tests.py
diff options
context:
space:
mode:
authorElliott Sales de Andrade <quantum.analyst@gmail.com>2018-04-19 21:26:49 -0400
committerJussi Pakkanen <jpakkane@gmail.com>2018-04-21 16:58:55 +0300
commit8dd6b8c7eda1197d5ccf8d604c70ff183c84e634 (patch)
treea85cc9f6cf9d85802a8b4ab5c31d13e93f2a63d5 /run_project_tests.py
parent78495b21e70d96ed94bfa91dfe62a923f60f4b29 (diff)
downloadmeson-8dd6b8c7eda1197d5ccf8d604c70ff183c84e634.zip
meson-8dd6b8c7eda1197d5ccf8d604c70ff183c84e634.tar.gz
meson-8dd6b8c7eda1197d5ccf8d604c70ff183c84e634.tar.bz2
Fix install checks when cross-compiling.
It checks the build machine for the correct extensions of resulting binaries, but it should be checking the host machine.
Diffstat (limited to 'run_project_tests.py')
-rwxr-xr-xrun_project_tests.py19
1 files changed, 9 insertions, 10 deletions
diff --git a/run_project_tests.py b/run_project_tests.py
index a1d36ef..b44a723 100755
--- a/run_project_tests.py
+++ b/run_project_tests.py
@@ -21,10 +21,7 @@ from io import StringIO
from ast import literal_eval
from enum import Enum
import tempfile
-from mesonbuild import mtest
-from mesonbuild import environment
-from mesonbuild import mesonlib
-from mesonbuild import mlog
+from mesonbuild import build, environment, mesonlib, mlog, mtest
from mesonbuild.mesonlib import stringlistify, Popen_safe
from mesonbuild.coredata import backendlist
import argparse
@@ -137,9 +134,9 @@ def get_relative_files_list_from_dir(fromdir):
paths.append(path)
return paths
-def platform_fix_name(fname, compiler):
+def platform_fix_name(fname, compiler, env):
if '?lib' in fname:
- if mesonlib.is_cygwin():
+ if mesonlib.for_cygwin(env.is_cross_build(), env):
fname = re.sub(r'lib/\?lib(.*)\.so$', r'bin/cyg\1.dll', fname)
fname = re.sub(r'\?lib(.*)\.dll$', r'cyg\1.dll', fname)
else:
@@ -147,7 +144,7 @@ def platform_fix_name(fname, compiler):
if fname.endswith('?exe'):
fname = fname[:-4]
- if mesonlib.is_windows() or mesonlib.is_cygwin():
+ if mesonlib.for_windows(env.is_cross_build(), env) or mesonlib.for_cygwin(env.is_cross_build(), env):
return fname + '.exe'
if fname.startswith('?msvc:'):
@@ -162,7 +159,7 @@ def platform_fix_name(fname, compiler):
return fname
-def validate_install(srcdir, installdir, compiler):
+def validate_install(srcdir, installdir, compiler, env):
# List of installed files
info_file = os.path.join(srcdir, 'installed_files.txt')
# If this exists, the test does not install any other files
@@ -175,7 +172,7 @@ def validate_install(srcdir, installdir, compiler):
elif os.path.exists(info_file):
with open(info_file) as f:
for line in f:
- line = platform_fix_name(line.strip(), compiler)
+ line = platform_fix_name(line.strip(), compiler, env)
if line:
expected[line] = False
# Check if expected files were found
@@ -328,6 +325,7 @@ def _run_test(testdir, test_build_dir, install_dir, extra_args, compiler, backen
return TestResult('Test that should have failed succeeded', BuildStep.configure, stdo, stde, mesonlog, gen_time)
if returncode != 0:
return TestResult('Generating the build system failed.', BuildStep.configure, stdo, stde, mesonlog, gen_time)
+ builddata = build.load(test_build_dir)
# Touch the meson.build file to force a regenerate so we can test that
# regeneration works before a build is run.
ensure_backend_detects_changes(backend)
@@ -381,7 +379,8 @@ def _run_test(testdir, test_build_dir, install_dir, extra_args, compiler, backen
return TestResult('Running clean failed.', BuildStep.clean, stdo, stde, mesonlog, gen_time, build_time, test_time)
if not install_commands:
return TestResult('', BuildStep.install, '', '', mesonlog, gen_time, build_time, test_time)
- return TestResult(validate_install(testdir, install_dir, compiler), BuildStep.validate, stdo, stde, mesonlog, gen_time, build_time, test_time)
+ return TestResult(validate_install(testdir, install_dir, compiler, builddata.environment),
+ BuildStep.validate, stdo, stde, mesonlog, gen_time, build_time, test_time)
def gather_tests(testdir):
tests = [t.replace('\\', '/').split('/', 2)[2] for t in glob(testdir + '/*')]