Skip to content

Commit de20988

Browse files
sirknightjdependabot[bot]niyatim23disa6302
authored
Release 2.2.1 (#293)
* Outside of browser environment * Remove Buffer * Remove unnecessary import * Increase max package size * Remove _ * Add options allowing for fine-grained control of sending and receiving certain ICE candidates * Add description * Add presets * Fix wrong method name * Remove debugging artifacts * Remove extra newlines * Extract to common method * sample: Add manual JoinStorageSession button * sample: Adjust labels * master role * sample: move the connected check to after the SDP answer is sent * Add correlationId to sdp answer for joinStorageSession * 100% code coverage in the unit tests * Increase package size * Remove testing artifact * Update README for correlationId * Fix boolean flag * Adjust css * Disable datachannel for WebRTC ingestion and remove remote-view in ingestion mode * Adjust stop button color * reset storage client on next run * reset storage client on next run * Adjust comment for correlationId * Bump @babel/traverse from 7.21.4 to 7.23.2 Bumps [@babel/traverse](https://github.com/babel/babel/tree/HEAD/packages/babel-traverse) from 7.21.4 to 7.23.2. - [Release notes](https://github.com/babel/babel/releases) - [Changelog](https://github.com/babel/babel/blob/main/CHANGELOG.md) - [Commits](https://github.com/babel/babel/commits/v7.23.2/packages/babel-traverse) --- updated-dependencies: - dependency-name: "@babel/traverse" dependency-type: indirect ... Signed-off-by: dependabot[bot] <[email protected]> * Bump react-devtools-core from 4.27.6 to 4.28.4 Bumps [react-devtools-core](https://github.com/facebook/react/tree/HEAD/packages/react-devtools-core) from 4.27.6 to 4.28.4. - [Release notes](https://github.com/facebook/react/releases) - [Changelog](https://github.com/facebook/react/blob/main/CHANGELOG.md) - [Commits](https://github.com/facebook/react/commits/HEAD/packages/react-devtools-core) --- updated-dependencies: - dependency-name: react-devtools-core dependency-type: indirect ... Signed-off-by: dependabot[bot] <[email protected]> * Bump version * Bump package lock * data channel benchmarking message * additional logs * granularity in time-to-first-frame * master and viewer metrics timeline chart * signaling metrics viewer + master breakdown * color coded, dynamic height adjustment, dynamic dataTable row addition * connectAsViewer, enable non-json messages, enable viewing them in message box * set timelineChartTestLength to 20 * cleanup 1 * pr cleanup as per comments * adding a comment * readme update * rename timestamp * update the readme * rename timestamps * decouple from dqp * rename * DQP enhacement and bug fixes * Rebase to include profiling chart * Use metrics object data * Bump follow-redirects from 1.15.2 to 1.15.5 Bumps [follow-redirects](https://github.com/follow-redirects/follow-redirects) from 1.15.2 to 1.15.5. - [Release notes](https://github.com/follow-redirects/follow-redirects/releases) - [Commits](follow-redirects/follow-redirects@v1.15.2...v1.15.5) --- updated-dependencies: - dependency-name: follow-redirects dependency-type: indirect ... Signed-off-by: dependabot[bot] <[email protected]> * Bump SDK version * Bump ip from 1.1.8 to 1.1.9 Bumps [ip](https://github.com/indutny/node-ip) from 1.1.8 to 1.1.9. - [Commits](indutny/node-ip@v1.1.8...v1.1.9) --- updated-dependencies: - dependency-name: ip dependency-type: indirect ... Signed-off-by: dependabot[bot] <[email protected]> * Bump package lock --------- Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Niyati Maheshwari <[email protected]> Co-authored-by: Divya Sampath Kumar <[email protected]>
1 parent fb1d4a3 commit de20988

File tree

7 files changed

+634
-53
lines changed

7 files changed

+634
-53
lines changed

README.md

+34
Original file line numberDiff line numberDiff line change
@@ -369,6 +369,40 @@ An enum with the following values:
369369
* `MASTER`
370370
* `VIEWER`
371371

372+
## Metrics
373+
374+
The DQP metrics can be enabled in the sample application by checking a box before starting the viewer on the JS side. On the master, there is a flag in the sample application which `(pSampleConfiguration->enableSendingMetricsToViewerViaDc)` can be set to TRUE to send metrics from the master to the [JS](https://awslabs.github.io/amazon-kinesis-video-streams-webrtc-sdk-js/examples/index.html) viewer. This helps get a detailed breakdown of time-to-first-frame and all the processes and API calls on master and the viewer both. This is intended to be used with the KVS WebRTC C SDK running as the master and the JS SDK as the viewer. The master sends peer, ice-agent, signaling and data-channel metrics to the viewer which are plotted ~ 20 seconds after the viewer is started. Since the timeline plot is intended to understand the time-to-first-frame, the sample web page needs to be refreshed and the master needs to be restarted if a new / updated plot is needed. While using the SDK in this mode, it is expected that all datachannel messages are JSON messages. This feature is only meant to be used for a single viewer at a time.
375+
376+
| Category | Metric | Calculation | Description |
377+
|--------------------|--------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
378+
| viewer-wait | viewer-waiting-for-master | Calculated as the time between the signaling client going to `open` state and the time to start the master | Time duration the viewer was waiting for the master to start (time to start the SDK after the viewer signaling channel was connected) |
379+
| viewer-signaling | signaling-viewer | Calculated as the time between creation of the `KinesisVideoClient` and the signaling client going to `open` state | Time taken to establish a signaling connection on the viewer-side |
380+
| viewer-signaling | setup-media-player-viewer | Calculated as the time taken for `getUserMedia` call | Time taken to setup a media player on the viewer-side by seeking permissions for mic / camera (if needed), fetch tracks from the same and add them to the peer connection peer. |
381+
| viewer-signaling | signaling-viewer-describe-channel | Calculated as the time taken for the `describeSignalingChannel` call | Time taken for the API call to describeSignalingChannel on the viewer |
382+
| viewer-signaling | signaling-viewer-describe-media-storage-config | Calculated as the time taken for the `describeMediaStorageConfiguration` call | Time taken for the API call to describeSignalingChannel on the viewer |
383+
| viewer-signaling | signaling-viewer-get-signaling-channel-endpoint | Calculated as the time taken for the `getSignalingChannelEndpoint` | Time taken for the API call to getSignalingChannelEndpoint on the viewer |
384+
| viewer-signaling | signaling-viewer-get-ice-server-config | Calculated as the time taken for the `getIceServerConfig` | Time taken for the API call to getIceServerConfig on the viewer |
385+
| viewer-signaling | signaling-connect-as-viewer | Calculated as the time taken between the signalingClient creation with all the information from the previous steps and it reaching the `open` state | Time taken to open the websocket via connectAsViewer |
386+
| viewer-sdp-exchange | sdp-exchange-viewer | Calculated as the time between setting the local description and the reception of an answer from the master | Time taken to send an offer and receive a response |
387+
| viewer-ice | ice-gathering-viewer | Calculated as the time between `viewer.peerConnection.iceGatheringState` going from `gathering` to `complete` | Time taken to gather all ice candidates on the viewer |
388+
| viewer-peer-connection | pc-establishment-viewer | Calculated as the time between `viewer.peerConnection.connectionState` going from `new` to `connected` | Time taken to establish the peer connection on the viewer |
389+
| viewer-datachannel | datachannel-viewer | Calculated as the time between `timestamp1` (time at which the viewer sends a message) and `timestamp3` (time at which the viewer receives a response from the master) | Time taken to send a message to the master and receive a response back
390+
| viewer-ttff | ttff-after-pc-viewer | Calculated as time between `viewer.peerConnection.connectionState` in `connected` state and `viewer.remoteView.addEventListener` goes to `loadeddata` | Time to first frame after the viewer\'s peer connection has been established |
391+
| master-wait | master-waiting-for-viewer | Calculated as the time between signaling state going to connected and the button to start the viewer | Time duration the master was waiting for the viewer to start (time to click the button after the master signaling channel was connected) |
392+
| master-signaling | signaling-master | Calculated as the time for the entire signaling process on the master | Time taken to establish a signaling connection on the master-side |
393+
| master-signaling | signaling-master-describe-channel | Calculated as the time taken for the `describeSignalingChannel` call | Time taken for the API call to desribeSignalingChannel on the master |
394+
| master-signaling | signaling-master-get-signaling-channel-endpoint | Calculated as the time taken for the `getSignalingChannelEndpoint` | Time taken for the API call to getSignalingChannelEndpoint on the master |
395+
| master-signaling | signaling-master-get-ice-server-config | Calculated as the time taken for the `getIceServerConfig` | Time taken for the API call to getIceServerConfig on the master |
396+
| master-signaling | signaling-master-get-token | Calculated as the time taken for `getCredentialsFn` for authentication | Time taken for the getToken call on the master |
397+
| master-signaling | signaling-master-create-channel | Calculated as the time taken for the `createSignalingChannel` | Time taken createChannel API call on the master |
398+
| master-signaling | signaling-master-connect | Calculated as the time taken for the `connectAsMaster` | Time taken for the signaling connect on the master |
399+
| master-sdp-exchange | sdp-exchange-master | Calculated as the time between the master receiving an offer, processing it and sending an answer to the viewer | Time taken to respond to an offer from the viewer with an answer |
400+
| master-ice | ice-gathering-master | Calculated as the time from starting the gathering to the time its scheduling was stopped | Time taken to gather all ice candidates on the master |
401+
| master-peer-connection | pc-establishment-master | Calculated as the time taken to go to `RTC_PEER_CONNECTION_STATE_CONNECTED` | Time taken to establish the peer connection on the master |
402+
| master-datachannel | datachannel-master | Calculated as the time between `timestamp2` (time at which the master sends a message) and `timestamp4` (time at which the master receives a response from the master) | Time taken to send a message to the viewer and receive a response back |
403+
| master-ttff | ttff-after-pc-master | Calculated as the time between `metrics.master.peerConnection.endTime` and `viewer.remoteView.addEventListener` reaches `loadeddata` | Time to first frame after the master's peer connection has been established |
404+
| ttff | ttff | Calculated as the time taken between the viewer button is clicked and `viewer.remoteView.addEventListener` reaches `loadeddata` | Time to first frame since the viewer button was clicked |
405+
372406
## Compatibility
373407

374408
The SDK is supported in the following browsers / environments:

examples/app.css

+1
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@
66
width: 100%;
77
}
88

9+
910
#logs-header {
1011
margin-top: 20px;
1112
}

examples/app.js

+11-3
Original file line numberDiff line numberDiff line change
@@ -89,6 +89,7 @@ function getFormValues() {
8989
secretAccessKey: $('#secretAccessKey').val(),
9090
sessionToken: $('#sessionToken').val() || null,
9191
enableDQPmetrics: $('#enableDQPmetrics').is(':checked'),
92+
enableProfileTimeline: $('#enableProfileTimeline').is(':checked'),
9293
sendHostCandidates: $('#send-host').is(':checked'),
9394
acceptHostCandidates: $('#accept-host').is(':checked'),
9495
sendRelayCandidates: $('#send-relay').is(':checked'),
@@ -137,6 +138,10 @@ function onStop() {
137138
$('#webrtc-live-stats').addClass('d-none');
138139
}
139140

141+
if (getFormValues().enableProfileTimeline) {
142+
$('#timeline-profiling').addClass('d-none');
143+
}
144+
140145
$('#form').removeClass('d-none');
141146
$('#join-storage-session-button').addClass('d-none');
142147
ROLE = null;
@@ -216,15 +221,17 @@ $('#viewer-button').click(async () => {
216221
$('#webrtc-live-stats').removeClass('d-none');
217222
}
218223

224+
if (formValues.enableProfileTimeline) {
225+
$('#timeline-profiling').removeClass('d-none');
226+
}
227+
219228
$(remoteMessage).empty();
220229
localMessage.value = '';
221230
toggleDataChannelElements();
222231

223232
printFormValues(formValues);
224233

225-
startViewer(localView, remoteView, formValues, onStatsReport, event => {
226-
remoteMessage.append(`${event.data}\n`);
227-
});
234+
startViewer(localView, remoteView, formValues, onStatsReport, remoteMessage);
228235
});
229236

230237
$('#stop-viewer-button').click(onStop);
@@ -428,6 +435,7 @@ const fields = [
428435
{ field: 'forceTURN', type: 'radio', name: 'natTraversal' },
429436
{ field: 'natTraversalDisabled', type: 'radio', name: 'natTraversal' },
430437
{ field: 'enableDQPmetrics', type: 'checkbox' },
438+
{ field: 'enableProfileTimeline', type: 'checkbox' },
431439
{ field: 'send-host', type: 'checkbox' },
432440
{ field: 'accept-host', type: 'checkbox' },
433441
{ field: 'send-relay', type: 'checkbox' },

examples/index.html

+37-13
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,7 @@
1313
<script src="https://unpkg.com/@ungap/url-search-params"></script>
1414
<script src="https://webrtc.github.io/adapter/adapter-latest.js"></script>
1515
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/chart.umd.min.js"></script>
16+
<script src="https://www.gstatic.com/charts/loader.js"></script>
1617
<link rel="icon" type="image/png" href="favicon.ico">
1718
</head>
1819
<body>
@@ -177,6 +178,18 @@ <h4>Amazon KVS WebRTC DQP</h4>
177178
</div>
178179
</div>
179180

181+
<h4>Amazon KVS WebRTC Profiling Timeline chart</h4>
182+
<div class="form-group">
183+
<div class="form-check form-check-inline">
184+
<input class="form-check-input" type="checkbox" id="enableProfileTimeline" value="enableProfileTimeline">
185+
<label for="enableProfileTimeline" class="form-check-label">Enable C SDK master and JS viewer profile timeline<small>(Master + Viewer)</small></label>
186+
<span data-delay="{ &quot;hide&quot;: 1500 }" data-position="auto" tabindex="0" class="text-info ml-1" data-toggle="tooltip" data-html="true" title="
187+
<p>Enables the test and metrics for the Amazon KVS WebRTC by sending the master-side metrics to the viewer via datachannel and display a timeline chart.</p>
188+
<a href=&quot;https://github.com/awslabs/amazon-kinesis-video-streams-webrtc-sdk-js/tree/develop?tab=readme-ov-file#metrics&quot;>Additional information</a>
189+
"><sup>&#9432;</sup></span>
190+
</div>
191+
</div>
192+
180193
<details><summary class="h4">Advanced</summary>
181194
<p><small>Filter settings for which ICE candidates and sent to and received from the peer.</small></p>
182195
<div class="container">
@@ -338,23 +351,34 @@ <h5>From Master</h5>
338351
</div>
339352
</div>
340353

341-
<div id="dqpmetrics" class="d-none">
342-
<h3 id="dqpmetrics-header">DQP Test Metrics (from Master)</h3>
343-
<div class="row">
344-
<div class="col">
345-
<div class="card bg-light mb-3">
346-
<div id="dqp-test"></div>
354+
<div>
355+
<div id="dqpmetrics" class="d-none">
356+
<h3 id="dqpmetrics-header">DQP Test Metrics (from Master)</h3>
357+
<div class="row">
358+
<div class="col">
359+
<div class="card bg-light mb-3">
360+
<div id="dqp-test"></div>
361+
</div>
347362
</div>
348-
</div>
349-
<div class="col">
350-
<div class="card bg-light mb-3">
351-
<canvas id="metricsChart" style="width:100%"; height="400px"></canvas>
363+
<div class="col">
364+
<div class="card bg-light mb-3">
365+
<canvas id="metricsChart" style="width:100%"; height="400px"></canvas>
366+
</div>
352367
</div>
353368
</div>
369+
<h3 id="live-stats-header">Live Stats (from Master)</h3>
370+
<div class="card bg-light mb-3">
371+
<div id="webrtc-live-stats"></div>
372+
</div>
354373
</div>
355-
<h3 id="live-stats-header">Live Stats (from Master)</h3>
356-
<div class="card bg-light mb-3">
357-
<div id="webrtc-live-stats"></div>
374+
<div id="timeline-profiling" class="d-none" style="padding-top:20px;">
375+
<div class="row">
376+
<div class="col">
377+
<h4 id="timeline-profiling-header"></h4>
378+
<div id="timeline-chart" style="width:100%;height:0px">
379+
</div>
380+
</div>
381+
</div>
358382
</div>
359383
</div>
360384

0 commit comments

Comments
 (0)