Files
pilotclient/tests/blackmisc/teststatusmessage/teststatusmessage.cpp
Mat Sutcliffe cba820cbce Ref T485 Update for efficient QString usage in CLogMessage:
- `debug()`, `warning()`, `error()` etc. overloaded on `const char16_t[]` to accept UTF-16 string literals.
- Overloads on `const char *` are deleted to avoid accidents.
- Message is stored as QString and/or QStringView depending which overload is used.
- The multiplexing between QString and QStringView is handled by a special value class, to keep the metaclass simple.
- QStringView does not have `arg()` method, so had to implement our own.
2019-02-22 20:34:54 +00:00

82 lines
2.8 KiB
C++

/* Copyright (C) 2018
* swift Project Community / Contributors
*
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
* including this file, may be copied, modified, propagated, or distributed except according to the terms
* contained in the LICENSE file.
*/
//! \cond PRIVATE_TESTS
//! \file
//! \ingroup testblackmisc
#include "blackmisc/statusmessage.h"
#include "test.h"
#include <QObject>
#include <QTest>
using namespace BlackMisc;
namespace BlackMiscTest
{
//! Testing property index access
class CTestStatusMessage : public QObject
{
Q_OBJECT
private slots:
//! Status message
void statusMessage();
//! Message with arguments
void statusArgs();
};
void CTestStatusMessage::statusMessage()
{
CStatusMessage s1(CStatusMessage::SeverityDebug, "debug msg.");
s1.setMSecsSinceEpoch(4000);
CStatusMessage s2(CStatusMessage::SeverityInfo, "info msg.");
s2.setMSecsSinceEpoch(3000);
// CStatusMessage s3(CStatusMessage::SeverityWarning, "warning msg.");
// s3.setMSecsSinceEpoch(2000);
// CStatusMessage s4(CStatusMessage::SeverityError, "error msg.");
// s4.setMSecsSinceEpoch(1000);
CStatusMessage cCopy(s1);
QVERIFY(cCopy.getMSecsSinceEpoch() == s1.getMSecsSinceEpoch());
CStatusMessage cAssign;
cAssign = s2;
QVERIFY(cAssign.getMSecsSinceEpoch() == s2.getMSecsSinceEpoch());
}
void CTestStatusMessage::statusArgs()
{
auto s1 = CStatusMessage().info(u"literal percent: %1");
auto s2 = CStatusMessage().info(u"literal percent: %a");
auto s3 = CStatusMessage().info(u"literal percent: %");
auto s4 = CStatusMessage().info(u"literal percent: %%");
auto s5 = CStatusMessage().info(u"literal percents: %%%");
auto s6 = CStatusMessage().info(u"will be expanded: %1%2") << "foo" << "bar";
auto s7 = CStatusMessage().info(u"will be expanded: %1+%2") << "foo" << "bar";
auto s8 = CStatusMessage().info(u"will be expanded: %012") << "foo";
QVERIFY(s1.getMessage() == "literal percent: %1");
QVERIFY(s2.getMessage() == "literal percent: %a");
QVERIFY(s3.getMessage() == "literal percent: %");
QVERIFY(s4.getMessage() == "literal percent: %");
QVERIFY(s5.getMessage() == "literal percents: %%");
QVERIFY(s6.getMessage() == "will be expanded: foobar");
QVERIFY(s7.getMessage() == "will be expanded: foo+bar");
QVERIFY(s8.getMessage() == "will be expanded: foo2");
}
} // namespace
//! main
BLACKTEST_APPLESS_MAIN(BlackMiscTest::CTestStatusMessage);
#include "teststatusmessage.moc"
//! \endcond