mkspecs: Add a benchmark "feature".
Testcases and benchmarks are rather different entities. You won't usually want to run benchmarks in the same environment you are wanting to run tests in, so this feature allows to differentiate between the two. We also add a "benchmark" make target (similar to check), which runs all configured benchmarks. Change-Id: I33759ce44c34e42a6a3a88f34e7b9c4372380721 Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@theqtcompany.com>
This commit is contained in:
parent
afe3c30759
commit
76f6ceec36
1
mkspecs/features/benchmark.prf
Normal file
1
mkspecs/features/benchmark.prf
Normal file
@ -0,0 +1 @@
|
|||||||
|
load(testcase)
|
@ -6,13 +6,16 @@ have_target {
|
|||||||
# qt_build_config tells us to re-enable exceptions here.
|
# qt_build_config tells us to re-enable exceptions here.
|
||||||
testcase_exceptions: CONFIG += exceptions
|
testcase_exceptions: CONFIG += exceptions
|
||||||
|
|
||||||
check.files =
|
benchmark: type = benchmark
|
||||||
check.path = .
|
else: type = check
|
||||||
|
|
||||||
|
$${type}.files =
|
||||||
|
$${type}.path = .
|
||||||
|
|
||||||
# Add environment for non-installed builds. Do this first, so the
|
# Add environment for non-installed builds. Do this first, so the
|
||||||
# 'make' variable expansions don't end up in a batch file/script.
|
# 'make' variable expansions don't end up in a batch file/script.
|
||||||
QT_TOOL_NAME = target
|
QT_TOOL_NAME = target
|
||||||
qtAddTargetEnv(check.commands, QT)
|
qtAddTargetEnv($${type}.commands, QT)
|
||||||
|
|
||||||
# If the test ends up in a different directory, we should cd to that directory.
|
# If the test ends up in a different directory, we should cd to that directory.
|
||||||
TESTRUN_CWD = $$DESTDIR
|
TESTRUN_CWD = $$DESTDIR
|
||||||
@ -27,44 +30,44 @@ debug_and_release:debug_and_release_target {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Allow for a custom test runner script
|
# Allow for a custom test runner script
|
||||||
check.commands += $(TESTRUNNER)
|
$${type}.commands += $(TESTRUNNER)
|
||||||
|
|
||||||
unix {
|
unix {
|
||||||
isEmpty(TEST_TARGET_DIR): TEST_TARGET_DIR = .
|
isEmpty(TEST_TARGET_DIR): TEST_TARGET_DIR = .
|
||||||
|
|
||||||
app_bundle: \
|
app_bundle: \
|
||||||
check.commands += $${TEST_TARGET_DIR}/$(QMAKE_TARGET).app/Contents/MacOS/$(QMAKE_TARGET)
|
$${type}.commands += $${TEST_TARGET_DIR}/$(QMAKE_TARGET).app/Contents/MacOS/$(QMAKE_TARGET)
|
||||||
else: \
|
else: \
|
||||||
check.commands += $${TEST_TARGET_DIR}/$(QMAKE_TARGET)
|
$${type}.commands += $${TEST_TARGET_DIR}/$(QMAKE_TARGET)
|
||||||
} else {
|
} else {
|
||||||
# Windows
|
# Windows
|
||||||
!isEmpty(TEST_TARGET_DIR): TEST_TARGET_DIR = $${TEST_TARGET_DIR}$${QMAKE_DIR_SEP}
|
!isEmpty(TEST_TARGET_DIR): TEST_TARGET_DIR = $${TEST_TARGET_DIR}$${QMAKE_DIR_SEP}
|
||||||
check.commands += $${TEST_TARGET_DIR}$(TARGET)
|
$${type}.commands += $${TEST_TARGET_DIR}$(TARGET)
|
||||||
}
|
}
|
||||||
|
|
||||||
# Allow for custom arguments to tests
|
# Allow for custom arguments to tests
|
||||||
check.commands += $(TESTARGS)
|
$${type}.commands += $(TESTARGS)
|
||||||
|
|
||||||
!isEmpty(TESTRUN_CWD):!contains(TESTRUN_CWD, ^\\./?): \
|
!isEmpty(TESTRUN_CWD):!contains(TESTRUN_CWD, ^\\./?): \
|
||||||
check.commands = cd $$shell_path($$TESTRUN_CWD) && $$check.commands
|
$${type}.commands = cd $$shell_path($$TESTRUN_CWD) && $$eval($${type}.commands)
|
||||||
|
|
||||||
# If the test is marked as insignificant, discard the exit code
|
# If the test is marked as insignificant, discard the exit code
|
||||||
insignificant_test:check.commands = -$${check.commands}
|
insignificant_test: $${type}.commands = -$$eval($${type}.commands)
|
||||||
|
|
||||||
QMAKE_EXTRA_TARGETS *= check
|
QMAKE_EXTRA_TARGETS *= $${type}
|
||||||
|
|
||||||
isEmpty(BUILDS)|build_pass {
|
isEmpty(BUILDS)|build_pass {
|
||||||
check.depends = first
|
$${type}.depends = first
|
||||||
} else {
|
} else {
|
||||||
# For exclusive builds, only run the test once.
|
# For exclusive builds, only run the test once.
|
||||||
check.CONFIG = recursive
|
$${type}.CONFIG = recursive
|
||||||
check.target = check_all
|
$${type}.target = $${type}_all
|
||||||
check.recurse_target = check
|
$${type}.recurse_target = $${type}
|
||||||
check.commands =
|
$${type}.commands =
|
||||||
|
|
||||||
check_first.depends = $$eval($$first(BUILDS).target)-check
|
$${type}_first.depends = $$eval($$first(BUILDS).target)-$${type}
|
||||||
check_first.target = check
|
$${type}_first.target = $${type}
|
||||||
QMAKE_EXTRA_TARGETS += check_first
|
QMAKE_EXTRA_TARGETS += $${type}_first
|
||||||
}
|
}
|
||||||
|
|
||||||
!no_testcase_installs:!contains(INSTALLS, target) {
|
!no_testcase_installs:!contains(INSTALLS, target) {
|
||||||
|
@ -7,3 +7,13 @@
|
|||||||
check.depends = first # `make check' implies build
|
check.depends = first # `make check' implies build
|
||||||
QMAKE_EXTRA_TARGETS += check
|
QMAKE_EXTRA_TARGETS += check
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# ... and the same for benchmarks, too.
|
||||||
|
!contains(QMAKE_EXTRA_TARGETS, benchmark) {
|
||||||
|
contains(TEMPLATE, subdirs): \
|
||||||
|
prepareRecursiveTarget(benchmark)
|
||||||
|
else: \
|
||||||
|
benchmark.depends = first # `make benchmark' implies build
|
||||||
|
QMAKE_EXTRA_TARGETS += benchmark
|
||||||
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user