testlib: Run test result expectation tests with stdout as output

For historical reasons a few of the subtests are skipped when
running with anything but the plain text logger to stdout.

To ensure we have as broad test coverage as possible for the
expected output of the various loggers we run these tests in
stdout-mode.

Pick-to: 6.2
Change-Id: I856905d1543afe89710533657a55bd599c0305fd
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
This commit is contained in:
Tor Arne Vestbø 2021-07-28 13:49:12 +02:00
parent 3c23317552
commit cba2adb195

View File

@ -602,10 +602,9 @@ struct TestLogger
QString outputFileName(const QString &test) const QString outputFileName(const QString &test) const
{ {
if (outputMode == StdoutOutput) return testOutputDir.filePath("output_" + test +
return QString(); (outputMode == StdoutOutput ? ".stdout" : "") +
"." + shortName());
return testOutputDir.filePath("output_" + test + "." + shortName());
} }
QString expectationFileName(const QString &test, int version = 0) const QString expectationFileName(const QString &test, int version = 0) const
@ -619,16 +618,15 @@ struct TestLogger
QStringList arguments(const QString &test) const QStringList arguments(const QString &test) const
{ {
auto fileName = outputFileName(test);
QStringList arguments; QStringList arguments;
if (argumentStyle == NewStyleArgument) { if (argumentStyle == NewStyleArgument) {
arguments << "-o" << (!fileName.isEmpty() ? fileName : QStringLiteral("-")) arguments << "-o" << (outputMode == FileOutput
+ "," + shortName(); ? outputFileName(test) : QStringLiteral("-")) +
"," + shortName();
} else { } else {
arguments << "-" + shortName(); arguments << "-" + shortName();
if (!fileName.isEmpty()) if (outputMode == FileOutput)
arguments << "-o" << fileName; arguments << "-o" << outputFileName(test);
} }
return arguments; return arguments;
@ -636,9 +634,6 @@ struct TestLogger
QByteArray testOutput(const QString &test) const QByteArray testOutput(const QString &test) const
{ {
if (outputMode == StdoutOutput)
return QByteArray();
QFile outputFile(outputFileName(test)); QFile outputFile(outputFileName(test));
REQUIRE(outputFile.exists()); REQUIRE(outputFile.exists());
REQUIRE(outputFile.open(QIODevice::ReadOnly)); REQUIRE(outputFile.open(QIODevice::ReadOnly));
@ -788,6 +783,11 @@ void checkErrorOutput(const QString &test, const QByteArray &errorOutput)
#endif #endif
return; return;
#ifdef Q_OS_WIN
if (test == "crashes")
return; // Complains about uncaught exception
#endif
#ifdef Q_OS_LINUX #ifdef Q_OS_LINUX
// QEMU outputs to stderr about uncaught signals // QEMU outputs to stderr about uncaught signals
if (QTestPrivate::isRunningArmOnX86() && if (QTestPrivate::isRunningArmOnX86() &&
@ -1050,10 +1050,14 @@ void runTest(const QString &test, const TestLoggers &requestedLoggers)
for (auto logger : loggers) { for (auto logger : loggers) {
QByteArray testOutput; QByteArray testOutput;
if (logger.outputMode == StdoutOutput) if (logger.outputMode == StdoutOutput) {
testOutput = testProcess.standardOutput; testOutput = testProcess.standardOutput;
else QFile file(logger.outputFileName(test));
REQUIRE(file.open(QIODevice::WriteOnly));
file.write(testOutput);
} else {
testOutput = logger.testOutput(test); testOutput = logger.testOutput(test);
}
checkTestOutput(test, logger, testOutput); checkTestOutput(test, logger, testOutput);
} }
@ -1205,7 +1209,7 @@ SCENARIO("Test output of the loggers is as expected")
GIVEN("The " << logger << " logger") { GIVEN("The " << logger << " logger") {
for (QString test : tests) { for (QString test : tests) {
AND_GIVEN("The " << test << " subtest") { AND_GIVEN("The " << test << " subtest") {
runTest(test, TestLogger(logger)); runTest(test, TestLogger(logger, StdoutOutput));
} }
} }
} }