@openreplay/tracker 9.0.12 → 10.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (110) hide show
  1. package/.nvmrc +1 -0
  2. package/CHANGELOG.md +15 -0
  3. package/README.md +4 -0
  4. package/bun.lockb +0 -0
  5. package/cjs/app/index.js +14 -11
  6. package/cjs/app/logger.d.ts +1 -1
  7. package/cjs/app/messages.gen.d.ts +2 -1
  8. package/cjs/app/messages.gen.js +20 -5
  9. package/cjs/app/nodes.js +4 -3
  10. package/cjs/app/observer/observer.js +2 -1
  11. package/cjs/common/messages.gen.d.ts +17 -4
  12. package/cjs/index.js +1 -1
  13. package/cjs/modules/Network/beaconProxy.d.ts +16 -0
  14. package/cjs/modules/Network/beaconProxy.js +82 -0
  15. package/cjs/modules/Network/fetchProxy.d.ts +0 -1
  16. package/cjs/modules/Network/fetchProxy.js +3 -1
  17. package/cjs/modules/Network/index.js +5 -0
  18. package/cjs/modules/Network/networkMessage.d.ts +1 -1
  19. package/cjs/modules/Network/networkMessage.js +7 -4
  20. package/cjs/modules/Network/xhrProxy.d.ts +0 -9
  21. package/cjs/modules/Network/xhrProxy.js +0 -1
  22. package/cjs/modules/axiosSpy.js +1 -1
  23. package/cjs/modules/constructedStyleSheets.js +25 -21
  24. package/cjs/modules/featureFlags.js +0 -1
  25. package/cjs/modules/img.js +2 -2
  26. package/cjs/modules/network.js +5 -4
  27. package/cjs/utils.d.ts +16 -0
  28. package/cjs/utils.js +53 -1
  29. package/coverage/clover.xml +829 -1064
  30. package/coverage/coverage-final.json +17 -21
  31. package/coverage/lcov-report/index.html +40 -55
  32. package/coverage/lcov-report/main/app/guards.ts.html +1 -1
  33. package/coverage/lcov-report/main/app/index.html +23 -23
  34. package/coverage/lcov-report/main/app/index.ts.html +212 -29
  35. package/coverage/lcov-report/main/app/logger.ts.html +2 -2
  36. package/coverage/lcov-report/main/app/messages.gen.ts.html +144 -144
  37. package/coverage/lcov-report/main/app/nodes.ts.html +13 -7
  38. package/coverage/lcov-report/main/app/observer/iframe_observer.ts.html +1 -1
  39. package/coverage/lcov-report/main/app/observer/iframe_offsets.ts.html +1 -1
  40. package/coverage/lcov-report/main/app/observer/index.html +1 -1
  41. package/coverage/lcov-report/main/app/observer/shadow_root_observer.ts.html +1 -1
  42. package/coverage/lcov-report/main/app/observer/top_observer.ts.html +1 -1
  43. package/coverage/lcov-report/main/app/sanitizer.ts.html +12 -3
  44. package/coverage/lcov-report/main/app/session.ts.html +30 -9
  45. package/coverage/lcov-report/main/app/ticker.ts.html +1 -1
  46. package/coverage/lcov-report/main/index.html +21 -21
  47. package/coverage/lcov-report/main/index.ts.html +26 -26
  48. package/coverage/lcov-report/main/modules/Network/beaconProxy.ts.html +19 -19
  49. package/coverage/lcov-report/main/modules/Network/fetchProxy.ts.html +102 -96
  50. package/coverage/lcov-report/main/modules/Network/index.html +65 -65
  51. package/coverage/lcov-report/main/modules/Network/index.ts.html +33 -33
  52. package/coverage/lcov-report/main/modules/Network/networkMessage.ts.html +71 -71
  53. package/coverage/lcov-report/main/modules/Network/utils.ts.html +34 -34
  54. package/coverage/lcov-report/main/modules/Network/xhrProxy.ts.html +13 -13
  55. package/coverage/lcov-report/main/modules/attributeSender.ts.html +13 -4
  56. package/coverage/lcov-report/main/modules/axiosSpy.ts.html +1 -1
  57. package/coverage/lcov-report/main/modules/connection.ts.html +1 -1
  58. package/coverage/lcov-report/main/modules/console.ts.html +1 -1
  59. package/coverage/lcov-report/main/modules/constructedStyleSheets.ts.html +42 -30
  60. package/coverage/lcov-report/main/modules/cssrules.ts.html +1 -1
  61. package/coverage/lcov-report/main/modules/exception.ts.html +1 -1
  62. package/coverage/lcov-report/main/modules/featureFlags.ts.html +1 -1
  63. package/coverage/lcov-report/main/modules/focus.ts.html +1 -1
  64. package/coverage/lcov-report/main/modules/fonts.ts.html +1 -1
  65. package/coverage/lcov-report/main/modules/img.ts.html +23 -20
  66. package/coverage/lcov-report/main/modules/index.html +13 -13
  67. package/coverage/lcov-report/main/modules/input.ts.html +1 -1
  68. package/coverage/lcov-report/main/modules/mouse.ts.html +1 -1
  69. package/coverage/lcov-report/main/modules/network.ts.html +2 -2
  70. package/coverage/lcov-report/main/modules/performance.ts.html +1 -1
  71. package/coverage/lcov-report/main/modules/scroll.ts.html +1 -1
  72. package/coverage/lcov-report/main/modules/selection.ts.html +1 -1
  73. package/coverage/lcov-report/main/modules/tabs.ts.html +1 -1
  74. package/coverage/lcov-report/main/modules/timing.ts.html +42 -6
  75. package/coverage/lcov-report/main/modules/viewport.ts.html +1 -1
  76. package/coverage/lcov-report/main/utils.ts.html +255 -39
  77. package/coverage/lcov-report/webworker/BatchWriter.ts.html +1 -1
  78. package/coverage/lcov-report/webworker/MessageEncoder.gen.ts.html +1 -1
  79. package/coverage/lcov-report/webworker/PrimitiveEncoder.ts.html +1 -1
  80. package/coverage/lcov-report/webworker/QueueSender.ts.html +1 -1
  81. package/coverage/lcov-report/webworker/index.html +1 -1
  82. package/coverage/lcov-report/webworker/index.ts.html +1 -1
  83. package/coverage/lcov.info +1376 -1729
  84. package/lib/app/index.js +15 -12
  85. package/lib/app/logger.d.ts +1 -1
  86. package/lib/app/messages.gen.d.ts +2 -1
  87. package/lib/app/messages.gen.js +16 -2
  88. package/lib/app/nodes.js +4 -3
  89. package/lib/app/observer/observer.js +2 -1
  90. package/lib/common/messages.gen.d.ts +17 -4
  91. package/lib/common/tsconfig.tsbuildinfo +1 -1
  92. package/lib/index.js +1 -1
  93. package/lib/modules/Network/beaconProxy.d.ts +16 -0
  94. package/lib/modules/Network/beaconProxy.js +77 -0
  95. package/lib/modules/Network/fetchProxy.d.ts +0 -1
  96. package/lib/modules/Network/fetchProxy.js +3 -1
  97. package/lib/modules/Network/index.js +5 -0
  98. package/lib/modules/Network/networkMessage.d.ts +1 -1
  99. package/lib/modules/Network/networkMessage.js +7 -4
  100. package/lib/modules/Network/xhrProxy.d.ts +0 -9
  101. package/lib/modules/Network/xhrProxy.js +0 -1
  102. package/lib/modules/axiosSpy.js +1 -1
  103. package/lib/modules/constructedStyleSheets.js +25 -21
  104. package/lib/modules/featureFlags.js +0 -1
  105. package/lib/modules/img.js +3 -3
  106. package/lib/modules/network.js +5 -4
  107. package/lib/utils.d.ts +16 -0
  108. package/lib/utils.js +47 -0
  109. package/package.json +13 -13
  110. package/rollup.config.js +4 -4
@@ -23,30 +23,30 @@
23
23
  <div class='clearfix'>
24
24
 
25
25
  <div class='fl pad1y space-right2'>
26
- <span class="strong">0% </span>
26
+ <span class="strong">21.86% </span>
27
27
  <span class="quiet">Statements</span>
28
- <span class='fraction'>0/501</span>
28
+ <span class='fraction'>110/503</span>
29
29
  </div>
30
30
 
31
31
 
32
32
  <div class='fl pad1y space-right2'>
33
- <span class="strong">0% </span>
33
+ <span class="strong">16.28% </span>
34
34
  <span class="quiet">Branches</span>
35
- <span class='fraction'>0/257</span>
35
+ <span class='fraction'>43/264</span>
36
36
  </div>
37
37
 
38
38
 
39
39
  <div class='fl pad1y space-right2'>
40
- <span class="strong">0% </span>
40
+ <span class="strong">12.85% </span>
41
41
  <span class="quiet">Functions</span>
42
- <span class='fraction'>0/70</span>
42
+ <span class='fraction'>9/70</span>
43
43
  </div>
44
44
 
45
45
 
46
46
  <div class='fl pad1y space-right2'>
47
- <span class="strong">0% </span>
47
+ <span class="strong">21.22% </span>
48
48
  <span class="quiet">Lines</span>
49
- <span class='fraction'>0/489</span>
49
+ <span class='fraction'>104/490</span>
50
50
  </div>
51
51
 
52
52
 
@@ -80,92 +80,92 @@
80
80
  </thead>
81
81
  <tbody><tr>
82
82
  <td class="file low" data-value="beaconProxy.ts"><a href="beaconProxy.ts.html">beaconProxy.ts</a></td>
83
- <td data-value="0" class="pic low">
84
- <div class="chart"><div class="cover-fill" style="width: 0%"></div><div class="cover-empty" style="width: 100%"></div></div>
83
+ <td data-value="11.32" class="pic low">
84
+ <div class="chart"><div class="cover-fill" style="width: 11%"></div><div class="cover-empty" style="width: 89%"></div></div>
85
85
  </td>
86
- <td data-value="0" class="pct low">0%</td>
87
- <td data-value="53" class="abs low">0/53</td>
88
- <td data-value="0" class="pct low">0%</td>
89
- <td data-value="23" class="abs low">0/23</td>
86
+ <td data-value="11.32" class="pct low">11.32%</td>
87
+ <td data-value="53" class="abs low">6/53</td>
88
+ <td data-value="26.08" class="pct low">26.08%</td>
89
+ <td data-value="23" class="abs low">6/23</td>
90
90
  <td data-value="0" class="pct low">0%</td>
91
91
  <td data-value="5" class="abs low">0/5</td>
92
- <td data-value="0" class="pct low">0%</td>
93
- <td data-value="53" class="abs low">0/53</td>
92
+ <td data-value="11.32" class="pct low">11.32%</td>
93
+ <td data-value="53" class="abs low">6/53</td>
94
94
  </tr>
95
95
 
96
96
  <tr>
97
97
  <td class="file low" data-value="fetchProxy.ts"><a href="fetchProxy.ts.html">fetchProxy.ts</a></td>
98
- <td data-value="0" class="pic low">
99
- <div class="chart"><div class="cover-fill" style="width: 0%"></div><div class="cover-empty" style="width: 100%"></div></div>
98
+ <td data-value="27.51" class="pic low">
99
+ <div class="chart"><div class="cover-fill" style="width: 27%"></div><div class="cover-empty" style="width: 73%"></div></div>
100
100
  </td>
101
- <td data-value="0" class="pct low">0%</td>
102
- <td data-value="147" class="abs low">0/147</td>
103
- <td data-value="0" class="pct low">0%</td>
104
- <td data-value="86" class="abs low">0/86</td>
105
- <td data-value="0" class="pct low">0%</td>
106
- <td data-value="20" class="abs low">0/20</td>
107
- <td data-value="0" class="pct low">0%</td>
108
- <td data-value="146" class="abs low">0/146</td>
101
+ <td data-value="27.51" class="pct low">27.51%</td>
102
+ <td data-value="149" class="abs low">41/149</td>
103
+ <td data-value="27.95" class="pct low">27.95%</td>
104
+ <td data-value="93" class="abs low">26/93</td>
105
+ <td data-value="20" class="pct low">20%</td>
106
+ <td data-value="20" class="abs low">4/20</td>
107
+ <td data-value="27.89" class="pct low">27.89%</td>
108
+ <td data-value="147" class="abs low">41/147</td>
109
109
  </tr>
110
110
 
111
111
  <tr>
112
- <td class="file low" data-value="index.ts"><a href="index.ts.html">index.ts</a></td>
113
- <td data-value="0" class="pic low">
114
- <div class="chart"><div class="cover-fill" style="width: 0%"></div><div class="cover-empty" style="width: 100%"></div></div>
112
+ <td class="file medium" data-value="index.ts"><a href="index.ts.html">index.ts</a></td>
113
+ <td data-value="78.57" class="pic medium">
114
+ <div class="chart"><div class="cover-fill" style="width: 78%"></div><div class="cover-empty" style="width: 22%"></div></div>
115
115
  </td>
116
- <td data-value="0" class="pct low">0%</td>
117
- <td data-value="14" class="abs low">0/14</td>
118
- <td data-value="0" class="pct low">0%</td>
119
- <td data-value="13" class="abs low">0/13</td>
120
- <td data-value="0" class="pct low">0%</td>
121
- <td data-value="2" class="abs low">0/2</td>
122
- <td data-value="0" class="pct low">0%</td>
123
- <td data-value="14" class="abs low">0/14</td>
116
+ <td data-value="78.57" class="pct medium">78.57%</td>
117
+ <td data-value="14" class="abs medium">11/14</td>
118
+ <td data-value="61.53" class="pct medium">61.53%</td>
119
+ <td data-value="13" class="abs medium">8/13</td>
120
+ <td data-value="100" class="pct high">100%</td>
121
+ <td data-value="2" class="abs high">2/2</td>
122
+ <td data-value="78.57" class="pct medium">78.57%</td>
123
+ <td data-value="14" class="abs medium">11/14</td>
124
124
  </tr>
125
125
 
126
126
  <tr>
127
- <td class="file low" data-value="networkMessage.ts"><a href="networkMessage.ts.html">networkMessage.ts</a></td>
128
- <td data-value="0" class="pic low">
129
- <div class="chart"><div class="cover-fill" style="width: 0%"></div><div class="cover-empty" style="width: 100%"></div></div>
127
+ <td class="file medium" data-value="networkMessage.ts"><a href="networkMessage.ts.html">networkMessage.ts</a></td>
128
+ <td data-value="58.82" class="pic medium">
129
+ <div class="chart"><div class="cover-fill" style="width: 58%"></div><div class="cover-empty" style="width: 42%"></div></div>
130
130
  </td>
131
- <td data-value="0" class="pct low">0%</td>
132
- <td data-value="51" class="abs low">0/51</td>
133
- <td data-value="0" class="pct low">0%</td>
134
- <td data-value="8" class="abs low">0/8</td>
135
- <td data-value="0" class="pct low">0%</td>
136
- <td data-value="8" class="abs low">0/8</td>
137
- <td data-value="0" class="pct low">0%</td>
138
- <td data-value="48" class="abs low">0/48</td>
131
+ <td data-value="58.82" class="pct medium">58.82%</td>
132
+ <td data-value="51" class="abs medium">30/51</td>
133
+ <td data-value="25" class="pct low">25%</td>
134
+ <td data-value="8" class="abs low">2/8</td>
135
+ <td data-value="25" class="pct low">25%</td>
136
+ <td data-value="8" class="abs low">2/8</td>
137
+ <td data-value="62.5" class="pct medium">62.5%</td>
138
+ <td data-value="48" class="abs medium">30/48</td>
139
139
  </tr>
140
140
 
141
141
  <tr>
142
142
  <td class="file low" data-value="utils.ts"><a href="utils.ts.html">utils.ts</a></td>
143
- <td data-value="0" class="pic low">
144
- <div class="chart"><div class="cover-fill" style="width: 0%"></div><div class="cover-empty" style="width: 100%"></div></div>
143
+ <td data-value="16.07" class="pic low">
144
+ <div class="chart"><div class="cover-fill" style="width: 16%"></div><div class="cover-empty" style="width: 84%"></div></div>
145
145
  </td>
146
- <td data-value="0" class="pct low">0%</td>
147
- <td data-value="112" class="abs low">0/112</td>
148
- <td data-value="0" class="pct low">0%</td>
149
- <td data-value="83" class="abs low">0/83</td>
150
- <td data-value="0" class="pct low">0%</td>
151
- <td data-value="9" class="abs low">0/9</td>
152
- <td data-value="0" class="pct low">0%</td>
153
- <td data-value="106" class="abs low">0/106</td>
146
+ <td data-value="16.07" class="pct low">16.07%</td>
147
+ <td data-value="112" class="abs low">18/112</td>
148
+ <td data-value="1.2" class="pct low">1.2%</td>
149
+ <td data-value="83" class="abs low">1/83</td>
150
+ <td data-value="11.11" class="pct low">11.11%</td>
151
+ <td data-value="9" class="abs low">1/9</td>
152
+ <td data-value="11.32" class="pct low">11.32%</td>
153
+ <td data-value="106" class="abs low">12/106</td>
154
154
  </tr>
155
155
 
156
156
  <tr>
157
157
  <td class="file low" data-value="xhrProxy.ts"><a href="xhrProxy.ts.html">xhrProxy.ts</a></td>
158
- <td data-value="0" class="pic low">
159
- <div class="chart"><div class="cover-fill" style="width: 0%"></div><div class="cover-empty" style="width: 100%"></div></div>
158
+ <td data-value="3.22" class="pic low">
159
+ <div class="chart"><div class="cover-fill" style="width: 3%"></div><div class="cover-empty" style="width: 97%"></div></div>
160
160
  </td>
161
- <td data-value="0" class="pct low">0%</td>
162
- <td data-value="124" class="abs low">0/124</td>
161
+ <td data-value="3.22" class="pct low">3.22%</td>
162
+ <td data-value="124" class="abs low">4/124</td>
163
163
  <td data-value="0" class="pct low">0%</td>
164
164
  <td data-value="44" class="abs low">0/44</td>
165
165
  <td data-value="0" class="pct low">0%</td>
166
166
  <td data-value="26" class="abs low">0/26</td>
167
- <td data-value="0" class="pct low">0%</td>
168
- <td data-value="122" class="abs low">0/122</td>
167
+ <td data-value="3.27" class="pct low">3.27%</td>
168
+ <td data-value="122" class="abs low">4/122</td>
169
169
  </tr>
170
170
 
171
171
  </tbody>
@@ -176,7 +176,7 @@
176
176
  <div class='footer quiet pad2 space-top1 center small'>
177
177
  Code coverage generated by
178
178
  <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
179
- at 2023-10-17T13:37:58.420Z
179
+ at 2023-11-03T09:39:08.430Z
180
180
  </div>
181
181
  <script src="../../../prettify.js"></script>
182
182
  <script>
@@ -23,30 +23,30 @@
23
23
  <div class='clearfix'>
24
24
 
25
25
  <div class='fl pad1y space-right2'>
26
- <span class="strong">0% </span>
26
+ <span class="strong">78.57% </span>
27
27
  <span class="quiet">Statements</span>
28
- <span class='fraction'>0/14</span>
28
+ <span class='fraction'>11/14</span>
29
29
  </div>
30
30
 
31
31
 
32
32
  <div class='fl pad1y space-right2'>
33
- <span class="strong">0% </span>
33
+ <span class="strong">61.53% </span>
34
34
  <span class="quiet">Branches</span>
35
- <span class='fraction'>0/13</span>
35
+ <span class='fraction'>8/13</span>
36
36
  </div>
37
37
 
38
38
 
39
39
  <div class='fl pad1y space-right2'>
40
- <span class="strong">0% </span>
40
+ <span class="strong">100% </span>
41
41
  <span class="quiet">Functions</span>
42
- <span class='fraction'>0/2</span>
42
+ <span class='fraction'>2/2</span>
43
43
  </div>
44
44
 
45
45
 
46
46
  <div class='fl pad1y space-right2'>
47
- <span class="strong">0% </span>
47
+ <span class="strong">78.57% </span>
48
48
  <span class="quiet">Lines</span>
49
- <span class='fraction'>0/14</span>
49
+ <span class='fraction'>11/14</span>
50
50
  </div>
51
51
 
52
52
 
@@ -61,7 +61,7 @@
61
61
  </div>
62
62
  </template>
63
63
  </div>
64
- <div class='status-line low'></div>
64
+ <div class='status-line medium'></div>
65
65
  <pre><table class="coverage">
66
66
  <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
67
67
  <a name='L2'></a><a href='#L2'>2</a>
@@ -116,17 +116,17 @@
116
116
  <a name='L51'></a><a href='#L51'>51</a>
117
117
  <a name='L52'></a><a href='#L52'>52</a>
118
118
  <a name='L53'></a><a href='#L53'>53</a>
119
- <a name='L54'></a><a href='#L54'>54</a></td><td class="line-coverage quiet"><span class="cline-any cline-no">&nbsp;</span>
120
- <span class="cline-any cline-no">&nbsp;</span>
121
- <span class="cline-any cline-no">&nbsp;</span>
119
+ <a name='L54'></a><a href='#L54'>54</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
120
+ <span class="cline-any cline-yes">1x</span>
121
+ <span class="cline-any cline-yes">1x</span>
122
122
  <span class="cline-any cline-neutral">&nbsp;</span>
123
123
  <span class="cline-any cline-neutral">&nbsp;</span>
124
124
  <span class="cline-any cline-neutral">&nbsp;</span>
125
- <span class="cline-any cline-no">&nbsp;</span>
126
- <span class="cline-any cline-no">&nbsp;</span>
125
+ <span class="cline-any cline-yes">1x</span>
126
+ <span class="cline-any cline-yes">1x</span>
127
127
  <span class="cline-any cline-neutral">&nbsp;</span>
128
128
  <span class="cline-any cline-neutral">&nbsp;</span>
129
- <span class="cline-any cline-no">&nbsp;</span>
129
+ <span class="cline-any cline-yes">1x</span>
130
130
  <span class="cline-any cline-neutral">&nbsp;</span>
131
131
  <span class="cline-any cline-neutral">&nbsp;</span>
132
132
  <span class="cline-any cline-neutral">&nbsp;</span>
@@ -135,7 +135,7 @@
135
135
  <span class="cline-any cline-neutral">&nbsp;</span>
136
136
  <span class="cline-any cline-neutral">&nbsp;</span>
137
137
  <span class="cline-any cline-neutral">&nbsp;</span>
138
- <span class="cline-any cline-no">&nbsp;</span>
138
+ <span class="cline-any cline-yes">1x</span>
139
139
  <span class="cline-any cline-no">&nbsp;</span>
140
140
  <span class="cline-any cline-neutral">&nbsp;</span>
141
141
  <span class="cline-any cline-neutral">&nbsp;</span>
@@ -145,10 +145,10 @@
145
145
  <span class="cline-any cline-neutral">&nbsp;</span>
146
146
  <span class="cline-any cline-neutral">&nbsp;</span>
147
147
  <span class="cline-any cline-neutral">&nbsp;</span>
148
- <span class="cline-any cline-no">&nbsp;</span>
148
+ <span class="cline-any cline-yes">1x</span>
149
149
  <span class="cline-any cline-neutral">&nbsp;</span>
150
- <span class="cline-any cline-no">&nbsp;</span>
151
- <span class="cline-any cline-no">&nbsp;</span>
150
+ <span class="cline-any cline-yes">1x</span>
151
+ <span class="cline-any cline-yes">1x</span>
152
152
  <span class="cline-any cline-neutral">&nbsp;</span>
153
153
  <span class="cline-any cline-neutral">&nbsp;</span>
154
154
  <span class="cline-any cline-neutral">&nbsp;</span>
@@ -159,7 +159,7 @@
159
159
  <span class="cline-any cline-neutral">&nbsp;</span>
160
160
  <span class="cline-any cline-no">&nbsp;</span>
161
161
  <span class="cline-any cline-neutral">&nbsp;</span>
162
- <span class="cline-any cline-no">&nbsp;</span>
162
+ <span class="cline-any cline-yes">1x</span>
163
163
  <span class="cline-any cline-no">&nbsp;</span>
164
164
  <span class="cline-any cline-neutral">&nbsp;</span>
165
165
  <span class="cline-any cline-neutral">&nbsp;</span>
@@ -169,17 +169,17 @@
169
169
  <span class="cline-any cline-neutral">&nbsp;</span>
170
170
  <span class="cline-any cline-neutral">&nbsp;</span>
171
171
  <span class="cline-any cline-neutral">&nbsp;</span>
172
- <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" >import FetchProxy from './fetchProxy.js'</span>
173
- <span class="cstat-no" title="statement not covered" >import XHRProxy from './xhrProxy.js'</span>
174
- <span class="cstat-no" title="statement not covered" >import BeaconProxy from './beaconProxy.js'</span>
172
+ <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import FetchProxy from './fetchProxy.js'
173
+ import XHRProxy from './xhrProxy.js'
174
+ import BeaconProxy from './beaconProxy.js'
175
175
  import { RequestResponseData } from './types.js'
176
176
  import { NetworkRequest } from '../../../common/messages.gen.js'
177
177
  &nbsp;
178
- const getWarning = <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >(a</span>pi: string) =&gt;</span>
179
- <span class="cstat-no" title="statement not covered" > console.warn(`Openreplay: Can't find ${api} in global context. </span>
178
+ const getWarning = (api: string) =&gt;
179
+ console.warn(`Openreplay: Can't find ${api} in global context.
180
180
  If you're using serverside rendering in your app, make sure that tracker is loaded dynamically, otherwise ${api} won't be tracked.`)
181
181
  &nbsp;
182
- <span class="cstat-no" title="statement not covered" >export default function <span class="fstat-no" title="function not covered" >s</span>etProxy(</span>
182
+ export default function setProxy(
183
183
  context: typeof globalThis,
184
184
  ignoredHeaders: boolean | string[],
185
185
  setSessionTokenHeader: (cb: (name: string, value: string) =&gt; void) =&gt; void,
@@ -188,7 +188,7 @@ If you're using serverside rendering in your app, make sure that tracker is load
188
188
  isServiceUrl: (url: string) =&gt; boolean,
189
189
  tokenUrlMatcher?: (url: string) =&gt; boolean,
190
190
  ) {
191
- <span class="cstat-no" title="statement not covered" > if (context.XMLHttpRequest) {</span>
191
+ <span class="missing-if-branch" title="if path not taken" >I</span>if (context.XMLHttpRequest) {
192
192
  <span class="cstat-no" title="statement not covered" > context.XMLHttpRequest = XHRProxy.create(</span>
193
193
  ignoredHeaders,
194
194
  setSessionTokenHeader,
@@ -198,10 +198,10 @@ If you're using serverside rendering in your app, make sure that tracker is load
198
198
  tokenUrlMatcher,
199
199
  )
200
200
  } else {
201
- <span class="cstat-no" title="statement not covered" > getWarning('XMLHttpRequest')</span>
201
+ getWarning('XMLHttpRequest')
202
202
  }
203
- <span class="cstat-no" title="statement not covered" > if (context.fetch) {</span>
204
- <span class="cstat-no" title="statement not covered" > context.fetch = FetchProxy.create(</span>
203
+ if (context.fetch) {
204
+ context.fetch = FetchProxy.create(
205
205
  ignoredHeaders,
206
206
  setSessionTokenHeader,
207
207
  sanitize,
@@ -209,10 +209,10 @@ If you're using serverside rendering in your app, make sure that tracker is load
209
209
  isServiceUrl,
210
210
  tokenUrlMatcher,
211
211
  )
212
- } else {
212
+ } else <span class="missing-if-branch" title="else path not taken" >E</span>{
213
213
  <span class="cstat-no" title="statement not covered" > getWarning('fetch')</span>
214
214
  }
215
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (context?.navigator?.sendBeacon) {</span>
215
+ <span class="missing-if-branch" title="if path not taken" >I</span>if (context<span class="branch-0 cbranch-no" title="branch not covered" >?.n</span>avigator<span class="branch-1 cbranch-no" title="branch not covered" >?.sendBeacon)</span> {
216
216
  <span class="cstat-no" title="statement not covered" > context.navigator.sendBeacon = BeaconProxy.create(</span>
217
217
  ignoredHeaders,
218
218
  setSessionTokenHeader,
@@ -229,7 +229,7 @@ If you're using serverside rendering in your app, make sure that tracker is load
229
229
  <div class='footer quiet pad2 space-top1 center small'>
230
230
  Code coverage generated by
231
231
  <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
232
- at 2023-10-17T13:37:58.420Z
232
+ at 2023-11-03T09:39:08.430Z
233
233
  </div>
234
234
  <script src="../../../prettify.js"></script>
235
235
  <script>
@@ -23,30 +23,30 @@
23
23
  <div class='clearfix'>
24
24
 
25
25
  <div class='fl pad1y space-right2'>
26
- <span class="strong">0% </span>
26
+ <span class="strong">58.82% </span>
27
27
  <span class="quiet">Statements</span>
28
- <span class='fraction'>0/51</span>
28
+ <span class='fraction'>30/51</span>
29
29
  </div>
30
30
 
31
31
 
32
32
  <div class='fl pad1y space-right2'>
33
- <span class="strong">0% </span>
33
+ <span class="strong">25% </span>
34
34
  <span class="quiet">Branches</span>
35
- <span class='fraction'>0/8</span>
35
+ <span class='fraction'>2/8</span>
36
36
  </div>
37
37
 
38
38
 
39
39
  <div class='fl pad1y space-right2'>
40
- <span class="strong">0% </span>
40
+ <span class="strong">25% </span>
41
41
  <span class="quiet">Functions</span>
42
- <span class='fraction'>0/8</span>
42
+ <span class='fraction'>2/8</span>
43
43
  </div>
44
44
 
45
45
 
46
46
  <div class='fl pad1y space-right2'>
47
- <span class="strong">0% </span>
47
+ <span class="strong">62.5% </span>
48
48
  <span class="quiet">Lines</span>
49
- <span class='fraction'>0/48</span>
49
+ <span class='fraction'>30/48</span>
50
50
  </div>
51
51
 
52
52
 
@@ -61,7 +61,7 @@
61
61
  </div>
62
62
  </template>
63
63
  </div>
64
- <div class='status-line low'></div>
64
+ <div class='status-line medium'></div>
65
65
  <pre><table class="coverage">
66
66
  <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
67
67
  <a name='L2'></a><a href='#L2'>2</a>
@@ -163,20 +163,20 @@
163
163
  <a name='L98'></a><a href='#L98'>98</a>
164
164
  <a name='L99'></a><a href='#L99'>99</a>
165
165
  <a name='L100'></a><a href='#L100'>100</a>
166
- <a name='L101'></a><a href='#L101'>101</a></td><td class="line-coverage quiet"><span class="cline-any cline-no">&nbsp;</span>
166
+ <a name='L101'></a><a href='#L101'>101</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">3x</span>
167
167
  <span class="cline-any cline-neutral">&nbsp;</span>
168
- <span class="cline-any cline-no">&nbsp;</span>
168
+ <span class="cline-any cline-yes">3x</span>
169
169
  <span class="cline-any cline-neutral">&nbsp;</span>
170
170
  <span class="cline-any cline-neutral">&nbsp;</span>
171
171
  <span class="cline-any cline-neutral">&nbsp;</span>
172
172
  <span class="cline-any cline-neutral">&nbsp;</span>
173
173
  <span class="cline-any cline-neutral">&nbsp;</span>
174
- <span class="cline-any cline-no">&nbsp;</span>
175
- <span class="cline-any cline-no">&nbsp;</span>
176
- <span class="cline-any cline-no">&nbsp;</span>
177
- <span class="cline-any cline-no">&nbsp;</span>
178
- <span class="cline-any cline-no">&nbsp;</span>
179
- <span class="cline-any cline-no">&nbsp;</span>
174
+ <span class="cline-any cline-yes">3x</span>
175
+ <span class="cline-any cline-yes">3x</span>
176
+ <span class="cline-any cline-yes">3x</span>
177
+ <span class="cline-any cline-yes">3x</span>
178
+ <span class="cline-any cline-yes">3x</span>
179
+ <span class="cline-any cline-yes">3x</span>
180
180
  <span class="cline-any cline-neutral">&nbsp;</span>
181
181
  <span class="cline-any cline-neutral">&nbsp;</span>
182
182
  <span class="cline-any cline-neutral">&nbsp;</span>
@@ -184,32 +184,32 @@
184
184
  <span class="cline-any cline-neutral">&nbsp;</span>
185
185
  <span class="cline-any cline-neutral">&nbsp;</span>
186
186
  <span class="cline-any cline-neutral">&nbsp;</span>
187
- <span class="cline-any cline-no">&nbsp;</span>
188
- <span class="cline-any cline-no">&nbsp;</span>
189
- <span class="cline-any cline-no">&nbsp;</span>
190
- <span class="cline-any cline-no">&nbsp;</span>
191
- <span class="cline-any cline-no">&nbsp;</span>
192
- <span class="cline-any cline-no">&nbsp;</span>
193
- <span class="cline-any cline-no">&nbsp;</span>
194
- <span class="cline-any cline-no">&nbsp;</span>
195
- <span class="cline-any cline-no">&nbsp;</span>
196
- <span class="cline-any cline-no">&nbsp;</span>
197
- <span class="cline-any cline-no">&nbsp;</span>
187
+ <span class="cline-any cline-yes">3x</span>
188
+ <span class="cline-any cline-yes">1x</span>
189
+ <span class="cline-any cline-yes">1x</span>
190
+ <span class="cline-any cline-yes">1x</span>
191
+ <span class="cline-any cline-yes">1x</span>
192
+ <span class="cline-any cline-yes">1x</span>
193
+ <span class="cline-any cline-yes">1x</span>
194
+ <span class="cline-any cline-yes">1x</span>
195
+ <span class="cline-any cline-yes">1x</span>
196
+ <span class="cline-any cline-yes">1x</span>
197
+ <span class="cline-any cline-yes">1x</span>
198
198
  <span class="cline-any cline-neutral">&nbsp;</span>
199
- <span class="cline-any cline-no">&nbsp;</span>
199
+ <span class="cline-any cline-yes">1x</span>
200
200
  <span class="cline-any cline-neutral">&nbsp;</span>
201
- <span class="cline-any cline-no">&nbsp;</span>
202
- <span class="cline-any cline-no">&nbsp;</span>
203
- <span class="cline-any cline-no">&nbsp;</span>
204
- <span class="cline-any cline-no">&nbsp;</span>
205
- <span class="cline-any cline-no">&nbsp;</span>
206
- <span class="cline-any cline-no">&nbsp;</span>
207
- <span class="cline-any cline-no">&nbsp;</span>
201
+ <span class="cline-any cline-yes">1x</span>
202
+ <span class="cline-any cline-yes">1x</span>
203
+ <span class="cline-any cline-yes">1x</span>
204
+ <span class="cline-any cline-yes">1x</span>
205
+ <span class="cline-any cline-yes">1x</span>
206
+ <span class="cline-any cline-yes">1x</span>
207
+ <span class="cline-any cline-yes">1x</span>
208
208
  <span class="cline-any cline-neutral">&nbsp;</span>
209
209
  <span class="cline-any cline-neutral">&nbsp;</span>
210
- <span class="cline-any cline-no">&nbsp;</span>
211
- <span class="cline-any cline-no">&nbsp;</span>
212
- <span class="cline-any cline-no">&nbsp;</span>
210
+ <span class="cline-any cline-yes">1x</span>
211
+ <span class="cline-any cline-yes">1x</span>
212
+ <span class="cline-any cline-yes">1x</span>
213
213
  <span class="cline-any cline-neutral">&nbsp;</span>
214
214
  <span class="cline-any cline-neutral">&nbsp;</span>
215
215
  <span class="cline-any cline-neutral">&nbsp;</span>
@@ -263,20 +263,20 @@
263
263
  <span class="cline-any cline-no">&nbsp;</span>
264
264
  <span class="cline-any cline-neutral">&nbsp;</span>
265
265
  <span class="cline-any cline-neutral">&nbsp;</span>
266
- <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" >import { NetworkRequest } from '../../app/messages.gen.js'</span>
266
+ <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import { NetworkRequest } from '../../app/messages.gen.js'
267
267
  import { RequestResponseData } from './types.js'
268
- <span class="cstat-no" title="statement not covered" >import { getTimeOrigin } from '../../utils.js'</span>
268
+ import { getTimeOrigin } from '../../utils.js'
269
269
  &nbsp;
270
270
  export type httpMethod =
271
271
  // '' is a rare case of error
272
272
  '' | 'GET' | 'POST' | 'PUT' | 'DELETE' | 'HEAD' | 'CONNECT' | 'OPTIONS' | 'TRACE' | 'PATCH'
273
273
  &nbsp;
274
- <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >export enum R</span>equestState {</span>
275
- <span class="cstat-no" title="statement not covered" > UNSENT = 0,</span>
276
- <span class="cstat-no" title="statement not covered" > OPENED = 1,</span>
277
- <span class="cstat-no" title="statement not covered" > HEADERS_RECEIVED = 2,</span>
278
- <span class="cstat-no" title="statement not covered" > LOADING = 3,</span>
279
- <span class="cstat-no" title="statement not covered" > DONE = 4,</span>
274
+ export enum RequestState {
275
+ UNSENT = 0,
276
+ OPENED = 1,
277
+ HEADERS_RECEIVED = 2,
278
+ LOADING = 3,
279
+ DONE = 4,
280
280
  }
281
281
  &nbsp;
282
282
  /**
@@ -284,32 +284,32 @@ export type httpMethod =
284
284
  * but it can be useful in the future if we will decide to display more stuff in our ui
285
285
  * */
286
286
  &nbsp;
287
- <span class="cstat-no" title="statement not covered" >export default class N</span>etworkMessage {
288
- <span class="cstat-no" title="statement not covered" > id = ''</span>
289
- <span class="cstat-no" title="statement not covered" > name?: string = ''</span>
290
- <span class="cstat-no" title="statement not covered" > method: httpMethod = ''</span>
291
- <span class="cstat-no" title="statement not covered" > url = ''</span>
292
- <span class="cstat-no" title="statement not covered" > status = 0</span>
293
- <span class="cstat-no" title="statement not covered" > statusText?: string = ''</span>
294
- <span class="cstat-no" title="statement not covered" > cancelState?: 0 | 1 | 2 | 3 = 0</span>
295
- <span class="cstat-no" title="statement not covered" > readyState?: RequestState = 0</span>
296
- <span class="cstat-no" title="statement not covered" > header: { [key: string]: string } = {}</span>
297
- <span class="cstat-no" title="statement not covered" > responseType: XMLHttpRequest['responseType'] = ''</span>
287
+ export default class NetworkMessage {
288
+ id = ''
289
+ name?: string = ''
290
+ method: httpMethod = ''
291
+ url = ''
292
+ status = 0
293
+ statusText?: string = ''
294
+ cancelState?: 0 | 1 | 2 | 3 = 0
295
+ readyState?: RequestState = 0
296
+ header: { [key: string]: string } = {}
297
+ responseType: XMLHttpRequest['responseType'] = ''
298
298
  requestType: 'xhr' | 'fetch' | 'ping' | 'custom' | 'beacon'
299
- <span class="cstat-no" title="statement not covered" > requestHeader: HeadersInit = {}</span>
299
+ requestHeader: HeadersInit = {}
300
300
  response: any
301
- <span class="cstat-no" title="statement not covered" > responseSize = 0 /</span>/ bytes
302
- <span class="cstat-no" title="statement not covered" > responseSizeText = ''</span>
303
- <span class="cstat-no" title="statement not covered" > startTime = 0</span>
304
- <span class="cstat-no" title="statement not covered" > endTime = 0</span>
305
- <span class="cstat-no" title="statement not covered" > duration = 0</span>
306
- <span class="cstat-no" title="statement not covered" > getData: { [key: string]: string } = {}</span>
307
- <span class="cstat-no" title="statement not covered" > requestData: string | null = null</span>
301
+ responseSize = 0 // bytes
302
+ responseSizeText = ''
303
+ startTime = 0
304
+ endTime = 0
305
+ duration = 0
306
+ getData: { [key: string]: string } = {}
307
+ requestData: string | null = null
308
308
  &nbsp;
309
- <span class="fstat-no" title="function not covered" > constructor(</span>
310
- private readonly <span class="cstat-no" title="statement not covered" >ignoredHeaders: boolean | string[] = <span class="branch-0 cbranch-no" title="branch not covered" >[</span>],</span>
311
- private readonly <span class="cstat-no" title="statement not covered" >setSessionTokenHeader: (cb: (name: string, value: string) =&gt; void) =&gt; void,</span>
312
- private readonly <span class="cstat-no" title="statement not covered" >sanitize: (data: RequestResponseData) =&gt; RequestResponseData,</span>
309
+ constructor(
310
+ private readonly ignoredHeaders: boolean | string[] = <span class="branch-0 cbranch-no" title="branch not covered" >[],</span>
311
+ private readonly setSessionTokenHeader: (cb: (name: string, value: string) =&gt; void) =&gt; void,
312
+ private readonly sanitize: (data: RequestResponseData) =&gt; RequestResponseData,
313
313
  ) {}
314
314
  &nbsp;
315
315
  <span class="fstat-no" title="function not covered" > getMessage(</span>) {
@@ -370,7 +370,7 @@ export type httpMethod =
370
370
  <div class='footer quiet pad2 space-top1 center small'>
371
371
  Code coverage generated by
372
372
  <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
373
- at 2023-10-17T13:37:58.420Z
373
+ at 2023-11-03T09:39:08.430Z
374
374
  </div>
375
375
  <script src="../../../prettify.js"></script>
376
376
  <script>