CMake: Add a test for init-repository

The new test uses the recently introduced upstream cmake test
infrastructure module, to ensure the execution log output is identical
between the old perl script and new the cmake script for a few basic
use cases. It is not an exhaustive test of all features. It should
work on Windows, macOS, Linux (assuming perl is installed).

There are also a few tests that only apply to the cmake-script
version for features that exist only in the latter (like the 'existing'
module-subset key).

The test is a 'manual' test instead of an 'auto' test because we don't
really want to clone so many submodules as part of every qt5.git
integration in Coin.
In the future, we could potentially add a nightly Jenkins job to run
the tests.

Task-number: QTBUG-120030
Change-Id: I4201d734c2877109102518b073dec24bb63edc24
Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io>
Reviewed-by:  Alexey Edelev <alexey.edelev@qt.io>
This commit is contained in:
Alexandru Croitor 2023-12-15 11:22:55 +01:00
parent b742509973
commit 915b8d2f54
9 changed files with 275 additions and 0 deletions

View File

@ -8,6 +8,7 @@ macro(qt_ir_include_all_helpers)
include(QtIROptionsHelpers) include(QtIROptionsHelpers)
include(QtIRParsingHelpers) include(QtIRParsingHelpers)
include(QtIRProcessHelpers) include(QtIRProcessHelpers)
include(QtIRTestHelpers)
include(QtTopLevelHelpers) include(QtTopLevelHelpers)
endmacro() endmacro()

View File

@ -0,0 +1,12 @@
# Copyright (C) 2024 The Qt Company Ltd.
# SPDX-License-Identifier: BSD-3-Clause
cmake_minimum_required(VERSION 3.16)
project(tst_run_cmake_tests)
enable_testing()
include("${CMAKE_CURRENT_SOURCE_DIR}/Common.cmake")
add_RunCMake_test(InitRepository
-DCMAKE_SYSTEM_NAME=${CMAKE_SYSTEM_NAME}
)

View File

@ -0,0 +1,20 @@
# Copyright (C) 2024 The Qt Company Ltd.
# SPDX-License-Identifier: BSD-3-Clause
set(top_repo_dir_path "${CMAKE_CURRENT_LIST_DIR}/../../..")
get_filename_component(top_repo_dir_path "${top_repo_dir_path}" ABSOLUTE)
macro(qt_ir_setup_test_include_paths)
set(ir_script_path "${top_repo_dir_path}/cmake")
list(APPEND CMAKE_MODULE_PATH
"${ir_script_path}"
"${ir_script_path}/3rdparty/cmake"
)
include(QtIRHelpers)
qt_ir_include_all_helpers()
endmacro()
qt_ir_setup_test_include_paths()
# Used by add_RunCMake_test
set(CMAKE_CMAKE_COMMAND "${CMAKE_COMMAND}")
set(_isMultiConfig FALSE)

View File

@ -0,0 +1,13 @@
\+ git submodule init qtsvg
Submodule 'qtsvg' \(https://code.qt.io/qt/qtsvg.git\) registered for path 'qtsvg'
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git clone --no-checkout https://code.qt.io/qt/qtsvg.git qtsvg
Cloning into 'qtsvg'...
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qtsvg.git
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
\+ git submodule update --force --no-fetch
Submodule path 'qtsvg': checked out '[0-9a-zA-Z]+'
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qt5
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
Warning: cannot find Git hooks, qtrepotools module might be absent

View File

@ -0,0 +1 @@
Will not reinitialize already initialized repository \(use -f to force\)!

View File

@ -0,0 +1,12 @@
\+ git submodule init qtsvg
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.origin.url https://code.qt.io/qt/qtsvg.git
\+ git fetch origin
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qtsvg.git
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
\+ git submodule update --force --no-fetch
Submodule path 'qtsvg': checked out '[0-9a-zA-Z]+'
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qt5
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
Warning: cannot find Git hooks, qtrepotools module might be absent

View File

@ -0,0 +1,19 @@
\+ git submodule init qtshadertools qtsvg
Submodule 'qtshadertools' \(https://code.qt.io/qt/qtshadertools.git\) registered for path 'qtshadertools'
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git clone --no-checkout https://code.qt.io/qt/qtshadertools.git qtshadertools
Cloning into 'qtshadertools'...
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qtshadertools.git
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
\+ git config remote.origin.url https://code.qt.io/qt/qtsvg.git
\+ git fetch origin
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qtsvg.git
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
\+ git submodule update --force --no-fetch
Submodule path 'qtshadertools': checked out '[0-9a-zA-Z]+'
Submodule path 'qtsvg': checked out '[0-9a-zA-Z]+'
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qt5
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
Warning: cannot find Git hooks, qtrepotools module might be absent

View File

@ -0,0 +1,44 @@
\+ git submodule init qtshadertools qtsvg qtactiveqt qttools
Submodule 'qtactiveqt' \(https://code.qt.io/qt/qtactiveqt.git\) registered for path 'qtactiveqt'
Submodule 'qttools' \(https://code.qt.io/qt/qttools.git\) registered for path 'qttools'
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.origin.url https://code.qt.io/qt/qtshadertools.git
\+ git fetch origin
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qtshadertools.git
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
\+ git config remote.origin.url https://code.qt.io/qt/qtsvg.git
\+ git fetch origin
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qtsvg.git
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
\+ git clone --no-checkout https://code.qt.io/qt/qtactiveqt.git qtactiveqt
Cloning into 'qtactiveqt'...
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qtactiveqt.git
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
\+ git clone --no-checkout https://code.qt.io/qt/qttools.git qttools
Cloning into 'qttools'...
\+ git config commit.template .+/tests/manual/RunCMake/build/tmp.+/qt6/.commit-template
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qttools.git
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
\+ git submodule update --force --no-fetch
Submodule path 'qtactiveqt': checked out '[0-9a-zA-Z]+'
Submodule path 'qtshadertools': checked out '[0-9a-zA-Z]+'
Submodule path 'qtsvg': checked out '[0-9a-zA-Z]+'
Submodule path 'qttools': checked out '[0-9a-zA-Z]+'
\+ git submodule init src/assistant/qlitehtml
Submodule 'src/assistant/qlitehtml' \(https://code.qt.io/playground/qlitehtml.git\) registered for path 'src/assistant/qlitehtml'
\+ git clone --no-checkout https://code.qt.io/playground/qlitehtml.git src/assistant/qlitehtml
Cloning into 'src/assistant/qlitehtml'...
\+ git submodule update --force --no-fetch
Submodule path 'src/assistant/qlitehtml': checked out '[0-9a-zA-Z]+'
\+ git submodule init src/3rdparty/litehtml
Submodule 'src/3rdparty/litehtml' \(https://github.com/litehtml/litehtml.git\) registered for path 'src/3rdparty/litehtml'
\+ git clone --no-checkout https://github.com/litehtml/litehtml.git src/3rdparty/litehtml
Cloning into 'src/3rdparty/litehtml'...
\+ git submodule update --force --no-fetch
Submodule path 'src/3rdparty/litehtml': checked out '[0-9a-zA-Z]+'
\+ git config remote.gerrit.url ssh://codereview.qt-project.org/qt/qt5
\+ git config remote.gerrit.fetch \+refs/heads/\*:refs/remotes/gerrit/\* /heads/
Warning: cannot find Git hooks, qtrepotools module might be absent

View File

@ -0,0 +1,153 @@
# Copyright (C) 2024 The Qt Company Ltd.
# SPDX-License-Identifier: BSD-3-Clause
cmake_minimum_required(VERSION 3.16)
include("${CMAKE_CURRENT_SOURCE_DIR}/../Common.cmake")
# The file is included separately from Common.cmake because it has side-effects
# that we want to apply only in the RunCMake part of the test.
include(QtIRRunCMake)
# Uses prefix set from outside scope.
function(run_suite_command name)
run_cmake_command(${prefix}_${name} ${ARGN})
endfunction()
macro(read_expected_output test file_name)
set(expect "")
set(expect_path "${RunCMake_SOURCE_DIR}/${file_name}-stdout.txt")
if(EXISTS "${expect_path}")
file(READ "${expect_path}" expect)
endif()
if(NOT expect)
message(FATAL_ERROR "No expected output for test ${file_name}. "
"Make sure to add a ${file_name}-stdout.txt file.")
endif()
set(RunCMake_TEST_EXPECT_stdout "${expect}")
endmacro()
function(run_suite_test test_name)
set(options "ONLY_CMAKE")
set(oneValueArgs "EXPECT_NAME")
set(multiValueArgs "COMMAND_ARGS")
cmake_parse_arguments(arg "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
if(prefix STREQUAL "perl" AND arg_ONLY_CMAKE)
return()
endif()
if(arg_EXPECT_NAME)
set(expect_name "${arg_EXPECT_NAME}")
else()
set(expect_name "${test_name}")
endif()
read_expected_output(${test_name} ${expect_name})
run_suite_command(${test_name} ${arg_COMMAND_ARGS})
endfunction()
function(run_suite)
set(options
USE_PERL_SCRIPT
)
set(oneValueArgs "")
set(multiValueArgs "")
cmake_parse_arguments(arg "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
if(arg_USE_PERL_SCRIPT)
set(use_perl_script TRUE)
set(prefix "perl")
set(extra_ir_args "")
else()
set(use_perl_script FALSE)
set(prefix "cmake")
# When testing the cmake script, we don't want to resolve deps by default and
# we want output to be the same as the one shown by the perl script.
set(extra_ir_args "--no-resolve-deps" "--perl-identical-output")
endif()
# Set in Common.cmake
set(local_clone_url "${top_repo_dir_path}")
# Path to temp qt6 dir based on script used.
set(tmp_path "${CMAKE_CURRENT_SOURCE_DIR}/tmp_${prefix}")
set(qt6_repo_dir "${tmp_path}/qt6")
# Path to init-repository script
set(init_repository_script_path "${qt6_repo_dir}/init-repository")
if(use_perl_script)
string(APPEND init_repository_script_path ".pl")
# Need to call perl explicitly, especially on Windows
list(PREPEND init_repository_script_path perl)
elseif(CMAKE_HOST_WIN32)
string(APPEND init_repository_script_path ".bat")
endif()
# Clean up the temp qt6 repo dir.
file(REMOVE_RECURSE "${qt6_repo_dir}")
file(REMOVE_RECURSE "${tmp_path}")
file(MAKE_DIRECTORY "${tmp_path}")
set(RunCMake_TEST_COMMAND_WORKING_DIRECTORY "${tmp_path}")
# Make a copy of the qt6 repo
run_suite_command(0010_prepare_qt6_clone git clone "${local_clone_url}" qt6 --quiet)
set(RunCMake_TEST_COMMAND_WORKING_DIRECTORY "${qt6_repo_dir}")
# Adjust its remote url to be the official mirror rather the local url.
set(remote_clone_url "https://code.qt.io/qt/qt5.git")
run_suite_command(0020_set_qt6_remote_url git remote set-url origin "${remote_clone_url}")
# Ignore certain lines
set(RunCMake_TEST_EXTRA_IGNORE_LINE_REGEX
"|Trace will be written to"
"|Put cmake in trace mode, but with variables expanded"
"|Put cmake in trace mode and redirect trace output"
)
# Merge stdout with stderr, otherwise we can't test for the same output across script
# implementations, because CMake has no easy way to control with output stream
# should be used.
set(RunCMake_TEST_OUTPUT_MERGE TRUE)
# Initialize just qtsvg
run_suite_test(0030_ir_qtsvg
COMMAND_ARGS ${init_repository_script_path} --module-subset=qtsvg ${extra_ir_args})
# Asking to do it again will refuse to do it, unless forced, because the repo has already been
# initialized. Only do this check for cmake, because the perl script checks for initialization
# if qtbase is initialized, and we don't want to test that because cloning qtbase just for the
# test is too slow.
run_suite_test(0040_ir_qtsvg_again
ONLY_CMAKE
COMMAND_ARGS ${init_repository_script_path} --module-subset=qtsvg ${extra_ir_args})
# Configuring without a module-subset will initialize qtsvg again, because the new behavior
# of the cmake script is to initialize previously existing submodules, rather than all of them.
run_suite_test(0050_ir_existing
ONLY_CMAKE
COMMAND_ARGS ${init_repository_script_path} -f ${extra_ir_args})
# Initialize more than one submodule, choosing the smaller ones, for faster cloning.
run_suite_test(0060_ir_shadertools_and_svg
COMMAND_ARGS ${init_repository_script_path}
--module-subset=qtshadertools,qtsvg -f
${extra_ir_args})
# Initialize qttools with dependencies, but without qtbase and qtdeclarative.
# This should also clone qtactiveqt.
list(REMOVE_ITEM extra_ir_args "--no-resolve-deps")
run_suite_test(0070_ir_qttools_with_deps
ONLY_CMAKE
COMMAND_ARGS ${init_repository_script_path}
--module-subset=qttools,-qtbase,-qtdeclarative,-qtimageformats,-qtlanguageserver -f
${extra_ir_args})
# Unset the working dir for further tests.
unset(RunCMake_TEST_COMMAND_WORKING_DIRECTORY)
endfunction()
run_suite()
run_suite(USE_PERL_SCRIPT)