mirror of
https://github.com/status-im/nim-websock.git
synced 2025-01-12 18:44:29 +00:00
389 lines
17 KiB
HTML
389 lines
17 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<style lang="css">
|
|
body {
|
|
background-color: #F4F4F4;
|
|
color: #333;
|
|
font-family: Segoe UI,Tahoma,Arial,Verdana,sans-serif;
|
|
}
|
|
|
|
p#intro {
|
|
font-family: Cambria,serif;
|
|
font-size: 1.1em;
|
|
color: #444;
|
|
}
|
|
|
|
p#intro a {
|
|
color: #444;
|
|
}
|
|
|
|
p#intro a:visited {
|
|
color: #444;
|
|
}
|
|
|
|
.block {
|
|
background-color: #e0e0e0;
|
|
padding: 16px;
|
|
margin: 20px;
|
|
}
|
|
|
|
p.case_text_block {
|
|
border-radius: 10px;
|
|
border: 1px solid #aaa;
|
|
padding: 16px;
|
|
margin: 4px 20px;
|
|
color: #444;
|
|
}
|
|
|
|
p.case_desc {
|
|
}
|
|
|
|
p.case_expect {
|
|
}
|
|
|
|
p.case_outcome {
|
|
}
|
|
|
|
p.case_closing_beh {
|
|
}
|
|
|
|
pre.http_dump {
|
|
font-family: Consolas, "Courier New", monospace;
|
|
font-size: 0.8em;
|
|
color: #333;
|
|
border-radius: 10px;
|
|
border: 1px solid #aaa;
|
|
padding: 16px;
|
|
margin: 4px 20px;
|
|
}
|
|
|
|
span.case_pickle {
|
|
font-family: Consolas, "Courier New", monospace;
|
|
font-size: 0.7em;
|
|
color: #000;
|
|
}
|
|
|
|
p#case_result,p#close_result {
|
|
border-radius: 10px;
|
|
background-color: #e8e2d1;
|
|
padding: 20px;
|
|
margin: 20px;
|
|
}
|
|
|
|
h1 {
|
|
margin-left: 60px;
|
|
}
|
|
|
|
h2 {
|
|
margin-left: 30px;
|
|
}
|
|
|
|
h3 {
|
|
margin-left: 50px;
|
|
}
|
|
|
|
a.up {
|
|
float: right;
|
|
border-radius: 16px;
|
|
margin-top: 16px;
|
|
margin-bottom: 10px;
|
|
|
|
margin-right: 30px;
|
|
padding-left: 10px;
|
|
padding-right: 10px;
|
|
padding-bottom: 2px;
|
|
padding-top: 2px;
|
|
background-color: #666;
|
|
color: #fff;
|
|
text-decoration: none;
|
|
font-size: 0.8em;
|
|
}
|
|
|
|
a.up:visited {
|
|
}
|
|
|
|
a.up:hover {
|
|
background-color: #028ec9;
|
|
}
|
|
</style>
|
|
<style lang="css">
|
|
p.case {
|
|
color: #fff;
|
|
border-radius: 10px;
|
|
padding: 20px;
|
|
margin: 12px 20px;
|
|
font-size: 1.2em;
|
|
}
|
|
|
|
p.case_ok {
|
|
background-color: #0a0;
|
|
}
|
|
|
|
p.case_non_strict, p.case_no_close {
|
|
background-color: #9a0;
|
|
}
|
|
|
|
p.case_info {
|
|
background-color: #4095BF;
|
|
}
|
|
|
|
p.case_failed {
|
|
background-color: #900;
|
|
}
|
|
|
|
table {
|
|
border-collapse: collapse;
|
|
border-spacing: 0px;
|
|
margin-left: 80px;
|
|
margin-bottom: 12px;
|
|
margin-top: 0px;
|
|
}
|
|
|
|
td
|
|
{
|
|
margin: 0;
|
|
font-size: 0.8em;
|
|
border: 1px #fff solid;
|
|
padding-top: 6px;
|
|
padding-bottom: 6px;
|
|
padding-left: 16px;
|
|
padding-right: 16px;
|
|
text-align: right;
|
|
}
|
|
|
|
td.right {
|
|
text-align: right;
|
|
}
|
|
|
|
td.left {
|
|
text-align: left;
|
|
}
|
|
|
|
tr.stats_header {
|
|
color: #eee;
|
|
background-color: #000;
|
|
}
|
|
|
|
tr.stats_row {
|
|
color: #000;
|
|
background-color: #fc3;
|
|
}
|
|
|
|
tr.stats_total {
|
|
color: #fff;
|
|
background-color: #888;
|
|
}
|
|
|
|
div#wirelog {
|
|
margin-top: 20px;
|
|
margin-bottom: 80px;
|
|
}
|
|
|
|
pre.wirelog_rx_octets {color: #aaa; margin: 0; background-color: #060; padding: 2px;}
|
|
pre.wirelog_tx_octets {color: #aaa; margin: 0; background-color: #600; padding: 2px;}
|
|
pre.wirelog_tx_octets_sync {color: #aaa; margin: 0; background-color: #606; padding: 2px;}
|
|
|
|
pre.wirelog_rx_frame {color: #fff; margin: 0; background-color: #0a0; padding: 2px;}
|
|
pre.wirelog_tx_frame {color: #fff; margin: 0; background-color: #a00; padding: 2px;}
|
|
pre.wirelog_tx_frame_sync {color: #fff; margin: 0; background-color: #a0a; padding: 2px;}
|
|
|
|
pre.wirelog_delay {color: #fff; margin: 0; background-color: #000; padding: 2px;}
|
|
pre.wirelog_kill_after {color: #fff; margin: 0; background-color: #000; padding: 2px;}
|
|
|
|
pre.wirelog_tcp_closed_by_me {color: #fff; margin: 0; background-color: #008; padding: 2px;}
|
|
pre.wirelog_tcp_closed_by_peer {color: #fff; margin: 0; background-color: #000; padding: 2px;}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<a name="top"></a>
|
|
<br/>
|
|
<center><a href="http://autobahn.ws/testsuite" title="Autobahn WebSocket Testsuite"><img src="http://autobahn.ws/static/img/ws_protocol_test_report.png" border="0" width="820" height="46" alt="Autobahn WebSocket Testsuite Report"></img></a></center>
|
|
<center><a href="http://autobahn.ws" title="Autobahn WebSocket"> <img src="http://autobahn.ws/static/img/ws_protocol_test_report_autobahn.png" border="0" width="300" height="68" alt="Autobahn WebSocket"> </img></a></center>
|
|
<br/>
|
|
<p class="case case_ok">websock-secure-client - <span style="font-size: 1.3em;"><b>Case 12.4.3</b></span> : Pass - <span style="font-size: 0.9em;"><b>489</b> ms @ 2024-01-23T06:05:25.077Z</a></p>
|
|
<p class="case_text_block case_desc"><b>Case Description</b><br/><br/>Send 1000 compressed messages each of payload size 256, auto-fragment to 0 octets. Use default permessage-deflate offer.</p>
|
|
<p class="case_text_block case_expect"><b>Case Expectation</b><br/><br/>Receive echo'ed messages (with payload as sent). Timeout case after 120 secs.</p>
|
|
|
|
<p class="case_text_block case_outcome">
|
|
<b>Case Outcome</b><br/><br/>Ok, received all echo'ed messages in time.<br/><br/>
|
|
<i>Expected:</i><br/><span class="case_pickle">{}</span><br/><br/>
|
|
<i>Observed:</i><br><span class="case_pickle">[]</span>
|
|
</p>
|
|
<p class="case_text_block case_closing_beh"><b>Case Closing Behavior</b><br/><br/>Connection was properly closed (OK)</p>
|
|
<br/><hr/>
|
|
<h2>Opening Handshake</h2>
|
|
<pre class="http_dump">GET /runCase?case=358&agent=websock-secure-client HTTP/1.1
|
|
Sec-Websocket-Extensions: permessage-deflate; client_max_window_bits=15
|
|
Upgrade: websocket
|
|
Host: 127.0.0.1:9002
|
|
Connection: Upgrade
|
|
Sec-Websocket-Version: 13
|
|
Sec-Websocket-Key: 9vttbUyLE3AuxvONsml0GA==
|
|
Cache-Control: no-cache</pre>
|
|
<pre class="http_dump">HTTP/1.1 101 Switching Protocols
|
|
Server: AutobahnTestSuite/0.8.2-0.10.9
|
|
X-Powered-By: AutobahnPython/0.10.9
|
|
Upgrade: WebSocket
|
|
Connection: Upgrade
|
|
Sec-WebSocket-Accept: 7F1Pyyy8SnrSGeRLEmmhzJGb2IQ=
|
|
Sec-WebSocket-Extensions: permessage-deflate</pre>
|
|
<br/><hr/>
|
|
<h2>Closing Behavior</h2>
|
|
<table>
|
|
<tr class="stats_header"><td>Key</td><td class="left">Value</td><td class="left">Description</td></tr>
|
|
<tr class="stats_row"><td>isServer</td><td class="left">True</td><td class="left">True, iff I (the fuzzer) am a server, and the peer is a client.</td></tr>
|
|
<tr class="stats_row"><td>closedByMe</td><td class="left">True</td><td class="left">True, iff I have initiated closing handshake (that is, did send close first).</td></tr>
|
|
<tr class="stats_row"><td>failedByMe</td><td class="left">False</td><td class="left">True, iff I have failed the WS connection (i.e. due to protocol error). Failing can be either by initiating closing handshake or brutal drop TCP.</td></tr>
|
|
<tr class="stats_row"><td>droppedByMe</td><td class="left">True</td><td class="left">True, iff I dropped the TCP connection.</td></tr>
|
|
<tr class="stats_row"><td>wasClean</td><td class="left">True</td><td class="left">True, iff full WebSocket closing handshake was performed (close frame sent and received) _and_ the server dropped the TCP (which is its responsibility).</td></tr>
|
|
<tr class="stats_row"><td>wasNotCleanReason</td><td class="left">None</td><td class="left">When wasClean == False, the reason what happened.</td></tr>
|
|
<tr class="stats_row"><td>wasServerConnectionDropTimeout</td><td class="left">False</td><td class="left">When we are a client, and we expected the server to drop the TCP, but that didn't happen in time, this gets True.</td></tr>
|
|
<tr class="stats_row"><td>wasOpenHandshakeTimeout</td><td class="left">False</td><td class="left">When performing the opening handshake, but the peer did not finish in time, this gets True.</td></tr>
|
|
<tr class="stats_row"><td>wasCloseHandshakeTimeout</td><td class="left">False</td><td class="left">When we initiated a closing handshake, but the peer did not respond in time, this gets True.</td></tr>
|
|
<tr class="stats_row"><td>localCloseCode</td><td class="left">1000</td><td class="left">The close code I sent in close frame (if any).</td></tr>
|
|
<tr class="stats_row"><td>localCloseReason</td><td class="left">None</td><td class="left">The close reason I sent in close frame (if any).</td></tr>
|
|
<tr class="stats_row"><td>remoteCloseCode</td><td class="left">1000</td><td class="left">The close code the peer sent me in close frame (if any).</td></tr>
|
|
<tr class="stats_row"><td>remoteCloseReason</td><td class="left">None</td><td class="left">The close reason the peer sent me in close frame (if any).</td></tr>
|
|
</table> <br/><hr/>
|
|
<h2>Wire Statistics</h2>
|
|
<h3>Octets Received by Chop Size</h3>
|
|
<table>
|
|
<tr class="stats_header"><td>Chop Size</td><td>Count</td><td>Octets</td></tr>
|
|
<tr class="stats_row"><td>8</td><td>1</td><td>8</td></tr>
|
|
<tr class="stats_row"><td>264</td><td>994</td><td>262416</td></tr>
|
|
<tr class="stats_row"><td>265</td><td>1</td><td>265</td></tr>
|
|
<tr class="stats_row"><td>267</td><td>1</td><td>267</td></tr>
|
|
<tr class="stats_row"><td>268</td><td>1</td><td>268</td></tr>
|
|
<tr class="stats_row"><td>270</td><td>2</td><td>540</td></tr>
|
|
<tr class="stats_row"><td>271</td><td>1</td><td>271</td></tr>
|
|
<tr class="stats_row"><td>295</td><td>1</td><td>295</td></tr>
|
|
<tr class="stats_total"><td>Total</td><td>1002</td><td>264330</td></tr>
|
|
</table>
|
|
<h3>Octets Transmitted by Chop Size</h3>
|
|
<table>
|
|
<tr class="stats_header"><td>Chop Size</td><td>Count</td><td>Octets</td></tr>
|
|
<tr class="stats_row"><td>4</td><td>1</td><td>4</td></tr>
|
|
<tr class="stats_row"><td>7</td><td>18</td><td>126</td></tr>
|
|
<tr class="stats_row"><td>8</td><td>20</td><td>160</td></tr>
|
|
<tr class="stats_row"><td>10</td><td>46</td><td>460</td></tr>
|
|
<tr class="stats_row"><td>11</td><td>39</td><td>429</td></tr>
|
|
<tr class="stats_row"><td>12</td><td>14</td><td>168</td></tr>
|
|
<tr class="stats_row"><td>13</td><td>87</td><td>1131</td></tr>
|
|
<tr class="stats_row"><td>14</td><td>186</td><td>2604</td></tr>
|
|
<tr class="stats_row"><td>15</td><td>89</td><td>1335</td></tr>
|
|
<tr class="stats_row"><td>16</td><td>72</td><td>1152</td></tr>
|
|
<tr class="stats_row"><td>17</td><td>53</td><td>901</td></tr>
|
|
<tr class="stats_row"><td>18</td><td>32</td><td>576</td></tr>
|
|
<tr class="stats_row"><td>19</td><td>32</td><td>608</td></tr>
|
|
<tr class="stats_row"><td>20</td><td>33</td><td>660</td></tr>
|
|
<tr class="stats_row"><td>21</td><td>39</td><td>819</td></tr>
|
|
<tr class="stats_row"><td>22</td><td>27</td><td>594</td></tr>
|
|
<tr class="stats_row"><td>23</td><td>16</td><td>368</td></tr>
|
|
<tr class="stats_row"><td>24</td><td>13</td><td>312</td></tr>
|
|
<tr class="stats_row"><td>25</td><td>9</td><td>225</td></tr>
|
|
<tr class="stats_row"><td>26</td><td>12</td><td>312</td></tr>
|
|
<tr class="stats_row"><td>27</td><td>9</td><td>243</td></tr>
|
|
<tr class="stats_row"><td>28</td><td>5</td><td>140</td></tr>
|
|
<tr class="stats_row"><td>29</td><td>6</td><td>174</td></tr>
|
|
<tr class="stats_row"><td>30</td><td>8</td><td>240</td></tr>
|
|
<tr class="stats_row"><td>31</td><td>10</td><td>310</td></tr>
|
|
<tr class="stats_row"><td>32</td><td>6</td><td>192</td></tr>
|
|
<tr class="stats_row"><td>33</td><td>5</td><td>165</td></tr>
|
|
<tr class="stats_row"><td>34</td><td>4</td><td>136</td></tr>
|
|
<tr class="stats_row"><td>35</td><td>3</td><td>105</td></tr>
|
|
<tr class="stats_row"><td>36</td><td>3</td><td>108</td></tr>
|
|
<tr class="stats_row"><td>37</td><td>5</td><td>185</td></tr>
|
|
<tr class="stats_row"><td>38</td><td>3</td><td>114</td></tr>
|
|
<tr class="stats_row"><td>39</td><td>4</td><td>156</td></tr>
|
|
<tr class="stats_row"><td>40</td><td>1</td><td>40</td></tr>
|
|
<tr class="stats_row"><td>41</td><td>6</td><td>246</td></tr>
|
|
<tr class="stats_row"><td>42</td><td>5</td><td>210</td></tr>
|
|
<tr class="stats_row"><td>43</td><td>2</td><td>86</td></tr>
|
|
<tr class="stats_row"><td>44</td><td>3</td><td>132</td></tr>
|
|
<tr class="stats_row"><td>46</td><td>1</td><td>46</td></tr>
|
|
<tr class="stats_row"><td>47</td><td>3</td><td>141</td></tr>
|
|
<tr class="stats_row"><td>48</td><td>3</td><td>144</td></tr>
|
|
<tr class="stats_row"><td>50</td><td>2</td><td>100</td></tr>
|
|
<tr class="stats_row"><td>51</td><td>1</td><td>51</td></tr>
|
|
<tr class="stats_row"><td>52</td><td>2</td><td>104</td></tr>
|
|
<tr class="stats_row"><td>53</td><td>2</td><td>106</td></tr>
|
|
<tr class="stats_row"><td>54</td><td>1</td><td>54</td></tr>
|
|
<tr class="stats_row"><td>55</td><td>2</td><td>110</td></tr>
|
|
<tr class="stats_row"><td>56</td><td>3</td><td>168</td></tr>
|
|
<tr class="stats_row"><td>58</td><td>3</td><td>174</td></tr>
|
|
<tr class="stats_row"><td>59</td><td>3</td><td>177</td></tr>
|
|
<tr class="stats_row"><td>60</td><td>2</td><td>120</td></tr>
|
|
<tr class="stats_row"><td>61</td><td>1</td><td>61</td></tr>
|
|
<tr class="stats_row"><td>63</td><td>2</td><td>126</td></tr>
|
|
<tr class="stats_row"><td>65</td><td>2</td><td>130</td></tr>
|
|
<tr class="stats_row"><td>67</td><td>1</td><td>67</td></tr>
|
|
<tr class="stats_row"><td>68</td><td>4</td><td>272</td></tr>
|
|
<tr class="stats_row"><td>69</td><td>2</td><td>138</td></tr>
|
|
<tr class="stats_row"><td>71</td><td>3</td><td>213</td></tr>
|
|
<tr class="stats_row"><td>73</td><td>1</td><td>73</td></tr>
|
|
<tr class="stats_row"><td>77</td><td>1</td><td>77</td></tr>
|
|
<tr class="stats_row"><td>81</td><td>1</td><td>81</td></tr>
|
|
<tr class="stats_row"><td>82</td><td>2</td><td>164</td></tr>
|
|
<tr class="stats_row"><td>85</td><td>1</td><td>85</td></tr>
|
|
<tr class="stats_row"><td>87</td><td>1</td><td>87</td></tr>
|
|
<tr class="stats_row"><td>88</td><td>2</td><td>176</td></tr>
|
|
<tr class="stats_row"><td>89</td><td>1</td><td>89</td></tr>
|
|
<tr class="stats_row"><td>93</td><td>2</td><td>186</td></tr>
|
|
<tr class="stats_row"><td>94</td><td>1</td><td>94</td></tr>
|
|
<tr class="stats_row"><td>97</td><td>1</td><td>97</td></tr>
|
|
<tr class="stats_row"><td>99</td><td>1</td><td>99</td></tr>
|
|
<tr class="stats_row"><td>102</td><td>1</td><td>102</td></tr>
|
|
<tr class="stats_row"><td>104</td><td>1</td><td>104</td></tr>
|
|
<tr class="stats_row"><td>112</td><td>2</td><td>224</td></tr>
|
|
<tr class="stats_row"><td>113</td><td>1</td><td>113</td></tr>
|
|
<tr class="stats_row"><td>114</td><td>1</td><td>114</td></tr>
|
|
<tr class="stats_row"><td>115</td><td>1</td><td>115</td></tr>
|
|
<tr class="stats_row"><td>117</td><td>1</td><td>117</td></tr>
|
|
<tr class="stats_row"><td>122</td><td>2</td><td>244</td></tr>
|
|
<tr class="stats_row"><td>123</td><td>2</td><td>246</td></tr>
|
|
<tr class="stats_row"><td>124</td><td>1</td><td>124</td></tr>
|
|
<tr class="stats_row"><td>135</td><td>1</td><td>135</td></tr>
|
|
<tr class="stats_row"><td>139</td><td>1</td><td>139</td></tr>
|
|
<tr class="stats_row"><td>159</td><td>1</td><td>159</td></tr>
|
|
<tr class="stats_row"><td>190</td><td>1</td><td>190</td></tr>
|
|
<tr class="stats_row"><td>252</td><td>1</td><td>252</td></tr>
|
|
<tr class="stats_total"><td>Total</td><td>1002</td><td>22114</td></tr>
|
|
</table>
|
|
<h3>Frames Received by Opcode</h3>
|
|
<table>
|
|
<tr class="stats_header"><td>Opcode</td><td>Count</td></tr>
|
|
<tr class="stats_row"><td>1</td><td>1000</td></tr>
|
|
<tr class="stats_row"><td>8</td><td>1</td></tr>
|
|
<tr class="stats_total"><td>Total</td><td>1001</td></tr>
|
|
</table>
|
|
<h3>Frames Transmitted by Opcode</h3>
|
|
<table>
|
|
<tr class="stats_header"><td>Opcode</td><td>Count</td></tr>
|
|
<tr class="stats_row"><td>1</td><td>1000</td></tr>
|
|
<tr class="stats_row"><td>8</td><td>1</td></tr>
|
|
<tr class="stats_total"><td>Total</td><td>1001</td></tr>
|
|
</table>
|
|
<br/><hr/>
|
|
<h2>Wire Log</h2>
|
|
<div id="wirelog">
|
|
<pre class="wirelog_rx_octets">000 RX OCTETS: 474554202f72756e436173653f636173653d333538266167656e743d776562736f636b2d7365637572652d636c69656e7420</pre>
|
|
<pre class="wirelog_rx_octets"> 485454502f312e310d0a5365632d ...</pre>
|
|
<pre class="wirelog_tx_octets">001 TX OCTETS: 485454502f312e312031303120537769746368696e672050726f746f636f6c730d0a5365727665723a204175746f6261686e</pre>
|
|
<pre class="wirelog_tx_octets"> 5465737453756974652f302e382e ...</pre>
|
|
<pre class="wirelog_delay">002 WIRELOG DISABLED</pre>
|
|
<pre class="wirelog_kill_after">003 CLOSE CONNECTION AFTER 120.000000 sec</pre>
|
|
<pre class="wirelog_delay">004 WIRELOG ENABLED</pre>
|
|
<pre class="wirelog_tx_frame">005 TX FRAME : OPCODE=8, FIN=True, RSV=0, PAYLOAD-LEN=2, MASK=None, PAYLOAD-REPEAT-LEN=None, CHOPSIZE=None, SYNC=False</pre>
|
|
<pre class="wirelog_tx_frame"> 0x03e8</pre>
|
|
<pre class="wirelog_tx_octets">006 TX OCTETS: 880203e8</pre>
|
|
<pre class="wirelog_rx_octets">007 RX OCTETS: 8882542b618957c3</pre>
|
|
<pre class="wirelog_rx_frame">008 RX FRAME : OPCODE=8, FIN=True, RSV=0, PAYLOAD-LEN=2, MASKED=True, MASK=3534326236313839</pre>
|
|
<pre class="wirelog_rx_frame"> 0x03e8</pre>
|
|
<pre class="wirelog_tcp_closed_by_me">009 TCP DROPPED BY ME</pre>
|
|
</div>
|
|
<br/><hr/>
|
|
</body>
|
|
</html>
|