Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(275)

Unified Diff: tools/py_event_log_analyzer/pb_parse.py

Issue 1999113002: New rtc dump analyzing tool in Python (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Moved unit test. Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tools/py_event_log_analyzer/pb_parse.py
diff --git a/tools/py_event_log_analyzer/pb_parse.py b/tools/py_event_log_analyzer/pb_parse.py
new file mode 100644
index 0000000000000000000000000000000000000000..d28a96e765ee575fe46c129489589d68630c1312
--- /dev/null
+++ b/tools/py_event_log_analyzer/pb_parse.py
@@ -0,0 +1,64 @@
+# Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
+#
+# Use of this source code is governed by a BSD-style license
+# that can be found in the LICENSE file in the root of the source
+# tree. An additional intellectual property rights grant can be found
+# in the file PATENTS. All contributing project authors may
+# be found in the AUTHORS file in the root of the source tree.
+
+"""Parses protobuf RTC dumps.
+"""
phoglund 2016/05/31 13:47:43 Nit: pull up line #10 to #9.
+
+from __future__ import division
+
+import os
+import struct
+import sys
+
+
+# makes sure to import correct protobuf
phoglund 2016/05/31 13:47:43 Nit: uppercase M, end with .
+sys.path += [os.path.join("../../", path) for path in
+ ["out/Debug/pyproto/webrtc/call/",
phoglund 2016/05/31 13:47:43 We should not do import hacks, and especially not
aleloi 2016/06/02 14:01:56 I added the changes to /webrtc/webrtc.gyp and /web
+ "out/Release/pyproto/webrtc/call/",
+ "third_party/protobuf/python/"]]
+import rtc_event_log_pb2 as rtc_pb
+
+
+class DataPoint(object):
+ """Simple container class for RTP events.
+ """
+
+ def __init__(self, rtp_header_str, packet_size,
+ arrival_timestamp_us):
+ """Builds a data point by parsing an RTP header, and extra information
+ about packet size and arrival time.
+
+ RTP header structure is defined in RFC 3550 section 5.1.
+
+ """
+ self.size = packet_size
+ self.arrival_timestamp_ms = arrival_timestamp_us / 1000
+ (first2header_bytes, self.sequence_number,
+ self.timestamp, self.ssrc
+ ) = struct.unpack_from("!HHII", rtp_header_str, 0)
+ self.payload_type = first2header_bytes & 0b01111111
+
+
+def parse_protobuf(file_path):
+ """Parses RTC event log from protobuf file.
+
+ Args:
+ file_path: path to protobuf file of RTC event stream
+
+ Returns:
+ all RTP packet events from the event stream as a list of DataPoints
+ """
+ event_stream = rtc_pb.EventStream()
+ with open(file_path, "rb") as f:
+ event_stream.ParseFromString(f.read())
+
+ return [DataPoint(event.rtp_packet.header,
+ event.rtp_packet.packet_length,
+ event.timestamp_us)
+ for event in event_stream.stream
+ if event.HasField("rtp_packet")]

Powered by Google App Engine
This is Rietveld 408576698