TST_TSTranslation refactoring. An error shouldn't stop test anymore.
--HG-- branch : develop
This commit is contained in:
parent
0cdd058eb4
commit
ec800565d7
|
@ -33,6 +33,8 @@
|
||||||
#include <QDomDocument>
|
#include <QDomDocument>
|
||||||
#include <QtTest>
|
#include <QtTest>
|
||||||
|
|
||||||
|
Q_DECLARE_METATYPE(QDomElement) // Need for testing
|
||||||
|
|
||||||
const QString TST_TSTranslation::TagName = QStringLiteral("name");
|
const QString TST_TSTranslation::TagName = QStringLiteral("name");
|
||||||
const QString TST_TSTranslation::TagMessage = QStringLiteral("message");
|
const QString TST_TSTranslation::TagMessage = QStringLiteral("message");
|
||||||
const QString TST_TSTranslation::TagSource = QStringLiteral("source");
|
const QString TST_TSTranslation::TagSource = QStringLiteral("source");
|
||||||
|
@ -44,20 +46,24 @@ const QString TST_TSTranslation::AttrValUnfinished = QStringLiteral("unfinished"
|
||||||
const QString TST_TSTranslation::AttrValObsolete = QStringLiteral("obsolete");
|
const QString TST_TSTranslation::AttrValObsolete = QStringLiteral("obsolete");
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
TST_TSTranslation::TST_TSTranslation(QObject *parent) :
|
TST_TSTranslation::TST_TSTranslation(QObject *parent)
|
||||||
QObject(parent),
|
: QObject(parent),
|
||||||
tsFile(),
|
tsFile(),
|
||||||
tsXML()
|
tsXML()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void TST_TSTranslation::CheckEnglishLocalization()
|
void TST_TSTranslation::CheckEnglishLocalization_data()
|
||||||
{
|
{
|
||||||
const QDomNodeList messages = LoadTSFile(QStringLiteral("valentina_en_US.ts"));
|
QTest::addColumn<QString>("source");
|
||||||
|
QTest::addColumn<QString>("translation");
|
||||||
|
|
||||||
|
const QString fileName = QStringLiteral("valentina_en_US.ts");
|
||||||
|
const QDomNodeList messages = LoadTSFile(fileName);
|
||||||
if (messages.isEmpty())
|
if (messages.isEmpty())
|
||||||
{
|
{
|
||||||
QSKIP("Can't begin test.");
|
QFAIL("Can't begin test.");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (qint32 i = 0, num = messages.size(); i < num; ++i)
|
for (qint32 i = 0, num = messages.size(); i < num; ++i)
|
||||||
|
@ -86,7 +92,9 @@ void TST_TSTranslation::CheckEnglishLocalization()
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
QCOMPARE(source, translation);
|
const QString message = QString("File '%1'. Check modification source message '%2'.").arg(fileName)
|
||||||
|
.arg(source);
|
||||||
|
QTest::newRow(qUtf8Printable(message)) << source << translation;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -97,12 +105,25 @@ void TST_TSTranslation::CheckEnglishLocalization()
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void TST_TSTranslation::CheckEmptyToolButton()
|
void TST_TSTranslation::CheckEnglishLocalization()
|
||||||
{
|
{
|
||||||
const QDomNodeList messages = LoadTSFile(QStringLiteral("valentina.ts"));
|
QFETCH(QString, source);
|
||||||
|
QFETCH(QString, translation);
|
||||||
|
|
||||||
|
QCOMPARE(source, translation);
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
void TST_TSTranslation::CheckEmptyToolButton_data()
|
||||||
|
{
|
||||||
|
QTest::addColumn<QString>("source");
|
||||||
|
QTest::addColumn<QDomElement>("message");
|
||||||
|
|
||||||
|
const QString fileName = QStringLiteral("valentina.ts");
|
||||||
|
const QDomNodeList messages = LoadTSFile(fileName);
|
||||||
if (messages.isEmpty())
|
if (messages.isEmpty())
|
||||||
{
|
{
|
||||||
QSKIP("Can't begin test.");
|
QFAIL("Can't begin test.");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (qint32 i = 0, num = messages.size(); i < num; ++i)
|
for (qint32 i = 0, num = messages.size(); i < num; ++i)
|
||||||
|
@ -116,28 +137,9 @@ void TST_TSTranslation::CheckEmptyToolButton()
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (source == QLatin1String("..."))
|
const QString tag = QString("File '%1'. Check modification source message '%2'.").arg(fileName)
|
||||||
{
|
.arg(source);
|
||||||
const QDomElement translationTag = message.firstChildElement(TagTranslation);
|
QTest::newRow(qUtf8Printable(tag)) << source << message;
|
||||||
if (translationTag.hasAttribute(AttrType))
|
|
||||||
{
|
|
||||||
const QString attrVal = translationTag.attribute(AttrType);
|
|
||||||
if (attrVal == AttrValVanished || attrVal == AttrValObsolete)
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const QDomNode context = message.parentNode();
|
|
||||||
if (context.isNull())
|
|
||||||
{
|
|
||||||
QFAIL("Can't get context.");
|
|
||||||
}
|
|
||||||
|
|
||||||
const QString contextName = context.firstChildElement(TagName).text();
|
|
||||||
const QString error = QString("Found '...' in context '%1'").arg(contextName);
|
|
||||||
QFAIL(qUtf8Printable(error));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -147,6 +149,36 @@ void TST_TSTranslation::CheckEmptyToolButton()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
void TST_TSTranslation::CheckEmptyToolButton()
|
||||||
|
{
|
||||||
|
QFETCH(QString, source);
|
||||||
|
QFETCH(QDomElement, message);
|
||||||
|
|
||||||
|
if (source == QLatin1String("..."))
|
||||||
|
{
|
||||||
|
const QDomElement translationTag = message.firstChildElement(TagTranslation);
|
||||||
|
if (translationTag.hasAttribute(AttrType))
|
||||||
|
{
|
||||||
|
const QString attrVal = translationTag.attribute(AttrType);
|
||||||
|
if (attrVal == AttrValVanished || attrVal == AttrValObsolete)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const QDomNode context = message.parentNode();
|
||||||
|
if (context.isNull())
|
||||||
|
{
|
||||||
|
QFAIL("Can't get context.");
|
||||||
|
}
|
||||||
|
|
||||||
|
const QString contextName = context.firstChildElement(TagName).text();
|
||||||
|
const QString error = QString("Found '...' in context '%1'").arg(contextName);
|
||||||
|
QFAIL(qUtf8Printable(error));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void TST_TSTranslation::CheckPlaceMarkerExist_data()
|
void TST_TSTranslation::CheckPlaceMarkerExist_data()
|
||||||
{
|
{
|
||||||
|
@ -158,99 +190,102 @@ void TST_TSTranslation::CheckPlaceMarkerExist_data()
|
||||||
QVERIFY2(locales.size() == fileNames.size()-1, "Unexpected count of files.");
|
QVERIFY2(locales.size() == fileNames.size()-1, "Unexpected count of files.");
|
||||||
}
|
}
|
||||||
|
|
||||||
QTest::addColumn<QString>("filename");
|
QTest::addColumn<QString>("source");
|
||||||
|
QTest::addColumn<QString>("translation");
|
||||||
|
|
||||||
for(int i = 0; i < locales.size(); ++i)
|
for(int j = 0; j < locales.size(); ++j)
|
||||||
{
|
{
|
||||||
const QString filename = QString("valentina_%1.ts").arg(locales.at(i));
|
const QString filename = QString("valentina_%1.ts").arg(locales.at(j));
|
||||||
const QString tag = QString("Check localization strings valentina_%1.ts").arg(locales.at(i));
|
|
||||||
QTest::newRow(qUtf8Printable(tag)) << filename;
|
const QDomNodeList messages = LoadTSFile(filename);
|
||||||
|
if (messages.isEmpty())
|
||||||
|
{
|
||||||
|
QFAIL("Can't begin test.");
|
||||||
|
}
|
||||||
|
|
||||||
|
for (qint32 i = 0, num = messages.size(); i < num; ++i)
|
||||||
|
{
|
||||||
|
const QDomElement message = messages.at(i).toElement();
|
||||||
|
if (message.isNull() == false)
|
||||||
|
{
|
||||||
|
const QString source = message.firstChildElement(TagSource).text();
|
||||||
|
if (source.isEmpty())
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
const QDomElement translationTag = message.firstChildElement(TagTranslation);
|
||||||
|
if (translationTag.hasAttribute(AttrType))
|
||||||
|
{
|
||||||
|
const QString attrVal = translationTag.attribute(AttrType);
|
||||||
|
if (attrVal == AttrValVanished || attrVal == AttrValUnfinished || attrVal == AttrValObsolete)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const QString translation = translationTag.text();
|
||||||
|
if (translation.isEmpty())
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
const QString message = QString("File '%1'. Check place holder source message '%2'").arg(filename)
|
||||||
|
.arg(source);
|
||||||
|
QTest::newRow(qUtf8Printable(message)) << source << translation;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const QString message = QString("File '%2'. Message %1 is null.").arg(i).arg(filename);
|
||||||
|
QFAIL(qUtf8Printable(message));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void TST_TSTranslation::CheckPlaceMarkerExist()
|
void TST_TSTranslation::CheckPlaceMarkerExist()
|
||||||
{
|
{
|
||||||
QFETCH(QString, filename);
|
QFETCH(QString, source);
|
||||||
|
QFETCH(QString, translation);
|
||||||
|
|
||||||
const QDomNodeList messages = LoadTSFile(filename);
|
int sourceMarkCount = 0;
|
||||||
if (messages.isEmpty())
|
int translationMarkCount = 0;
|
||||||
{
|
|
||||||
QSKIP("Can't begin test.");
|
|
||||||
}
|
|
||||||
|
|
||||||
for (qint32 i = 0, num = messages.size(); i < num; ++i)
|
for (int i = 1; i <= 99; ++i)
|
||||||
{
|
{
|
||||||
const QDomElement message = messages.at(i).toElement();
|
const QString marker = QLatin1String("%") + QString().setNum(i);
|
||||||
if (message.isNull() == false)
|
const bool sourceMark = source.indexOf(marker) != -1;
|
||||||
|
if (sourceMark)
|
||||||
{
|
{
|
||||||
const QString source = message.firstChildElement(TagSource).text();
|
++sourceMarkCount;
|
||||||
if (source.isEmpty())
|
if (sourceMarkCount != i)
|
||||||
{
|
{
|
||||||
continue;
|
const QString message = QString("In source string '%1' was missed place marker ")
|
||||||
|
.arg(source) + QLatin1String("'%") + QString().setNum(sourceMarkCount) +
|
||||||
|
QLatin1String("'.");
|
||||||
|
QFAIL(qUtf8Printable(message));
|
||||||
}
|
}
|
||||||
|
|
||||||
const QDomElement translationTag = message.firstChildElement(TagTranslation);
|
|
||||||
if (translationTag.hasAttribute(AttrType))
|
|
||||||
{
|
|
||||||
const QString attrVal = translationTag.attribute(AttrType);
|
|
||||||
if (attrVal == AttrValVanished || attrVal == AttrValUnfinished || attrVal == AttrValObsolete)
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
const QString translation = translationTag.text();
|
|
||||||
if (translation.isEmpty())
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
int sourceMarkCount = 0;
|
|
||||||
int translationMarkCount = 0;
|
|
||||||
|
|
||||||
for (int i = 1; i <= 99; ++i)
|
|
||||||
{
|
|
||||||
const QString marker = QLatin1String("%") + QString().setNum(i);
|
|
||||||
const bool sourceMark = source.indexOf(marker) != -1;
|
|
||||||
if (sourceMark)
|
|
||||||
{
|
|
||||||
++sourceMarkCount;
|
|
||||||
if (sourceMarkCount != i)
|
|
||||||
{
|
|
||||||
const QString message = QString("In source string '%1' was missed place marker ")
|
|
||||||
.arg(source) + QLatin1String("'%") + QString().setNum(sourceMarkCount) +
|
|
||||||
QLatin1String("'.");
|
|
||||||
QFAIL(qUtf8Printable(message));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const bool translationMark = translation.indexOf(marker) != -1;
|
|
||||||
if (translationMark)
|
|
||||||
{
|
|
||||||
++translationMarkCount;
|
|
||||||
if (translationMarkCount != i)
|
|
||||||
{
|
|
||||||
const QString message = QString("In translation string '%1' was missed place marker ")
|
|
||||||
.arg(translation) + QLatin1String("'%") + QString().setNum(translationMarkCount) +
|
|
||||||
QLatin1String("'.");
|
|
||||||
QFAIL(qUtf8Printable(message));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sourceMark != translationMark)
|
|
||||||
{
|
|
||||||
const QString message =
|
|
||||||
QString("Compare to source string in the translation string '%1' was missed place marker ")
|
|
||||||
.arg(translation) + QLatin1String("'%") + QString().setNum(sourceMarkCount) +
|
|
||||||
QLatin1String("'.");
|
|
||||||
QFAIL(qUtf8Printable(message));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
|
||||||
|
const bool translationMark = translation.indexOf(marker) != -1;
|
||||||
|
if (translationMark)
|
||||||
{
|
{
|
||||||
const QString message = QString("Message %1 is null.").arg(i);
|
++translationMarkCount;
|
||||||
|
if (translationMarkCount != i)
|
||||||
|
{
|
||||||
|
const QString message = QString("In translation string '%1' was missed place marker ")
|
||||||
|
.arg(translation) + QLatin1String("'%") + QString().setNum(translationMarkCount) +
|
||||||
|
QLatin1String("'.");
|
||||||
|
QFAIL(qUtf8Printable(message));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sourceMark != translationMark)
|
||||||
|
{
|
||||||
|
const QString message =
|
||||||
|
QString("Compare to source string in the translation string '%1' was missed place marker ")
|
||||||
|
.arg(translation) + QLatin1String("'%") + QString().setNum(sourceMarkCount) +
|
||||||
|
QLatin1String("'.");
|
||||||
QFAIL(qUtf8Printable(message));
|
QFAIL(qUtf8Printable(message));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -282,8 +317,8 @@ QDomNodeList TST_TSTranslation::LoadTSFile(const QString &filename)
|
||||||
tsXML = QSharedPointer<QDomDocument>(new QDomDocument());
|
tsXML = QSharedPointer<QDomDocument>(new QDomDocument());
|
||||||
if (tsXML->setContent(tsFile.data(), &errorMsg, &errorLine, &errorColumn) == false)
|
if (tsXML->setContent(tsFile.data(), &errorMsg, &errorLine, &errorColumn) == false)
|
||||||
{
|
{
|
||||||
const QString message = QString("Parsing error file valentina_en_US.ts in line %1 column %2.")
|
const QString message = QString("Parsing error file %1 in line %2 column %3.")
|
||||||
.arg(errorLine).arg(errorColumn);
|
.arg(filename).arg(errorLine).arg(errorColumn);
|
||||||
QWARN(qUtf8Printable(message));
|
QWARN(qUtf8Printable(message));
|
||||||
return QDomNodeList();
|
return QDomNodeList();
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,7 +41,9 @@ public:
|
||||||
explicit TST_TSTranslation(QObject *parent = nullptr);
|
explicit TST_TSTranslation(QObject *parent = nullptr);
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
|
void CheckEnglishLocalization_data();
|
||||||
void CheckEnglishLocalization();
|
void CheckEnglishLocalization();
|
||||||
|
void CheckEmptyToolButton_data();
|
||||||
void CheckEmptyToolButton();
|
void CheckEmptyToolButton();
|
||||||
void CheckPlaceMarkerExist_data();
|
void CheckPlaceMarkerExist_data();
|
||||||
void CheckPlaceMarkerExist();
|
void CheckPlaceMarkerExist();
|
||||||
|
|
Loading…
Reference in New Issue
Block a user