Home | History | Annotate | Download | only in cros
      1 import unittest
      2 
      3 import cfm_jmidata_log_collector
      4 
      5 
      6 class CfmJmidataLogCollectorTest(unittest.TestCase):
      7     """
      8     Tests for the CfmJmidataLogCOllector.
      9     """
     10     # Test methods, disable missing-docstring
     11     # pylint: disable=missing-docstring
     12     def jmi_get_no_error(self, key):
     13         data = cfm_jmidata_log_collector.GetDataFromLogs(self, key, JMI_LOG)
     14 
     15     def test_jmi_data(self):
     16         # TODO(kerl): Add assertions on the actual values.
     17         self.jmi_get_no_error('video_sent_bytes')
     18         self.jmi_get_no_error('video_received_bytes')
     19         self.jmi_get_no_error('audio_sent_bytes')
     20         self.jmi_get_no_error('audio_received_bytes')
     21         self.jmi_get_no_error('audio_received_energy_level')
     22         self.jmi_get_no_error('audio_sent_energy_level')
     23         self.jmi_get_no_error('framerate_received')
     24         self.jmi_get_no_error('framerate_sent')
     25         self.jmi_get_no_error('framerate_decoded')
     26         self.jmi_get_no_error('frames_decoded')
     27         self.jmi_get_no_error('frames_encoded')
     28         self.jmi_get_no_error('average_encode_time')
     29         self.jmi_get_no_error('framerate_to_renderer')
     30         self.jmi_get_no_error('framerate_outgoing')
     31         self.jmi_get_no_error('video_sent_frame_width')
     32         self.jmi_get_no_error('video_received_frame_width')
     33         self.jmi_get_no_error('video_sent_frame_height')
     34         self.jmi_get_no_error('video_received_frame_height')
     35         self.jmi_get_no_error('cpu_adaptation')
     36         self.jmi_get_no_error('bandwidth_adaptation')
     37         self.jmi_get_no_error('adaptation_changes')
     38         self.jmi_get_no_error('video_packets_sent')
     39         self.jmi_get_no_error('video_packets_lost')
     40         self.jmi_get_no_error('video_encode_cpu_usage')
     41         self.jmi_get_no_error('num_active_vid_in_streams')
     42         self.jmi_get_no_error('cpu_processors')
     43         self.jmi_get_no_error('cpu_percent')
     44         self.jmi_get_no_error('browser_cpu_percent')
     45         self.jmi_get_no_error('gpu_cpu_percent')
     46         self.jmi_get_no_error('nacl_effects_cpu_percent')
     47         self.jmi_get_no_error('renderer_cpu_percent')
     48 
     49 if __name__ == '__main__':
     50     unittest.main()
     51 
     52 
     53 JMI_LOG = (
     54 '[15.269s]8 talk.media.webrtc.FluteSession: Sending ["jmidatav3","muvc-priva'
     55 'te-chat-9999i7ng7stjkncgvef6rsa76e44sme (at] groupchat.google.com","c24448231337'
     56 '9091599_NMS",0,{"global":{"jmiVersion":3,"numOfProcessors":4,"totalCpuUsage'
     57 '":118.68242938362964,"tabCpuUsage":86.59793314433666,"browserCpuUsage":19.1'
     58 '03619952307305,"gpuCpuUsage":37.19470138265887}},null,{"VideoBwe":{"googAct'
     59 'ualEncBitrate":1374400,"googAvailableSendBandwidth":3956329,"googRetransmit'
     60 'Bitrate":0,"googAvailableReceiveBandwidth":0,"googTargetEncBitrate":3400000'
     61 ',"googBucketDelay":0,"googTransmitBitrate":1389144}},null,{"googCandidatePa'
     62 'ir":{"responsesSent":0,"requestsReceived":0,"googRemoteCandidateType":"loca'
     63 'l","googReadable":"true","googLocalAddress":"[2620:0:1000:1309:3d4f:37b0:65'
     64 '9a:5378]:55946","consentRequestsSent":1,"googTransportType":"udp","googChan'
     65 'nelId":"Channel-audio-1","googLocalCandidateType":"local","googWritable":"t'
     66 'rue","requestsSent":8,"googRemoteAddress":"[2607:f8b0:400e:c05::7f]:19305",'
     67 '"googRtt":20,"googActiveConnection":"true","packetsDiscardedOnSend":0,"byte'
     68 'sReceived":5593200,"responsesReceived":8,"remoteCandidateId":"Cand-ztHGWbjH'
     69 '","localCandidateId":"Cand-iAXjSqBm","bytesSent":1915475,"packetsSent":2367'
     70 '}},{"localcandidate":{"networkType":"unknown","id":"Cand-iAXjSqBm"}},null,{'
     71 '"googCandidatePair":{"responsesSent":0,"requestsReceived":0,"googRemoteCand'
     72 'idateType":"local","googReadable":"false","googLocalAddress":"172.27.213.80'
     73 ':55830","consentRequestsSent":0,"googTransportType":"udp","googChannelId":"'
     74 'Channel-audio-1","googLocalCandidateType":"local","googWritable":"false","r'
     75 'equestsSent":0,"googRemoteAddress":"173.194.203.127:19305","googRtt":3000,"'
     76 'googActiveConnection":"false","packetsDiscardedOnSend":0,"bytesReceived":0,'
     77 '"responsesReceived":0,"remoteCandidateId":"Cand-DcRzosft","localCandidateId'
     78 '":"Cand-t/EGflq7","bytesSent":0,"packetsSent":0}},{"localcandidate":{"netwo'
     79 'rkType":"unknown","id":"Cand-t/EGflq7"}},null,null,null,null,null,null,null'
     80 ',null,null,null,null,null,null,null,null,null,null,null,null,null,null,{"ss'
     81 'rc":{"googDecodingCTN":958,"packetsLost":0,"googSecondaryDecodedRate":0,"go'
     82 'ogDecodingPLC":3,"packetsReceived":1,"googExpandRate":0,"googJitterReceived'
     83 '":0,"googDecodingCNG":847,"ssrc":181174217,"googPreferredJitterBufferMs":0,'
     84 '"googSpeechExpandRate":0,"totalSamplesDuration":9.58,"totalAudioEnergy":0,"'
     85 'transportId":"Channel-audio-1","mediaType":"audio","googDecodingPLCCNG":108'
     86 ',"googCodecName":"opus","googSecondaryDiscardedRate":0,"googDecodingNormal"'
     87 ':0,"googTrackId":"hangout7F4822D4_ephemeral.id.google.com%5Efd2eefeedc/1811'
     88 '74217","audioOutputLevel":0,"googAccelerateRate":0,"bytesReceived":21,"goog'
     89 'CurrentDelayMs":10,"googDecodingCTSG":0,"googCaptureStartNtpTimeMs":0,"goog'
     90 'PreemptiveExpandRate":0,"googJitterBufferMs":10,"googDecodingMuted":107}},{'
     91 '"ssrc":{"googDecodingCTN":958,"packetsLost":0,"googSecondaryDecodedRate":0,'
     92 '"googDecodingPLC":4,"packetsReceived":46,"googExpandRate":0,"googJitterRece'
     93 'ived":1,"googDecodingCNG":914,"ssrc":1176043198,"googPreferredJitterBufferM'
     94 's":20,"googSpeechExpandRate":0,"totalSamplesDuration":9.58,"totalAudioEnerg'
     95 'y":8.7084e-9,"transportId":"Channel-audio-1","mediaType":"audio","googDecod'
     96 'ingPLCCNG":10,"googCodecName":"opus","googSecondaryDiscardedRate":0,"googDe'
     97 'codingNormal":30,"googTrackId":"hangoutF18BB657_ephemeral.id.google.com%5Ed'
     98 '5e1b749e1/1176043198","audioOutputLevel":1,"googAccelerateRate":0,"bytesRec'
     99 'eived":1679,"googCurrentDelayMs":89,"googDecodingCTSG":0,"googCaptureStartN'
    100 'tpTimeMs":0,"googPreemptiveExpandRate":0,"googJitterBufferMs":90,"googDecod'
    101 'ingMuted":9}},{"ssrc":{"googDecodingCTN":958,"packetsLost":0,"googSecondary'
    102 'DecodedRate":0,"googDecodingPLC":3,"packetsReceived":46,"googExpandRate":0,'
    103 '"googJitterReceived":2,"googDecodingCNG":919,"ssrc":1301596892,"googPreferr'
    104 'edJitterBufferMs":20,"googSpeechExpandRate":0,"totalSamplesDuration":9.58,"'
    105 'totalAudioEnergy":8.81085e-9,"transportId":"Channel-audio-1","mediaType":"a'
    106 'udio","googDecodingPLCCNG":6,"googCodecName":"opus","googSecondaryDiscarded'
    107 'Rate":0,"googDecodingNormal":30,"googTrackId":"hangoutF724C8C9_ephemeral.id'
    108 '.google.com%5E23a2bf2b70/1301596892","audioOutputLevel":1,"googAccelerateRa'
    109 'te":0,"bytesReceived":1679,"googCurrentDelayMs":80,"googDecodingCTSG":0,"go'
    110 'ogCaptureStartNtpTimeMs":0,"googPreemptiveExpandRate":0,"googJitterBufferMs'
    111 '":80,"googDecodingMuted":5}},{"ssrc":{"googDecodingCTN":958,"packetsLost":0'
    112 ',"googSecondaryDecodedRate":0,"googDecodingPLC":3,"packetsReceived":1,"goog'
    113 'ExpandRate":0,"googJitterReceived":0,"googDecodingCNG":847,"ssrc":226549935'
    114 '5,"googPreferredJitterBufferMs":0,"googSpeechExpandRate":0,"totalSamplesDur'
    115 'ation":9.58,"totalAudioEnergy":0,"transportId":"Channel-audio-1","mediaType'
    116 '":"audio","googDecodingPLCCNG":108,"googCodecName":"opus","googSecondaryDis'
    117 'cardedRate":0,"googDecodingNormal":0,"googTrackId":"hangout83754FD7_ephemer'
    118 'al.id.google.com%5E2f542d3bca/2265499355","audioOutputLevel":0,"googAcceler'
    119 'ateRate":0,"bytesReceived":21,"googCurrentDelayMs":10,"googDecodingCTSG":0,'
    120 '"googCaptureStartNtpTimeMs":0,"googPreemptiveExpandRate":0,"googJitterBuffe'
    121 'rMs":10,"googDecodingMuted":107}},{"ssrc":{"googDecodingCTN":958,"packetsLo'
    122 'st":0,"googSecondaryDecodedRate":0,"googDecodingPLC":0,"packetsReceived":46'
    123 ',"googJitterReceived":1,"googDecodingCNG":929,"ssrc":3200798097,"googPrefer'
    124 'redJitterBufferMs":20,"googSpeechExpandRate":0,"totalSamplesDuration":9.58,'
    125 '"totalAudioEnergy":8.81085e-9,"transportId":"Channel-audio-1","mediaType":"'
    126 'audio","googDecodingPLCCNG":0,"googCodecName":"opus","googSecondaryDiscarde'
    127 'dRate":0,"googDecodingNormal":29,"googTrackId":"hangout2A69C3CE_ephemeral.i'
    128 'd.google.com%5E51a54492e6/3200798097","audioOutputLevel":1,"googAccelerateR'
    129 'ate":0,"bytesReceived":1679,"googCurrentDelayMs":81,"googDecodingCTSG":0,"g'
    130 'oogExpandRate":0,"googPreemptiveExpandRate":0,"googJitterBufferMs":93,"goog'
    131 'DecodingMuted":0}},{"ssrc":{"googDecodingCTN":958,"packetsLost":0,"googSeco'
    132 'ndaryDecodedRate":0,"googDecodingPLC":3,"packetsReceived":15,"googExpandRat'
    133 'e":0,"googJitterReceived":5,"googDecodingCNG":895,"ssrc":3611799563,"googPr'
    134 'eferredJitterBufferMs":20,"googSpeechExpandRate":0,"totalSamplesDuration":9'
    135 '.58,"totalAudioEnergy":0,"transportId":"Channel-audio-1","mediaType":"audio'
    136 '","googDecodingPLCCNG":60,"googCodecName":"opus","googSecondaryDiscardedRat'
    137 'e":0,"googDecodingNormal":0,"googTrackId":"hangoutF9EAE779_ephemeral.id.goo'
    138 'gle.com%5E42ce92f210/3611799563","audioOutputLevel":0,"googAccelerateRate":'
    139 '0,"bytesReceived":315,"googCurrentDelayMs":10,"googDecodingCTSG":0,"googCap'
    140 'tureStartNtpTimeMs":0,"googPreemptiveExpandRate":0,"googJitterBufferMs":90,'
    141 '"googDecodingMuted":59}},{"ssrc":{"googCaptureStartNtpTimeMs":0,"packetsLos'
    142 't":0,"googSecondaryDecodedRate":0,"googDecodingPLC":0,"packetsReceived":0,"'
    143 'googJitterReceived":0,"googDecodingCNG":0,"ssrc":3678956685,"googPreferredJ'
    144 'itterBufferMs":0,"googSpeechExpandRate":0,"totalSamplesDuration":0,"totalAu'
    145 'dioEnergy":0,"transportId":"Channel-audio-1","mediaType":"audio","googDecod'
    146 'ingCTN":0,"googDecodingPLCCNG":0,"googCodecName":"","googDecodingNormal":0,'
    147 '"googTrackId":"hangout9227780C_ephemeral.id.google.com%5Effba3cb857/3678956'
    148 '685","googSecondaryDiscardedRate":0,"googAccelerateRate":0,"bytesReceived":'
    149 '0,"googCurrentDelayMs":0,"googDecodingCTSG":0,"googExpandRate":0,"googPreem'
    150 'ptiveExpandRate":0,"googJitterBufferMs":0,"googDecodingMuted":0}},{"ssrc":{'
    151 '"googDecodingCTN":958,"packetsLost":0,"googSecondaryDecodedRate":0,"googDec'
    152 'odingPLC":3,"packetsReceived":46,"googExpandRate":0,"googJitterReceived":2,'
    153 '"googDecodingCNG":916,"ssrc":3763354856,"googPreferredJitterBufferMs":20,"g'
    154 'oogSpeechExpandRate":0,"totalSamplesDuration":9.58,"totalAudioEnergy":8.801'
    155 '54e-9,"transportId":"Channel-audio-1","mediaType":"audio","googDecodingPLCC'
    156 'NG":9,"googCodecName":"opus","googSecondaryDiscardedRate":0,"googDecodingNo'
    157 'rmal":30,"googTrackId":"hangout757A0188_ephemeral.id.google.com%5E576980a8a'
    158 'e/3763354856","audioOutputLevel":1,"googAccelerateRate":0,"bytesReceived":1'
    159 '679,"googCurrentDelayMs":91,"googDecodingCTSG":0,"googCaptureStartNtpTimeMs'
    160 '":0,"googPreemptiveExpandRate":0,"googJitterBufferMs":90,"googDecodingMuted'
    161 '":8}},{"ssrc":{"googDecodingCTN":958,"packetsLost":0,"googSecondaryDecodedR'
    162 'ate":0,"googDecodingPLC":0,"packetsReceived":46,"googJitterReceived":3,"goo'
    163 'gDecodingCNG":928,"ssrc":4088893509,"googPreferredJitterBufferMs":20,"googS'
    164 'peechExpandRate":0,"totalSamplesDuration":9.58,"totalAudioEnergy":8.80154e-'
    165 '9,"transportId":"Channel-audio-1","mediaType":"audio","googDecodingPLCCNG":'
    166 '0,"googCodecName":"opus","googSecondaryDiscardedRate":0,"googDecodingNormal'
    167 '":30,"googTrackId":"hangoutD84553B2_ephemeral.id.google.com%5E63d56c7215/40'
    168 '88893509","audioOutputLevel":1,"googAccelerateRate":0,"bytesReceived":1748,'
    169 '"googCurrentDelayMs":89,"googDecodingCTSG":0,"googExpandRate":0,"googPreemp'
    170 'tiveExpandRate":0,"googJitterBufferMs":90,"googDecodingMuted":0}},{"ssrc":{'
    171 '"googContentType":"realtime","googCaptureStartNtpTimeMs":0,"googTargetDelay'
    172 'Ms":127,"packetsLost":0,"googDecodeMs":6,"googFrameHeightReceived":180,"goo'
    173 'gFrameRateOutput":23,"packetsReceived":193,"ssrc":234375295,"googRenderDela'
    174 'yMs":10,"googMaxDecodeMs":13,"googTrackId":"hangout7F4822D4_ephemeral.id.go'
    175 'ogle.com%5Efd2eefeedc/234375295","googFrameWidthReceived":320,"codecImpleme'
    176 'ntationName":"unknown","transportId":"Channel-audio-1","mediaType":"video",'
    177 '"googInterframeDelayMax":1541,"googCodecName":"VP8","googFrameRateReceived"'
    178 ':25,"framesDecoded":141,"googNacksSent":0,"googFirsSent":0,"bytesReceived":'
    179 '145834,"googCurrentDelayMs":78,"googMinPlayoutDelayMs":0,"googFrameRateDeco'
    180 'ded":23,"googJitterBufferMs":104,"googPlisSent":0,"fpsGraphicsInput":15.331'
    181 '086576691497,"fpsGraphicsOutput":15.331086576691497,"googFrameSpacing":996}'
    182 '},{"ssrc":{"googContentType":"realtime","googCaptureStartNtpTimeMs":0,"goog'
    183 'TargetDelayMs":117,"packetsLost":0,"googDecodeMs":3,"googFrameHeightReceive'
    184 'd":180,"googFrameRateOutput":24,"packetsReceived":223,"ssrc":365354875,"goo'
    185 'gRenderDelayMs":10,"googMaxDecodeMs":14,"googTrackId":"hangout2A69C3CE_ephe'
    186 'meral.id.google.com%5E51a54492e6/365354875","googFrameWidthReceived":320,"c'
    187 'odecImplementationName":"unknown","transportId":"Channel-audio-1","mediaTyp'
    188 'e":"video","googInterframeDelayMax":362,"googCodecName":"VP8","googFrameRat'
    189 'eReceived":23,"framesDecoded":168,"googNacksSent":0,"googFirsSent":0,"bytes'
    190 'Received":171134,"googCurrentDelayMs":75,"googMinPlayoutDelayMs":0,"googFra'
    191 'meRateDecoded":24,"googJitterBufferMs":93,"googPlisSent":0,"fpsGraphicsInpu'
    192 't":17.980188823503184,"fpsGraphicsOutput":17.980188823503184,"googFrameSpac'
    193 'ing":502}},{"ssrc":{"googContentType":"realtime","googCaptureStartNtpTimeMs'
    194 '":0,"googTargetDelayMs":40,"packetsLost":0,"googDecodeMs":10,"googFrameHeig'
    195 'htReceived":180,"googFrameRateOutput":13,"packetsReceived":1078,"ssrc":6586'
    196 '85198,"googRenderDelayMs":10,"googMaxDecodeMs":12,"googTrackId":"hangoutD84'
    197 '553B2_ephemeral.id.google.com%5E63d56c7215/658685198","googFrameWidthReceiv'
    198 'ed":320,"codecImplementationName":"unknown","transportId":"Channel-audio-1"'
    199 ',"mediaType":"video","googInterframeDelayMax":152,"googCodecName":"VP8","go'
    200 'ogFrameRateReceived":13,"framesDecoded":108,"googNacksSent":0,"googFirsSent'
    201 '":0,"bytesReceived":1232161,"googCurrentDelayMs":40,"googMinPlayoutDelayMs"'
    202 ':0,"googFrameRateDecoded":13,"googJitterBufferMs":18,"googPlisSent":0,"fpsG'
    203 'raphicsInput":11.537631880897864,"fpsGraphicsOutput":11.42980354556237,"goo'
    204 'gFrameSpacing":501}},{"ssrc":{"googContentType":"realtime","googCaptureStar'
    205 'tNtpTimeMs":0,"googTargetDelayMs":110,"packetsLost":0,"googDecodeMs":19,"go'
    206 'ogFrameHeightReceived":720,"googFrameRateOutput":23,"packetsReceived":2542,'
    207 '"ssrc":771366933,"googRenderDelayMs":10,"googMaxDecodeMs":22,"googTrackId":'
    208 '"hangoutF18BB657_ephemeral.id.google.com%5Ed5e1b749e1/771366933","googFrame'
    209 'WidthReceived":1280,"codecImplementationName":"unknown","transportId":"Chan'
    210 'nel-audio-1","mediaType":"video","googInterframeDelayMax":136,"googCodecNam'
    211 'e":"VP8","googFrameRateReceived":24,"framesDecoded":203,"googNacksSent":0,"'
    212 'googFirsSent":0,"bytesReceived":2921629,"googCurrentDelayMs":101,"googMinPl'
    213 'ayoutDelayMs":0,"googFrameRateDecoded":23,"googJitterBufferMs":78,"googPlis'
    214 'Sent":0,"fpsGraphicsInput":21.86439764526312,"fpsGraphicsOutput":21.8539465'
    215 '38565932,"googFrameSpacing":512}},{"ssrc":{"googContentType":"realtime","go'
    216 'ogCaptureStartNtpTimeMs":0,"googTargetDelayMs":103,"packetsLost":0,"googDec'
    217 'odeMs":3,"googFrameHeightReceived":180,"googFrameRateOutput":22,"packetsRec'
    218 'eived":195,"ssrc":811526342,"googRenderDelayMs":10,"googMaxDecodeMs":13,"go'
    219 'ogTrackId":"hangoutF724C8C9_ephemeral.id.google.com%5E23a2bf2b70/811526342"'
    220 ',"googFrameWidthReceived":320,"codecImplementationName":"unknown","transpor'
    221 'tId":"Channel-audio-1","mediaType":"video","googInterframeDelayMax":1444,"g'
    222 'oogCodecName":"VP8","googFrameRateReceived":23,"framesDecoded":143,"googNac'
    223 'ksSent":0,"googFirsSent":0,"bytesReceived":147248,"googCurrentDelayMs":69,"'
    224 'googMinPlayoutDelayMs":0,"googFrameRateDecoded":22,"googJitterBufferMs":80,'
    225 '"googPlisSent":0,"fpsGraphicsInput":15.432764893113935,"fpsGraphicsOutput":'
    226 '15.432764893113935,"googFrameSpacing":505}},{"ssrc":{"googContentType":"rea'
    227 'ltime","googCaptureStartNtpTimeMs":0,"googTargetDelayMs":92,"packetsLost":0'
    228 ',"googDecodeMs":4,"googFrameHeightReceived":180,"googFrameRateOutput":21,"p'
    229 'acketsReceived":208,"ssrc":1009208770,"googRenderDelayMs":10,"googMaxDecode'
    230 'Ms":13,"googTrackId":"hangout757A0188_ephemeral.id.google.com%5E576980a8ae/'
    231 '1009208770","googFrameWidthReceived":320,"codecImplementationName":"unknown'
    232 '","transportId":"Channel-audio-1","mediaType":"video","googInterframeDelayM'
    233 'ax":810,"googCodecName":"VP8","googFrameRateReceived":23,"framesDecoded":15'
    234 '6,"googNacksSent":0,"googFirsSent":0,"bytesReceived":151801,"googCurrentDel'
    235 'ayMs":79,"googMinPlayoutDelayMs":0,"googFrameRateDecoded":21,"googJitterBuf'
    236 'ferMs":69,"googPlisSent":0,"fpsGraphicsInput":16.79306605413843,"fpsGraphic'
    237 'sOutput":16.684723692498824,"googFrameSpacing":502}},{"ssrc":{"googContentT'
    238 'ype":"realtime","googCaptureStartNtpTimeMs":0,"googTargetDelayMs":82,"packe'
    239 'tsLost":0,"googDecodeMs":4,"googFrameHeightReceived":180,"googFrameRateOutp'
    240 'ut":24,"packetsReceived":210,"ssrc":1750328988,"googRenderDelayMs":10,"goog'
    241 'MaxDecodeMs":15,"googTrackId":"hangout9227780C_ephemeral.id.google.com%5Eff'
    242 'ba3cb857/1750328988","googFrameWidthReceived":320,"codecImplementationName"'
    243 ':"unknown","transportId":"Channel-audio-1","mediaType":"video","googInterfr'
    244 'ameDelayMax":518,"googCodecName":"VP8","googFrameRateReceived":24,"framesDe'
    245 'coded":152,"googNacksSent":0,"googFirsSent":0,"bytesReceived":157397,"googC'
    246 'urrentDelayMs":72,"googMinPlayoutDelayMs":0,"googFrameRateDecoded":24,"goog'
    247 'JitterBufferMs":57,"googPlisSent":0,"fpsGraphicsInput":16.296136355665766,"'
    248 'fpsGraphicsOutput":16.296136355665766,"googFrameSpacing":746}},{"ssrc":{"go'
    249 'ogContentType":"realtime","googCaptureStartNtpTimeMs":0,"googTargetDelayMs"'
    250 ':102,"packetsLost":0,"googDecodeMs":4,"googFrameHeightReceived":180,"googFr'
    251 'ameRateOutput":24,"packetsReceived":220,"ssrc":2749867232,"googRenderDelayM'
    252 's":10,"googMaxDecodeMs":12,"googTrackId":"hangoutF9EAE779_ephemeral.id.goog'
    253 'le.com%5E42ce92f210/2749867232","googFrameWidthReceived":320,"codecImplemen'
    254 'tationName":"unknown","transportId":"Channel-audio-1","mediaType":"video","'
    255 'googInterframeDelayMax":583,"googCodecName":"VP8","googFrameRateReceived":2'
    256 '4,"framesDecoded":171,"googNacksSent":0,"googFirsSent":0,"bytesReceived":16'
    257 '3793,"googCurrentDelayMs":75,"googMinPlayoutDelayMs":0,"googFrameRateDecode'
    258 'd":24,"googJitterBufferMs":80,"googPlisSent":0,"fpsGraphicsInput":18.197388'
    259 '58914156,"fpsGraphicsOutput":18.19738858914156,"googFrameSpacing":502}},{"s'
    260 'src":{"googContentType":"realtime","googCaptureStartNtpTimeMs":0,"googTarge'
    261 'tDelayMs":87,"packetsLost":0,"googDecodeMs":5,"googFrameHeightReceived":180'
    262 ',"googFrameRateOutput":24,"packetsReceived":220,"ssrc":3276788334,"googRend'
    263 'erDelayMs":10,"googMaxDecodeMs":13,"googTrackId":"hangout83754FD7_ephemeral'
    264 '.id.google.com%5E2f542d3bca/3276788334","googFrameWidthReceived":320,"codec'
    265 'ImplementationName":"unknown","transportId":"Channel-audio-1","mediaType":"'
    266 'video","googInterframeDelayMax":648,"googCodecName":"VP8","googFrameRateRec'
    267 'eived":25,"framesDecoded":167,"googNacksSent":0,"googFirsSent":0,"bytesRece'
    268 'ived":159314,"googCurrentDelayMs":72,"googMinPlayoutDelayMs":0,"googFrameRa'
    269 'teDecoded":24,"googJitterBufferMs":64,"googPlisSent":0,"fpsGraphicsInput":1'
    270 '7.872616766543615,"fpsGraphicsOutput":17.76429787704941,"googFrameSpacing":'
    271 '502}},{"ssrc":{"audioInputLevel":0,"packetsLost":0,"googResidualEchoLikelih'
    272 'ood":0,"googRtt":24,"googResidualEchoLikelihoodRecentMax":0,"googEchoCancel'
    273 'lationReturnLossEnhancement":-100,"totalSamplesDuration":0,"totalAudioEnerg'
    274 'y":0,"transportId":"Channel-audio-1","mediaType":"audio","aecDivergentFilte'
    275 'rFraction":0,"googEchoCancellationReturnLoss":-100,"googCodecName":"opus","'
    276 'googEchoCancellationEchoDelayMedian":388,"googEchoCancellationQualityMin":0'
    277 ',"googTrackId":"4224ce1c-0c2f-4bb4-9d91-3798ca549328","ssrc":141808114,"goo'
    278 'gJitterReceived":3,"googTypingNoiseState":"false","packetsSent":63,"bytesSe'
    279 'nt":2709,"googEchoCancellationEchoDelayStdDev":0}},{"ssrc":{"googContentTyp'
    280 'e":"realtime","googFrameWidthSent":1280,"packetsLost":45,"googRtt":23,"goog'
    281 'EncodeUsagePercent":82,"googCpuLimitedResolution":"false","googNacksReceive'
    282 'd":0,"googBandwidthLimitedResolution":"false","googPlisReceived":0,"googAvg'
    283 'EncodeMs":17,"googTrackId":"99a2ae0e-9cfa-4a7d-83a6-8ea3d5cc2c2e","googFram'
    284 'eRateInput":24,"framesEncoded":657,"codecImplementationName":"SimulcastEnco'
    285 'derAdapter (unknown, unknown, unknown)","transportId":"Channel-audio-1","me'
    286 'diaType":"video","googFrameHeightSent":720,"googFrameRateSent":24,"googCode'
    287 'cName":"VP8","googAdaptationChanges":0,"ssrc":3865366536,"googFirsReceived"'
    288 ':0,"packetsSent":1869,"bytesSent":1796767,"googAdaptationReason":0}}]')
    289 
    290