aboutsummaryrefslogtreecommitdiff
path: root/src/profiling/test
diff options
context:
space:
mode:
authorMatteo Martincigh <matteo.martincigh@arm.com>2019-10-16 10:29:17 +0100
committerMatteo Martincigh <matteo.martincigh@arm.com>2019-10-16 13:41:02 +0100
commit8844c2f35b06931a799f9a77637e8e291b43d60a (patch)
treeecee747df54c51916381170635bbaa2b89a86824 /src/profiling/test
parentb884ea4441097b2a8231aed90b41a637524944c2 (diff)
downloadarmnn-8844c2f35b06931a799f9a77637e8e291b43d60a.tar.gz
IVGCVSW-3931 Create the Timeline Event Binary Packet
* Added WriteTimelineEventBinaryPacket function * Added unit tests * Code refactoring Signed-off-by: Matteo Martincigh <matteo.martincigh@arm.com> Change-Id: I36b6a8b26bb46eb5ea97bb711ef7e153ea6d851f
Diffstat (limited to 'src/profiling/test')
-rw-r--r--src/profiling/test/TimelinePacketTests.cpp114
1 files changed, 113 insertions, 1 deletions
diff --git a/src/profiling/test/TimelinePacketTests.cpp b/src/profiling/test/TimelinePacketTests.cpp
index 759d825580..558af0400b 100644
--- a/src/profiling/test/TimelinePacketTests.cpp
+++ b/src/profiling/test/TimelinePacketTests.cpp
@@ -433,4 +433,116 @@ BOOST_AUTO_TEST_CASE(TimelineEventClassTest4)
BOOST_CHECK(readProfilingGuid == profilingGuid);
}
-BOOST_AUTO_TEST_SUITE_END() // TimelinePacketTests \ No newline at end of file
+BOOST_AUTO_TEST_CASE(TimelineEventPacketTest1)
+{
+ const uint64_t timestamp = 456789u;
+ const uint32_t threadId = 654321u;
+ const uint64_t profilingGuid = 123456u;
+ unsigned int numberOfBytesWritten = 789u;
+ TimelinePacketStatus result = WriteTimelineEventBinaryPacket(timestamp,
+ threadId,
+ profilingGuid,
+ nullptr,
+ 512u,
+ numberOfBytesWritten);
+ BOOST_CHECK(result == TimelinePacketStatus::BufferExhaustion);
+ BOOST_CHECK(numberOfBytesWritten == 0);
+}
+
+BOOST_AUTO_TEST_CASE(TimelineEventPacketTest2)
+{
+ std::vector<unsigned char> buffer(512, 0);
+
+ const uint64_t timestamp = 456789u;
+ const uint32_t threadId = 654321u;
+ const uint64_t profilingGuid = 123456u;
+ unsigned int numberOfBytesWritten = 789u;
+ TimelinePacketStatus result = WriteTimelineEventBinaryPacket(timestamp,
+ threadId,
+ profilingGuid,
+ buffer.data(),
+ 0,
+ numberOfBytesWritten);
+ BOOST_CHECK(result == TimelinePacketStatus::BufferExhaustion);
+ BOOST_CHECK(numberOfBytesWritten == 0);
+}
+
+BOOST_AUTO_TEST_CASE(TimelineEventPacketTest3)
+{
+ std::vector<unsigned char> buffer(10, 0);
+
+ const uint64_t timestamp = 456789u;
+ const uint32_t threadId = 654321u;
+ const uint64_t profilingGuid = 123456u;
+ unsigned int numberOfBytesWritten = 789u;
+ TimelinePacketStatus result = WriteTimelineEventBinaryPacket(timestamp,
+ threadId,
+ profilingGuid,
+ buffer.data(),
+ boost::numeric_cast<unsigned int>(buffer.size()),
+ numberOfBytesWritten);
+ BOOST_CHECK(result == TimelinePacketStatus::BufferExhaustion);
+ BOOST_CHECK(numberOfBytesWritten == 0);
+}
+
+BOOST_AUTO_TEST_CASE(TimelineEventPacketTest4)
+{
+ std::vector<unsigned char> buffer(512, 0);
+
+ const uint64_t timestamp = 456789u;
+ const uint32_t threadId = 654321u;
+ const uint64_t profilingGuid = 123456u;
+ unsigned int numberOfBytesWritten = 789u;
+ TimelinePacketStatus result = WriteTimelineEventBinaryPacket(timestamp,
+ threadId,
+ profilingGuid,
+ buffer.data(),
+ boost::numeric_cast<unsigned int>(buffer.size()),
+ numberOfBytesWritten);
+ BOOST_CHECK(result == TimelinePacketStatus::Ok);
+ BOOST_CHECK(numberOfBytesWritten == 32);
+
+ unsigned int uint32_t_size = sizeof(uint32_t);
+ unsigned int uint64_t_size = sizeof(uint64_t);
+
+ // Check the packet header
+ unsigned int offset = 0;
+ uint32_t packetHeaderWord0 = ReadUint32(buffer.data(), offset);
+ uint32_t packetFamily = (packetHeaderWord0 >> 26) & 0x0000003F;
+ uint32_t packetClass = (packetHeaderWord0 >> 19) & 0x0000007F;
+ uint32_t packetType = (packetHeaderWord0 >> 16) & 0x00000007;
+ uint32_t streamId = (packetHeaderWord0 >> 0) & 0x00000007;
+ BOOST_CHECK(packetFamily == 1);
+ BOOST_CHECK(packetClass == 0);
+ BOOST_CHECK(packetType == 1);
+ BOOST_CHECK(streamId == 0);
+
+ offset += uint32_t_size;
+ uint32_t packetHeaderWord1 = ReadUint32(buffer.data(), offset);
+ uint32_t sequenceNumbered = (packetHeaderWord1 >> 24) & 0x00000001;
+ uint32_t dataLength = (packetHeaderWord1 >> 0) & 0x00FFFFFF;
+ BOOST_CHECK(sequenceNumbered == 0);
+ BOOST_CHECK(dataLength == 24);
+
+ // Check the decl_id
+ offset += uint32_t_size;
+ uint32_t readDeclId = ReadUint32(buffer.data(), offset);
+ BOOST_CHECK(readDeclId == 4);
+
+ // Check the timestamp
+ offset += uint32_t_size;
+ uint64_t readTimestamp = ReadUint64(buffer.data(), offset);
+ BOOST_CHECK(readTimestamp == timestamp);
+
+ // Check the thread id
+ offset += uint64_t_size;
+ uint32_t readThreadId = ReadUint32(buffer.data(), offset);
+ BOOST_CHECK(readThreadId == threadId);
+
+ // Check the profiling GUID
+ offset += uint32_t_size;
+ uint64_t readProfilingGuid = ReadUint64(buffer.data(), offset);
+ BOOST_CHECK(readProfilingGuid == profilingGuid);
+}
+
+BOOST_AUTO_TEST_SUITE_END()