2016-09-29 13:04:05 -05:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
|
|
|
|
/*
|
|
|
|
* This file is part of the LibreOffice project.
|
|
|
|
*
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include <cppunit/extensions/HelperMacros.h>
|
|
|
|
|
|
|
|
#include "Common.hpp"
|
2016-11-24 08:56:06 -06:00
|
|
|
#include "Protocol.hpp"
|
2017-01-21 18:47:49 -06:00
|
|
|
#include "Message.hpp"
|
2016-09-29 13:04:05 -05:00
|
|
|
#include "MessageQueue.hpp"
|
2016-12-18 11:04:18 -06:00
|
|
|
#include "SenderQueue.hpp"
|
2016-09-29 13:04:05 -05:00
|
|
|
#include "Util.hpp"
|
|
|
|
|
|
|
|
namespace CPPUNIT_NS
|
|
|
|
{
|
|
|
|
template<>
|
|
|
|
struct assertion_traits<std::vector<char>>
|
|
|
|
{
|
|
|
|
static bool equal(const std::vector<char>& x, const std::vector<char>& y)
|
|
|
|
{
|
|
|
|
return x == y;
|
|
|
|
}
|
|
|
|
|
|
|
|
static std::string toString(const std::vector<char>& x)
|
|
|
|
{
|
|
|
|
const std::string text = '"' + (!x.empty() ? std::string(x.data(), x.size()) : "<empty>") + '"';
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/// TileQueue unit-tests.
|
|
|
|
class TileQueueTests : public CPPUNIT_NS::TestFixture
|
|
|
|
{
|
|
|
|
CPPUNIT_TEST_SUITE(TileQueueTests);
|
|
|
|
|
|
|
|
CPPUNIT_TEST(testTileQueuePriority);
|
|
|
|
CPPUNIT_TEST(testTileCombinedRendering);
|
2016-09-29 13:32:25 -05:00
|
|
|
CPPUNIT_TEST(testTileRecombining);
|
2016-09-30 15:02:22 -05:00
|
|
|
CPPUNIT_TEST(testViewOrder);
|
2016-10-04 07:23:42 -05:00
|
|
|
CPPUNIT_TEST(testPreviewsDeprioritization);
|
2016-12-18 11:04:18 -06:00
|
|
|
CPPUNIT_TEST(testSenderQueue);
|
|
|
|
CPPUNIT_TEST(testSenderQueueTileDeduplication);
|
2016-12-18 16:28:35 -06:00
|
|
|
CPPUNIT_TEST(testInvalidateViewCursorDeduplication);
|
2017-01-25 11:21:56 -06:00
|
|
|
CPPUNIT_TEST(testCallbackInvalidation);
|
2017-04-07 05:29:01 -05:00
|
|
|
CPPUNIT_TEST(testCallbackIndicatorValue);
|
|
|
|
CPPUNIT_TEST(testCallbackPageSize);
|
2016-09-29 13:04:05 -05:00
|
|
|
|
|
|
|
CPPUNIT_TEST_SUITE_END();
|
|
|
|
|
|
|
|
void testTileQueuePriority();
|
|
|
|
void testTileCombinedRendering();
|
2016-09-29 13:32:25 -05:00
|
|
|
void testTileRecombining();
|
2016-09-30 15:02:22 -05:00
|
|
|
void testViewOrder();
|
2016-10-04 07:23:42 -05:00
|
|
|
void testPreviewsDeprioritization();
|
2016-12-18 11:04:18 -06:00
|
|
|
void testSenderQueue();
|
|
|
|
void testSenderQueueTileDeduplication();
|
2016-12-18 16:28:35 -06:00
|
|
|
void testInvalidateViewCursorDeduplication();
|
2017-01-25 11:21:56 -06:00
|
|
|
void testCallbackInvalidation();
|
2017-04-07 05:29:01 -05:00
|
|
|
void testCallbackIndicatorValue();
|
|
|
|
void testCallbackPageSize();
|
2016-09-29 13:04:05 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
void TileQueueTests::testTileQueuePriority()
|
|
|
|
{
|
2017-06-14 11:28:07 -05:00
|
|
|
const std::string reqHigh = "tile part=0 width=256 height=256 tileposx=0 tileposy=0 tilewidth=3840 tileheight=3840 oldwid=0 wid=0";
|
|
|
|
const std::string resHigh = "tile part=0 width=256 height=256 tileposx=0 tileposy=0 tilewidth=3840 tileheight=3840 oldwid=0 wid=0 ver=-1";
|
2016-09-29 13:04:05 -05:00
|
|
|
const TileQueue::Payload payloadHigh(resHigh.data(), resHigh.data() + resHigh.size());
|
2017-06-14 11:28:07 -05:00
|
|
|
const std::string reqLow = "tile part=0 width=256 height=256 tileposx=0 tileposy=253440 tilewidth=3840 tileheight=3840 oldwid=0 wid=0";
|
|
|
|
const std::string resLow = "tile part=0 width=256 height=256 tileposx=0 tileposy=253440 tilewidth=3840 tileheight=3840 oldwid=0 wid=0 ver=-1";
|
2016-09-29 13:04:05 -05:00
|
|
|
const TileQueue::Payload payloadLow(resLow.data(), resLow.data() + resLow.size());
|
|
|
|
|
|
|
|
TileQueue queue;
|
|
|
|
|
|
|
|
// Request the tiles.
|
|
|
|
queue.put(reqLow);
|
|
|
|
queue.put(reqHigh);
|
|
|
|
|
|
|
|
// Original order.
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadLow, queue.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadHigh, queue.get());
|
|
|
|
|
|
|
|
// Request the tiles.
|
|
|
|
queue.put(reqLow);
|
|
|
|
queue.put(reqHigh);
|
|
|
|
queue.put(reqHigh);
|
|
|
|
queue.put(reqLow);
|
|
|
|
|
|
|
|
// Set cursor above reqHigh.
|
|
|
|
queue.updateCursorPosition(0, 0, 0, 0, 10, 100);
|
|
|
|
|
|
|
|
// Prioritized order.
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadHigh, queue.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadLow, queue.get());
|
|
|
|
|
|
|
|
// Repeat with cursor position set.
|
|
|
|
queue.put(reqLow);
|
|
|
|
queue.put(reqHigh);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadHigh, queue.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadLow, queue.get());
|
|
|
|
|
|
|
|
// Repeat by changing cursor position.
|
|
|
|
queue.put(reqLow);
|
|
|
|
queue.put(reqHigh);
|
|
|
|
queue.updateCursorPosition(0, 0, 0, 253450, 10, 100);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadLow, queue.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadHigh, queue.get());
|
|
|
|
}
|
|
|
|
|
|
|
|
void TileQueueTests::testTileCombinedRendering()
|
|
|
|
{
|
|
|
|
const std::string req1 = "tile part=0 width=256 height=256 tileposx=0 tileposy=0 tilewidth=3840 tileheight=3840";
|
|
|
|
const std::string req2 = "tile part=0 width=256 height=256 tileposx=3840 tileposy=0 tilewidth=3840 tileheight=3840";
|
|
|
|
const std::string req3 = "tile part=0 width=256 height=256 tileposx=0 tileposy=3840 tilewidth=3840 tileheight=3840";
|
|
|
|
const std::string req4 = "tile part=0 width=256 height=256 tileposx=3840 tileposy=3840 tilewidth=3840 tileheight=3840";
|
|
|
|
|
2017-06-14 11:28:07 -05:00
|
|
|
const std::string resHor = "tilecombine part=0 width=256 height=256 tileposx=0,3840 tileposy=0,0 imgsize=0,0 tilewidth=3840 tileheight=3840 ver=-1,-1 oldwid=0,0 wid=0,0";
|
2016-09-29 13:04:05 -05:00
|
|
|
const TileQueue::Payload payloadHor(resHor.data(), resHor.data() + resHor.size());
|
2017-06-14 11:28:07 -05:00
|
|
|
const std::string resVer = "tilecombine part=0 width=256 height=256 tileposx=0,0 tileposy=0,3840 imgsize=0,0 tilewidth=3840 tileheight=3840 ver=-1,-1 oldwid=0,0 wid=0,0";
|
2016-11-28 20:44:09 -06:00
|
|
|
const TileQueue::Payload payloadVer(resVer.data(), resVer.data() + resVer.size());
|
2017-06-14 11:28:07 -05:00
|
|
|
const std::string resFull = "tilecombine part=0 width=256 height=256 tileposx=0,3840,0 tileposy=0,0,3840 imgsize=0,0,0 tilewidth=3840 tileheight=3840 ver=-1,-1,-1 oldwid=0,0,0 wid=0,0,0";
|
2016-09-29 13:04:05 -05:00
|
|
|
const TileQueue::Payload payloadFull(resFull.data(), resFull.data() + resFull.size());
|
|
|
|
|
|
|
|
TileQueue queue;
|
|
|
|
|
2016-11-28 20:44:09 -06:00
|
|
|
// Horizontal.
|
2016-09-29 13:04:05 -05:00
|
|
|
queue.put(req1);
|
|
|
|
queue.put(req2);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadHor, queue.get());
|
|
|
|
|
2016-11-28 20:44:09 -06:00
|
|
|
// Vertical.
|
2016-09-29 13:04:05 -05:00
|
|
|
queue.put(req1);
|
|
|
|
queue.put(req3);
|
2016-11-28 20:44:09 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadVer, queue.get());
|
2016-09-29 13:04:05 -05:00
|
|
|
|
2016-11-28 20:44:09 -06:00
|
|
|
// Vertical.
|
2016-09-29 13:04:05 -05:00
|
|
|
queue.put(req1);
|
|
|
|
queue.put(req2);
|
|
|
|
queue.put(req3);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(payloadFull, queue.get());
|
|
|
|
}
|
|
|
|
|
2016-10-04 07:23:42 -05:00
|
|
|
namespace {
|
|
|
|
|
|
|
|
std::string payloadAsString(const MessageQueue::Payload& payload)
|
|
|
|
{
|
|
|
|
return std::string(payload.data(), payload.size());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-09-29 13:32:25 -05:00
|
|
|
void TileQueueTests::testTileRecombining()
|
|
|
|
{
|
|
|
|
TileQueue queue;
|
|
|
|
|
|
|
|
queue.put("tilecombine part=0 width=256 height=256 tileposx=0,3840,7680 tileposy=0,0,0 tilewidth=3840 tileheight=3840");
|
|
|
|
queue.put("tilecombine part=0 width=256 height=256 tileposx=0,3840 tileposy=0,0 tilewidth=3840 tileheight=3840");
|
|
|
|
|
|
|
|
// the tilecombine's get merged, resulting in 3 "tile" messages
|
|
|
|
CPPUNIT_ASSERT_EQUAL(3, static_cast<int>(queue._queue.size()));
|
|
|
|
|
|
|
|
// but when we later extract that, it is just one "tilecombine" message
|
2016-10-04 07:23:42 -05:00
|
|
|
std::string message(payloadAsString(queue.get()));
|
2016-09-29 13:32:25 -05:00
|
|
|
|
2017-06-14 11:28:07 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("tilecombine part=0 width=256 height=256 tileposx=7680,0,3840 tileposy=0,0,0 imgsize=0,0,0 tilewidth=3840 tileheight=3840 ver=-1,-1,-1 oldwid=0,0,0 wid=0,0,0"), message);
|
2016-09-29 13:32:25 -05:00
|
|
|
|
|
|
|
// and nothing remains in the queue
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, static_cast<int>(queue._queue.size()));
|
|
|
|
}
|
|
|
|
|
2016-09-30 15:02:22 -05:00
|
|
|
void TileQueueTests::testViewOrder()
|
|
|
|
{
|
|
|
|
TileQueue queue;
|
|
|
|
|
|
|
|
// should result in the 3, 2, 1, 0 order of the views
|
|
|
|
queue.updateCursorPosition(0, 0, 0, 0, 10, 100);
|
|
|
|
queue.updateCursorPosition(2, 0, 0, 0, 10, 100);
|
|
|
|
queue.updateCursorPosition(1, 0, 0, 7680, 10, 100);
|
|
|
|
queue.updateCursorPosition(3, 0, 0, 0, 10, 100);
|
|
|
|
queue.updateCursorPosition(2, 0, 0, 15360, 10, 100);
|
|
|
|
queue.updateCursorPosition(3, 0, 0, 23040, 10, 100);
|
|
|
|
|
|
|
|
const std::vector<std::string> tiles =
|
|
|
|
{
|
2017-06-14 11:28:07 -05:00
|
|
|
"tile part=0 width=256 height=256 tileposx=0 tileposy=0 tilewidth=3840 tileheight=3840 oldwid=0 wid=0 ver=-1",
|
|
|
|
"tile part=0 width=256 height=256 tileposx=0 tileposy=7680 tilewidth=3840 tileheight=3840 oldwid=0 wid=0 ver=-1",
|
|
|
|
"tile part=0 width=256 height=256 tileposx=0 tileposy=15360 tilewidth=3840 tileheight=3840 oldwid=0 wid=0 ver=-1",
|
|
|
|
"tile part=0 width=256 height=256 tileposx=0 tileposy=23040 tilewidth=3840 tileheight=3840 oldwid=0 wid=0 ver=-1"
|
2016-09-30 15:02:22 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
for (auto &tile : tiles)
|
|
|
|
queue.put(tile);
|
|
|
|
|
2016-10-04 07:23:42 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(4, static_cast<int>(queue._queue.size()));
|
2016-09-30 15:02:22 -05:00
|
|
|
|
|
|
|
// should result in the 3, 2, 1, 0 order of the tiles thanks to the cursor
|
|
|
|
// positions
|
|
|
|
for (size_t i = 0; i < tiles.size(); ++i)
|
|
|
|
{
|
2016-10-04 07:23:42 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(tiles[3 - i], payloadAsString(queue.get()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void TileQueueTests::testPreviewsDeprioritization()
|
|
|
|
{
|
|
|
|
TileQueue queue;
|
|
|
|
|
|
|
|
// simple case - put previews to the queue and get everything back again
|
|
|
|
const std::vector<std::string> previews =
|
|
|
|
{
|
|
|
|
"tile part=0 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=-1 id=0",
|
|
|
|
"tile part=1 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=-1 id=1",
|
|
|
|
"tile part=2 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=-1 id=2",
|
|
|
|
"tile part=3 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=-1 id=3"
|
|
|
|
};
|
2016-09-30 15:02:22 -05:00
|
|
|
|
2016-10-04 07:23:42 -05:00
|
|
|
for (auto &preview : previews)
|
|
|
|
queue.put(preview);
|
|
|
|
|
|
|
|
for (size_t i = 0; i < previews.size(); ++i)
|
|
|
|
{
|
|
|
|
CPPUNIT_ASSERT_EQUAL(previews[i], payloadAsString(queue.get()));
|
2016-09-30 15:02:22 -05:00
|
|
|
}
|
|
|
|
|
2016-10-04 07:23:42 -05:00
|
|
|
// stays empty after all is done
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, static_cast<int>(queue._queue.size()));
|
|
|
|
|
|
|
|
// re-ordering case - put previews and normal tiles to the queue and get
|
|
|
|
// everything back again but this time the tiles have to interleave with
|
|
|
|
// the previews
|
|
|
|
const std::vector<std::string> tiles =
|
|
|
|
{
|
2017-06-14 11:28:07 -05:00
|
|
|
"tile part=0 width=256 height=256 tileposx=0 tileposy=0 tilewidth=3840 tileheight=3840 oldwid=0 wid=0 ver=-1",
|
|
|
|
"tile part=0 width=256 height=256 tileposx=0 tileposy=7680 tilewidth=3840 tileheight=3840 oldwid=0 wid=0 ver=-1"
|
2016-10-04 07:23:42 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
for (auto &preview : previews)
|
|
|
|
queue.put(preview);
|
|
|
|
|
|
|
|
queue.put(tiles[0]);
|
|
|
|
|
2016-11-29 20:55:44 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(previews[0], payloadAsString(queue.get()));
|
2017-01-25 12:14:38 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(tiles[0], payloadAsString(queue.get()));
|
2016-10-04 07:23:42 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(previews[1], payloadAsString(queue.get()));
|
|
|
|
|
|
|
|
queue.put(tiles[1]);
|
|
|
|
|
2016-11-29 20:55:44 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(previews[2], payloadAsString(queue.get()));
|
2017-01-25 12:14:38 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(tiles[1], payloadAsString(queue.get()));
|
2016-10-04 07:23:42 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(previews[3], payloadAsString(queue.get()));
|
|
|
|
|
|
|
|
// stays empty after all is done
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, static_cast<int>(queue._queue.size()));
|
|
|
|
|
|
|
|
// cursor positioning case - the cursor position should not prioritize the
|
|
|
|
// previews
|
|
|
|
queue.updateCursorPosition(0, 0, 0, 0, 10, 100);
|
|
|
|
|
|
|
|
queue.put(tiles[1]);
|
|
|
|
queue.put(previews[0]);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(tiles[1], payloadAsString(queue.get()));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(previews[0], payloadAsString(queue.get()));
|
|
|
|
|
|
|
|
// stays empty after all is done
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, static_cast<int>(queue._queue.size()));
|
2016-09-30 15:02:22 -05:00
|
|
|
}
|
|
|
|
|
2016-12-18 11:04:18 -06:00
|
|
|
void TileQueueTests::testSenderQueue()
|
|
|
|
{
|
2017-01-21 18:51:02 -06:00
|
|
|
SenderQueue<std::shared_ptr<Message>> queue;
|
2016-12-18 11:04:18 -06:00
|
|
|
|
2017-01-21 18:51:02 -06:00
|
|
|
std::shared_ptr<Message> item;
|
2016-12-18 11:04:18 -06:00
|
|
|
|
|
|
|
// Empty queue
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(false, queue.dequeue(item));
|
2016-12-18 11:04:18 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
|
|
|
|
const std::vector<std::string> messages =
|
|
|
|
{
|
|
|
|
"message 1",
|
|
|
|
"message 2",
|
|
|
|
"message 3"
|
|
|
|
};
|
|
|
|
|
|
|
|
for (const auto& msg : messages)
|
|
|
|
{
|
2017-01-21 18:51:02 -06:00
|
|
|
queue.enqueue(std::make_shared<Message>(msg, Message::Dir::Out));
|
2016-12-18 11:04:18 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(3UL, queue.size());
|
|
|
|
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 11:04:18 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(2UL, queue.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(messages[0], std::string(item->data().data(), item->data().size()));
|
|
|
|
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 11:04:18 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(1UL, queue.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(messages[1], std::string(item->data().data(), item->data().size()));
|
2016-12-18 16:28:35 -06:00
|
|
|
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 11:04:18 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(messages[2], std::string(item->data().data(), item->data().size()));
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
}
|
|
|
|
|
|
|
|
void TileQueueTests::testSenderQueueTileDeduplication()
|
|
|
|
{
|
2017-01-21 18:51:02 -06:00
|
|
|
SenderQueue<std::shared_ptr<Message>> queue;
|
2016-12-18 11:04:18 -06:00
|
|
|
|
2017-01-21 18:51:02 -06:00
|
|
|
std::shared_ptr<Message> item;
|
2016-12-18 11:04:18 -06:00
|
|
|
|
|
|
|
// Empty queue
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(false, queue.dequeue(item));
|
2016-12-18 11:04:18 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
|
|
|
|
const std::vector<std::string> part_messages =
|
|
|
|
{
|
|
|
|
"tile: part=0 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=0",
|
|
|
|
"tile: part=1 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=1",
|
|
|
|
"tile: part=2 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=-1"
|
|
|
|
};
|
|
|
|
|
|
|
|
for (const auto& msg : part_messages)
|
|
|
|
{
|
2017-01-21 18:51:02 -06:00
|
|
|
queue.enqueue(std::make_shared<Message>(msg, Message::Dir::Out));
|
2016-12-18 11:04:18 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(3UL, queue.size());
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 11:04:18 -06:00
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
|
|
|
|
const std::vector<std::string> dup_messages =
|
|
|
|
{
|
|
|
|
"tile: part=0 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=-1",
|
|
|
|
"tile: part=0 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=1",
|
|
|
|
"tile: part=0 width=180 height=135 tileposx=0 tileposy=0 tilewidth=15875 tileheight=11906 ver=1"
|
|
|
|
};
|
|
|
|
|
|
|
|
for (const auto& msg : dup_messages)
|
|
|
|
{
|
2017-01-21 18:51:02 -06:00
|
|
|
queue.enqueue(std::make_shared<Message>(msg, Message::Dir::Out));
|
2016-12-18 11:04:18 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1UL, queue.size());
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 11:04:18 -06:00
|
|
|
|
|
|
|
// The last one should persist.
|
|
|
|
CPPUNIT_ASSERT_EQUAL(dup_messages[2], std::string(item->data().data(), item->data().size()));
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
}
|
|
|
|
|
2016-12-18 16:28:35 -06:00
|
|
|
void TileQueueTests::testInvalidateViewCursorDeduplication()
|
|
|
|
{
|
2017-01-21 18:51:02 -06:00
|
|
|
SenderQueue<std::shared_ptr<Message>> queue;
|
2016-12-18 16:28:35 -06:00
|
|
|
|
2017-01-21 18:51:02 -06:00
|
|
|
std::shared_ptr<Message> item;
|
2016-12-18 16:28:35 -06:00
|
|
|
|
|
|
|
// Empty queue
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(false, queue.dequeue(item));
|
2016-12-18 16:28:35 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
|
|
|
|
const std::vector<std::string> view_messages =
|
|
|
|
{
|
|
|
|
"invalidateviewcursor: { \"viewId\": \"1\", \"rectangle\": \"3999, 1418, 0, 298\", \"part\": \"0\" }",
|
|
|
|
"invalidateviewcursor: { \"viewId\": \"2\", \"rectangle\": \"3999, 1418, 0, 298\", \"part\": \"0\" }",
|
|
|
|
"invalidateviewcursor: { \"viewId\": \"3\", \"rectangle\": \"3999, 1418, 0, 298\", \"part\": \"0\" }",
|
|
|
|
};
|
|
|
|
|
|
|
|
for (const auto& msg : view_messages)
|
|
|
|
{
|
2017-01-21 18:51:02 -06:00
|
|
|
queue.enqueue(std::make_shared<Message>(msg, Message::Dir::Out));
|
2016-12-18 16:28:35 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(3UL, queue.size());
|
|
|
|
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 16:28:35 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(2UL, queue.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(view_messages[0], std::string(item->data().data(), item->data().size()));
|
|
|
|
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 16:28:35 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(1UL, queue.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(view_messages[1], std::string(item->data().data(), item->data().size()));
|
|
|
|
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 16:28:35 -06:00
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(view_messages[2], std::string(item->data().data(), item->data().size()));
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
|
|
|
|
const std::vector<std::string> dup_messages =
|
|
|
|
{
|
|
|
|
"invalidateviewcursor: { \"viewId\": \"1\", \"rectangle\": \"3999, 1418, 0, 298\", \"part\": \"0\" }",
|
|
|
|
"invalidateviewcursor: { \"viewId\": \"1\", \"rectangle\": \"1000, 1418, 0, 298\", \"part\": \"0\" }",
|
|
|
|
"invalidateviewcursor: { \"viewId\": \"1\", \"rectangle\": \"2000, 1418, 0, 298\", \"part\": \"0\" }",
|
|
|
|
};
|
|
|
|
|
|
|
|
for (const auto& msg : dup_messages)
|
|
|
|
{
|
2017-01-21 18:51:02 -06:00
|
|
|
queue.enqueue(std::make_shared<Message>(msg, Message::Dir::Out));
|
2016-12-18 16:28:35 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1UL, queue.size());
|
2017-03-15 05:20:43 -05:00
|
|
|
CPPUNIT_ASSERT_EQUAL(true, queue.dequeue(item));
|
2016-12-18 16:28:35 -06:00
|
|
|
|
|
|
|
// The last one should persist.
|
|
|
|
CPPUNIT_ASSERT_EQUAL(dup_messages[2], std::string(item->data().data(), item->data().size()));
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0UL, queue.size());
|
|
|
|
}
|
|
|
|
|
2017-01-25 11:21:56 -06:00
|
|
|
void TileQueueTests::testCallbackInvalidation()
|
|
|
|
{
|
|
|
|
TileQueue queue;
|
|
|
|
|
|
|
|
// join tiles
|
|
|
|
queue.put("callback all 0 284, 1418, 11105, 275, 0");
|
|
|
|
queue.put("callback all 0 4299, 1418, 7090, 275, 0");
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, static_cast<int>(queue._queue.size()));
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("callback all 0 284, 1418, 11105, 275, 0"), payloadAsString(queue.get()));
|
|
|
|
|
|
|
|
// invalidate everywhing with EMPTY, but keep the different part intact
|
|
|
|
queue.put("callback all 0 284, 1418, 11105, 275, 0");
|
|
|
|
queue.put("callback all 0 4299, 1418, 7090, 275, 1");
|
|
|
|
queue.put("callback all 0 4299, 10418, 7090, 275, 0");
|
|
|
|
queue.put("callback all 0 4299, 20418, 7090, 275, 0");
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(4, static_cast<int>(queue._queue.size()));
|
|
|
|
|
|
|
|
queue.put("callback all 0 EMPTY, 0");
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(2, static_cast<int>(queue._queue.size()));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("callback all 0 4299, 1418, 7090, 275, 1"), payloadAsString(queue.get()));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("callback all 0 EMPTY, 0"), payloadAsString(queue.get()));
|
|
|
|
}
|
|
|
|
|
2017-04-07 05:29:01 -05:00
|
|
|
void TileQueueTests::testCallbackIndicatorValue()
|
|
|
|
{
|
|
|
|
TileQueue queue;
|
|
|
|
|
|
|
|
// join tiles
|
|
|
|
queue.put("callback all 10 25");
|
|
|
|
queue.put("callback all 10 50");
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, static_cast<int>(queue._queue.size()));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("callback all 10 50"), payloadAsString(queue.get()));
|
|
|
|
}
|
|
|
|
|
|
|
|
void TileQueueTests::testCallbackPageSize()
|
|
|
|
{
|
|
|
|
TileQueue queue;
|
|
|
|
|
|
|
|
// join tiles
|
|
|
|
queue.put("callback all 13 12474, 188626");
|
|
|
|
queue.put("callback all 13 12474, 205748");
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, static_cast<int>(queue._queue.size()));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("callback all 13 12474, 205748"), payloadAsString(queue.get()));
|
|
|
|
}
|
|
|
|
|
2016-09-29 13:04:05 -05:00
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION(TileQueueTests);
|
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|