From af5c46bde858e88392214be41361588c1ebee5f0 Mon Sep 17 00:00:00 2001 From: Ferran Balaguer Date: Fri, 30 Aug 2019 15:49:15 +0100 Subject: IVGCVSW-3434 Create the SendCounterPacket interface Signed-off-by: Ferran Balaguer Change-Id: I0d9b0ab12f17cb86544163ce3f0dc4945151e9e1 --- src/profiling/test/SendCounterPacketTests.cpp | 131 ++++++++++++++++++++++++++ 1 file changed, 131 insertions(+) create mode 100644 src/profiling/test/SendCounterPacketTests.cpp (limited to 'src/profiling/test/SendCounterPacketTests.cpp') diff --git a/src/profiling/test/SendCounterPacketTests.cpp b/src/profiling/test/SendCounterPacketTests.cpp new file mode 100644 index 0000000000..9a314c1fdc --- /dev/null +++ b/src/profiling/test/SendCounterPacketTests.cpp @@ -0,0 +1,131 @@ +// +// Copyright © 2017 Arm Ltd. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#include "../IBufferWrapper.hpp" +#include "../ISendCounterPacket.hpp" + +#include +#include + + +BOOST_AUTO_TEST_SUITE(SendCounterPacketTests) + +using namespace armnn::profiling; + +class MockBuffer : public IBufferWrapper +{ +public: + MockBuffer() : m_Buffer() {} + + unsigned char* Reserve(unsigned int requestedSize, unsigned int& reservedSize) override + { + if (requestedSize > m_BufferSize) + { + reservedSize = m_BufferSize; + } + else + { + reservedSize = requestedSize; + } + + return m_Buffer; + } + + void Commit(unsigned int size) override {} + + const unsigned char* GetReadBuffer(unsigned int& size) override + { + size = static_cast(strlen(reinterpret_cast(m_Buffer)) + 1); + return m_Buffer; + } + + void Release( unsigned int size) override {} + +private: + static const unsigned int m_BufferSize = 512; + unsigned char m_Buffer[m_BufferSize]; +}; + +class MockSendCounterPacket : public ISendCounterPacket +{ +public: + MockSendCounterPacket(IBufferWrapper& sendBuffer) : m_Buffer(sendBuffer) {} + + void SendStreamMetaDataPacket() override + { + std::string message("SendStreamMetaDataPacket"); + unsigned int reserved = 0; + unsigned char* buffer = m_Buffer.Reserve(1024, reserved); + memcpy(buffer, message.c_str(), static_cast(message.size()) + 1); + } + + void SendCounterDirectoryPacket(const Category& category, const std::vector& counters) override + { + std::string message("SendCounterDirectoryPacket"); + unsigned int reserved = 0; + unsigned char* buffer = m_Buffer.Reserve(1024, reserved); + memcpy(buffer, message.c_str(), static_cast(message.size()) + 1); + } + + void SendPeriodicCounterCapturePacket(uint64_t timestamp, const std::vector& counterValues, + const std::vector& counterUids) override + { + std::string message("SendPeriodicCounterCapturePacket"); + unsigned int reserved = 0; + unsigned char* buffer = m_Buffer.Reserve(1024, reserved); + memcpy(buffer, message.c_str(), static_cast(message.size()) + 1); + } + + void SendPeriodicCounterSelectionPacket(uint32_t capturePeriod, + const std::vector& selectedCounterIds) override + { + std::string message("SendPeriodicCounterSelectionPacket"); + unsigned int reserved = 0; + unsigned char* buffer = m_Buffer.Reserve(1024, reserved); + memcpy(buffer, message.c_str(), static_cast(message.size()) + 1); + m_Buffer.Commit(reserved); + } + + void SetReadyToRead() override + {} + +private: + IBufferWrapper& m_Buffer; +}; + +BOOST_AUTO_TEST_CASE(MockSendCounterPacketTest) +{ + unsigned int size = 0; + + MockBuffer mockBuffer; + MockSendCounterPacket sendCounterPacket(mockBuffer); + + sendCounterPacket.SendStreamMetaDataPacket(); + const char* buffer = reinterpret_cast(mockBuffer.GetReadBuffer(size)); + + BOOST_TEST(strcmp(buffer, "SendStreamMetaDataPacket") == 0); + + Category category; + std::vector counters; + sendCounterPacket.SendCounterDirectoryPacket(category, counters); + + BOOST_TEST(strcmp(buffer, "SendCounterDirectoryPacket") == 0); + + uint64_t timestamp = 0; + std::vector counterValues; + std::vector counterUids; + sendCounterPacket.SendPeriodicCounterCapturePacket(timestamp, counterValues, counterUids); + + BOOST_TEST(strcmp(buffer, "SendPeriodicCounterCapturePacket") == 0); + + uint32_t capturePeriod = 0; + std::vector selectedCounterIds; + sendCounterPacket.SendPeriodicCounterSelectionPacket(capturePeriod, selectedCounterIds); + + BOOST_TEST(strcmp(buffer, "SendPeriodicCounterSelectionPacket") == 0); + +} + +BOOST_AUTO_TEST_SUITE_END() -- cgit v1.2.1