summaryrefslogtreecommitdiffstats
path: root/tests/auto/corelib/kernel/qtranslator
diff options
context:
space:
mode:
Diffstat (limited to 'tests/auto/corelib/kernel/qtranslator')
-rw-r--r--tests/auto/corelib/kernel/qtranslator/CMakeLists.txt17
-rw-r--r--tests/auto/corelib/kernel/qtranslator/tst_qtranslator.cpp85
2 files changed, 40 insertions, 62 deletions
diff --git a/tests/auto/corelib/kernel/qtranslator/CMakeLists.txt b/tests/auto/corelib/kernel/qtranslator/CMakeLists.txt
index e3e69537bf..92b6edb17c 100644
--- a/tests/auto/corelib/kernel/qtranslator/CMakeLists.txt
+++ b/tests/auto/corelib/kernel/qtranslator/CMakeLists.txt
@@ -1,9 +1,20 @@
-# Generated from qtranslator.pro.
+# Copyright (C) 2022 The Qt Company Ltd.
+# SPDX-License-Identifier: BSD-3-Clause
#####################################################################
## tst_qtranslator Test:
#####################################################################
+if(NOT QT_BUILD_STANDALONE_TESTS AND NOT QT_BUILDING_QT)
+ cmake_minimum_required(VERSION 3.16)
+ project(tst_qtranslator LANGUAGES CXX)
+ find_package(Qt6BuildInternals REQUIRED COMPONENTS STANDALONE_TEST)
+endif()
+
+if (NOT QT_FEATURE_thread)
+ return()
+endif()
+
qt_internal_add_test(tst_qtranslator
SOURCES
tst_qtranslator.cpp
@@ -24,7 +35,6 @@ qt_internal_add_resource(tst_qtranslator "qtranslator"
${qtranslator_resource_files}
)
-
## Scopes:
#####################################################################
@@ -44,6 +54,3 @@ if(ANDROID)
${android_testdata_resource_files}
)
endif()
-
-#### Keys ignored in scope 3:.:.:qtranslator.pro:else:
-# TESTDATA = "dependencies_la.qm" "hellotr_empty.qm" "hellotr_la.qm" "msgfmt_from_po.qm"
diff --git a/tests/auto/corelib/kernel/qtranslator/tst_qtranslator.cpp b/tests/auto/corelib/kernel/qtranslator/tst_qtranslator.cpp
index 2486eeda5c..f214572cfa 100644
--- a/tests/auto/corelib/kernel/qtranslator/tst_qtranslator.cpp
+++ b/tests/auto/corelib/kernel/qtranslator/tst_qtranslator.cpp
@@ -1,30 +1,5 @@
-/****************************************************************************
-**
-** Copyright (C) 2021 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the test suite of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:GPL-EXCEPT$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
+// Copyright (C) 2021 The Qt Company Ltd.
+// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
#include <QTest>
#include <QWaitCondition>
@@ -52,6 +27,7 @@ private slots:
void load_data();
void load();
+ void loadLocale_data();
void loadLocale();
void threadLoad();
void testLanguageChange();
@@ -120,7 +96,7 @@ void tst_QTranslator::load()
{
QFile file(filepath);
- file.open(QFile::ReadOnly);
+ QVERIFY(file.open(QFile::ReadOnly));
QByteArray data = file.readAll();
QTranslator tor;
QVERIFY(tor.load((const uchar *)data.constData(), data.length()));
@@ -141,12 +117,23 @@ void tst_QTranslator::load()
}
}
+void tst_QTranslator::loadLocale_data()
+{
+ QTest::addColumn<QString>("localeName");
+ QTest::addColumn<QStringList>("fileNames");
+
+ QTest::addRow("US English")
+ << "en_US"
+ << QStringList{"en_US.qm", "en_US", "en.qm", "en"};
+ QTest::addRow("Australia")
+ << "en_AU"
+ << QStringList{"en_Latn_AU.qm", "en_AU.qm", "en.qm"};
+}
+
void tst_QTranslator::loadLocale()
{
- QLocale locale;
- auto localeName = locale.uiLanguages().value(0).replace('-', '_');
- if (localeName.isEmpty())
- QSKIP("This test requires at least one available UI language.");
+ QFETCH(const QString, localeName);
+ QFETCH(const QStringList, fileNames);
QByteArray ba;
{
@@ -159,36 +146,16 @@ void tst_QTranslator::loadLocale()
QTemporaryDir dir;
QVERIFY(dir.isValid());
- auto path = dir.path();
+ const auto path = dir.path();
QFile file(path + "/dummy");
QVERIFY2(file.open(QFile::WriteOnly), qPrintable(file.errorString()));
QCOMPARE(file.write(ba), ba.size());
file.close();
- /*
- Test the following order:
-
- /tmp/tmpDir/foo-en_US.qm
- /tmp/tmpDir/foo-en_US
- /tmp/tmpDir/foo-en.qm
- /tmp/tmpDir/foo-en
- /tmp/tmpDir/foo.qm
- /tmp/tmpDir/foo-
- /tmp/tmpDir/foo
- */
-
QStringList files;
- while (true) {
- files.append(path + "/foo-" + localeName + ".qm");
- QVERIFY2(file.copy(files.last()), qPrintable(file.errorString()));
-
- files.append(path + "/foo-" + localeName);
+ for (const auto &fileName : fileNames) {
+ files.append(path + "/foo-" + fileName);
QVERIFY2(file.copy(files.last()), qPrintable(file.errorString()));
-
- int rightmost = localeName.lastIndexOf(QLatin1Char('_'));
- if (rightmost <= 0)
- break;
- localeName.truncate(rightmost);
}
files.append(path + "/foo.qm");
@@ -200,10 +167,14 @@ void tst_QTranslator::loadLocale()
files.append(path + "/foo");
QVERIFY2(file.rename(files.last()), qPrintable(file.errorString()));
+ QLocale locale(localeName);
QTranslator tor;
for (const auto &filePath : files) {
QVERIFY(tor.load(locale, "foo", "-", path, ".qm"));
- QCOMPARE(tor.filePath(), filePath);
+ // As the file system might be case insensitive, we can't guarantee that
+ // the casing of the file name is preserved. The order of loading
+ // en_AU vs en_au if both exist is undefined anyway.
+ QCOMPARE(tor.filePath().toLower(), filePath.toLower());
QVERIFY2(file.remove(filePath), qPrintable(file.errorString()));
}
}
@@ -354,7 +325,7 @@ void tst_QTranslator::dependencies()
{
QTranslator tor( 0 );
QFile file("dependencies_la.qm");
- file.open(QFile::ReadOnly);
+ QVERIFY(file.open(QFile::ReadOnly));
QByteArray data = file.readAll();
QVERIFY(tor.load((const uchar *)data.constData(), data.length()));
QVERIFY(!tor.isEmpty());