1
0
Fork 0
mirror of https://git.jami.net/savoirfairelinux/jami-client-qt.git synced 2025-04-22 06:02:03 +02:00
jami-client-qt/tests/unittests/previewengine_unittest.cpp
Andreas Traczyk 3ad0b92dcd link-preview: use non-ASCII UTF-8 characters in a UTF-8 test
Non-ASCII characters in UTF-8 are encoded with multiple bytes. Testing with these characters ensures that the decoder correctly interprets multi-byte sequences.

Gitlab: #1536
Change-Id: I0a92ee91b6cd26d70daab1f9baef3a9577aee02e
2024-07-04 13:01:02 -04:00

94 lines
3.4 KiB
C++

/*
* Copyright (C) 2024 Savoir-faire Linux Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
#include "globaltestenvironment.h"
#include <QtHttpServer/QHttpServer>
class PreviewEngineFixture : public ::testing::Test
{
public:
// Prepare unit test context. Called at
// prior each unit test execution
void SetUp() override
{
server = new QHttpServer();
// Setup a server that can return an HTML body.
server->listen(QHostAddress::LocalHost, 8000);
}
// Close unit test context. Called
// after each unit test ending
void TearDown() override
{
delete server;
}
// An instance of QHttpServer used to create a server.
QHttpServer* server;
};
/*!
* WHEN We parse a link
* THEN The infoReady signal should be emitted once with the correct info
*/
TEST_F(PreviewEngineFixture, ParsingALinkEmitsInfoReadySignal)
{
auto link = QString("http://localhost:8000/test");
server->route("/test",
[]() { return QString("<meta property=\"og:title\" content=\"Test title\">"); });
QSignalSpy infoReadySpy(globalEnv.previewEngine.data(), &PreviewEngine::infoReady);
Q_EMIT globalEnv.previewEngine->parseLink("msgId_01", link);
// Wait for the infoReady signal which should be emitted once with the correct ID.
infoReadySpy.wait();
EXPECT_EQ(infoReadySpy.count(), 1) << "infoReady signal should be emitted once";
QList<QVariant> infoReadyArguments = infoReadySpy.takeFirst();
EXPECT_TRUE(infoReadyArguments.at(0).typeId() == qMetaTypeId<QString>());
EXPECT_EQ(infoReadyArguments.at(0).toString(), "msgId_01");
}
/*!
* WHEN We parse a link that has a description containing characters encoded using UTF-8
* THEN The description should be parsed and match the original string
*/
TEST_F(PreviewEngineFixture, UTF8CharactersAreParsedCorrectly)
{
const auto testString = QString("liberté 自由 自由 свобода Szabadság ŐőŰű 자유 😊 € è ñ");
server->route("/test", [&]() {
return QString("<meta property=\"og:description\" content=\"%1\">").arg(testString);
});
QSignalSpy infoReadySpy(globalEnv.previewEngine.data(), &PreviewEngine::infoReady);
Q_EMIT globalEnv.previewEngine->parseLink("msgId_01", "http://localhost:8000/test");
// Wait for the infoReady signal which should be emitted once.
infoReadySpy.wait();
EXPECT_EQ(infoReadySpy.count(), 1) << "infoReady signal should be emitted once";
QList<QVariant> infoReadyArguments = infoReadySpy.takeFirst();
EXPECT_TRUE(infoReadyArguments.at(1).typeId() == qMetaTypeId<QVariantMap>());
// Check that the description is parsed correctly.
QVariantMap info = infoReadyArguments.at(1).toMap();
EXPECT_TRUE(info.contains("description"));
EXPECT_EQ(info["description"].toString(), testString);
}