@newrelic/browser-agent 0.1.230 → 1.232.0

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 (365) hide show
  1. package/README.md +27 -3
  2. package/dist/cjs/common/browser-version/ios-version.js +4 -3
  3. package/dist/cjs/common/config/state/configurable.js +27 -21
  4. package/dist/cjs/common/config/state/info.js +1 -1
  5. package/dist/cjs/common/config/state/init.js +9 -1
  6. package/dist/cjs/common/config/state/loader-config.js +1 -1
  7. package/dist/cjs/common/config/state/runtime.js +26 -28
  8. package/dist/cjs/common/constants/env.cdn.js +29 -0
  9. package/dist/cjs/common/constants/env.js +32 -0
  10. package/dist/cjs/common/constants/env.npm.js +30 -0
  11. package/dist/cjs/common/context/shared-context.js +2 -1
  12. package/dist/cjs/common/event-emitter/contextual-ee.test.js +282 -0
  13. package/dist/cjs/common/event-emitter/handle.test.js +58 -0
  14. package/dist/cjs/common/event-emitter/register-handler.test.js +55 -0
  15. package/dist/cjs/common/event-listener/event-listener-opts.js +4 -2
  16. package/dist/cjs/common/harvest/harvest-scheduler.js +14 -11
  17. package/dist/cjs/common/harvest/harvest.js +5 -3
  18. package/dist/cjs/common/ids/id.js +14 -6
  19. package/dist/cjs/common/ids/id.test.js +85 -0
  20. package/dist/cjs/common/ids/unique-id.js +75 -51
  21. package/dist/cjs/common/ids/unique-id.test.js +49 -0
  22. package/dist/cjs/common/session/constants.js +12 -0
  23. package/dist/cjs/common/session/session-entity.js +278 -0
  24. package/dist/cjs/common/session/session-entity.test.js +436 -0
  25. package/dist/cjs/common/storage/first-party-cookies.js +35 -0
  26. package/dist/cjs/common/storage/local-memory.js +35 -0
  27. package/dist/cjs/common/storage/local-memory.test.js +20 -0
  28. package/dist/cjs/common/storage/local-storage.js +33 -0
  29. package/dist/cjs/common/storage/local-storage.test.js +14 -0
  30. package/dist/cjs/common/timer/interaction-timer.js +78 -0
  31. package/dist/cjs/common/timer/interaction-timer.test.js +216 -0
  32. package/dist/cjs/common/timer/timer.js +32 -0
  33. package/dist/cjs/common/timer/timer.test.js +105 -0
  34. package/dist/cjs/common/timing/nav-timing.js +51 -30
  35. package/dist/cjs/common/timing/nav-timing.test.js +192 -0
  36. package/dist/cjs/common/unload/eol.js +2 -2
  37. package/dist/cjs/common/url/clean-url.test.js +9 -0
  38. package/dist/cjs/common/url/encode.test.js +74 -0
  39. package/dist/cjs/common/url/location.js +4 -0
  40. package/dist/cjs/common/url/location.test.js +13 -0
  41. package/dist/cjs/common/url/parse-url.test.js +111 -0
  42. package/dist/cjs/common/url/protocol.js +2 -12
  43. package/dist/cjs/common/url/protocol.test.js +16 -0
  44. package/dist/cjs/common/util/console.js +1 -1
  45. package/dist/cjs/common/util/data-size.js +6 -0
  46. package/dist/cjs/common/util/data-size.test.js +47 -0
  47. package/dist/cjs/common/util/invoke.js +73 -0
  48. package/dist/cjs/common/util/invoke.test.js +49 -0
  49. package/dist/cjs/common/util/map-own.test.js +3 -3
  50. package/dist/cjs/common/util/obfuscate.js +1 -5
  51. package/dist/cjs/common/window/page-visibility.js +5 -2
  52. package/dist/cjs/common/wrap/index.js +0 -7
  53. package/dist/cjs/common/wrap/wrap-events.js +6 -9
  54. package/dist/cjs/common/wrap/wrap-fetch.js +6 -6
  55. package/dist/cjs/common/wrap/wrap-history.js +7 -6
  56. package/dist/cjs/common/wrap/wrap-jsonp.js +7 -6
  57. package/dist/cjs/common/wrap/wrap-mutation.js +7 -6
  58. package/dist/cjs/common/wrap/wrap-promise.js +7 -6
  59. package/dist/cjs/common/wrap/wrap-promise.test.js +119 -0
  60. package/dist/cjs/common/wrap/wrap-raf.js +6 -6
  61. package/dist/cjs/common/wrap/wrap-timer.js +7 -7
  62. package/dist/cjs/common/wrap/wrap-xhr.js +5 -6
  63. package/dist/cjs/features/ajax/aggregate/index.js +3 -3
  64. package/dist/cjs/features/jserrors/aggregate/compute-stack-trace.test.js +5 -5
  65. package/dist/cjs/features/jserrors/aggregate/format-stack-trace.test.js +1 -1
  66. package/dist/cjs/features/jserrors/aggregate/index.js +6 -6
  67. package/dist/cjs/features/jserrors/instrument/index.js +2 -2
  68. package/dist/cjs/features/metrics/aggregate/index.js +19 -9
  69. package/dist/cjs/features/metrics/instrument/index.js +0 -25
  70. package/dist/cjs/features/metrics/instrument/workers-helper.js +5 -5
  71. package/dist/cjs/features/page_action/aggregate/index.js +3 -3
  72. package/dist/cjs/features/page_view_event/aggregate/index.js +23 -9
  73. package/dist/cjs/features/page_view_timing/aggregate/index.js +40 -30
  74. package/dist/cjs/features/session_trace/aggregate/index.js +18 -15
  75. package/dist/cjs/features/spa/aggregate/index.js +6 -5
  76. package/dist/cjs/features/utils/agent-session.js +73 -0
  77. package/dist/cjs/features/utils/feature-base.js +1 -1
  78. package/dist/cjs/features/utils/instrument-base.js +12 -3
  79. package/dist/cjs/features/utils/lazy-loader.js +2 -2
  80. package/dist/cjs/loaders/agent.js +2 -2
  81. package/dist/cjs/loaders/api/api.js +9 -9
  82. package/dist/cjs/loaders/api/apiAsync.js +3 -2
  83. package/dist/cjs/loaders/configure/configure.js +0 -6
  84. package/dist/cjs/loaders/features/enabled-features.js +1 -1
  85. package/dist/cjs/loaders/micro-agent.js +2 -1
  86. package/dist/esm/common/browser-version/ios-version.js +4 -3
  87. package/dist/esm/common/config/state/configurable.js +26 -20
  88. package/dist/esm/common/config/state/info.js +1 -1
  89. package/dist/esm/common/config/state/init.js +9 -1
  90. package/dist/esm/common/config/state/loader-config.js +1 -1
  91. package/dist/esm/common/config/state/runtime.js +26 -28
  92. package/dist/esm/common/constants/env.cdn.js +20 -0
  93. package/dist/esm/common/constants/env.js +23 -0
  94. package/dist/esm/common/constants/env.npm.js +21 -0
  95. package/dist/esm/common/context/shared-context.js +2 -1
  96. package/dist/esm/common/event-emitter/contextual-ee.test.js +278 -0
  97. package/dist/esm/common/event-emitter/handle.test.js +54 -0
  98. package/dist/esm/common/event-emitter/register-handler.test.js +51 -0
  99. package/dist/esm/common/event-listener/event-listener-opts.js +4 -2
  100. package/dist/esm/common/harvest/harvest-scheduler.js +14 -11
  101. package/dist/esm/common/harvest/harvest.js +4 -2
  102. package/dist/esm/common/ids/id.js +16 -6
  103. package/dist/esm/common/ids/id.test.js +81 -0
  104. package/dist/esm/common/ids/unique-id.js +75 -51
  105. package/dist/esm/common/ids/unique-id.test.js +44 -0
  106. package/dist/esm/common/session/constants.js +3 -0
  107. package/dist/esm/common/session/session-entity.js +271 -0
  108. package/dist/esm/common/session/session-entity.test.js +434 -0
  109. package/dist/esm/common/storage/first-party-cookies.js +28 -0
  110. package/dist/esm/common/storage/local-memory.js +28 -0
  111. package/dist/esm/common/storage/local-memory.test.js +18 -0
  112. package/dist/esm/common/storage/local-storage.js +26 -0
  113. package/dist/esm/common/storage/local-storage.test.js +12 -0
  114. package/dist/esm/common/timer/interaction-timer.js +71 -0
  115. package/dist/esm/common/timer/interaction-timer.test.js +214 -0
  116. package/dist/esm/common/timer/timer.js +25 -0
  117. package/dist/esm/common/timer/timer.test.js +103 -0
  118. package/dist/esm/common/timing/nav-timing.js +51 -29
  119. package/dist/esm/common/timing/nav-timing.test.js +190 -0
  120. package/dist/esm/common/unload/eol.js +1 -1
  121. package/dist/esm/common/url/clean-url.test.js +7 -0
  122. package/dist/esm/common/url/encode.test.js +70 -0
  123. package/dist/esm/common/url/location.js +4 -0
  124. package/dist/esm/common/url/location.test.js +11 -0
  125. package/dist/esm/common/url/parse-url.test.js +107 -0
  126. package/dist/esm/common/url/protocol.js +3 -12
  127. package/dist/esm/common/url/protocol.test.js +14 -0
  128. package/dist/esm/common/util/console.js +1 -1
  129. package/dist/esm/common/util/data-size.js +7 -0
  130. package/dist/esm/common/util/data-size.test.js +45 -0
  131. package/dist/esm/common/util/invoke.js +66 -0
  132. package/dist/esm/common/util/invoke.test.js +47 -0
  133. package/dist/esm/common/util/map-own.test.js +3 -3
  134. package/dist/esm/common/util/obfuscate.js +2 -6
  135. package/dist/esm/common/window/page-visibility.js +5 -2
  136. package/dist/esm/common/wrap/index.js +1 -2
  137. package/dist/esm/common/wrap/wrap-events.js +6 -9
  138. package/dist/esm/common/wrap/wrap-fetch.js +6 -6
  139. package/dist/esm/common/wrap/wrap-history.js +7 -6
  140. package/dist/esm/common/wrap/wrap-jsonp.js +7 -6
  141. package/dist/esm/common/wrap/wrap-mutation.js +7 -6
  142. package/dist/esm/common/wrap/wrap-promise.js +7 -6
  143. package/dist/esm/common/wrap/wrap-promise.test.js +115 -0
  144. package/dist/esm/common/wrap/wrap-raf.js +6 -6
  145. package/dist/esm/common/wrap/wrap-timer.js +7 -7
  146. package/dist/esm/common/wrap/wrap-xhr.js +5 -6
  147. package/dist/esm/features/ajax/aggregate/index.js +3 -3
  148. package/dist/esm/features/jserrors/aggregate/compute-stack-trace.test.js +5 -5
  149. package/dist/esm/features/jserrors/aggregate/format-stack-trace.test.js +1 -1
  150. package/dist/esm/features/jserrors/aggregate/index.js +6 -6
  151. package/dist/esm/features/jserrors/instrument/index.js +2 -2
  152. package/dist/esm/features/metrics/aggregate/index.js +21 -11
  153. package/dist/esm/features/metrics/instrument/index.js +0 -25
  154. package/dist/esm/features/metrics/instrument/workers-helper.js +5 -5
  155. package/dist/esm/features/page_action/aggregate/index.js +3 -3
  156. package/dist/esm/features/page_view_event/aggregate/index.js +23 -9
  157. package/dist/esm/features/page_view_timing/aggregate/index.js +40 -30
  158. package/dist/esm/features/session_trace/aggregate/index.js +18 -15
  159. package/dist/esm/features/spa/aggregate/index.js +6 -5
  160. package/dist/esm/features/utils/agent-session.js +67 -0
  161. package/dist/esm/features/utils/feature-base.js +1 -1
  162. package/dist/esm/features/utils/instrument-base.js +7 -2
  163. package/dist/esm/features/utils/lazy-loader.js +2 -2
  164. package/dist/esm/loaders/agent.js +2 -2
  165. package/dist/esm/loaders/api/api.js +6 -9
  166. package/dist/esm/loaders/api/apiAsync.js +2 -1
  167. package/dist/esm/loaders/configure/configure.js +2 -8
  168. package/dist/esm/loaders/features/enabled-features.js +1 -1
  169. package/dist/types/common/config/state/configurable.d.ts.map +1 -1
  170. package/dist/types/common/config/state/init.d.ts.map +1 -1
  171. package/dist/types/common/config/state/runtime.d.ts.map +1 -1
  172. package/dist/types/common/constants/env.cdn.d.ts +18 -0
  173. package/dist/types/common/constants/env.cdn.d.ts.map +1 -0
  174. package/dist/types/common/constants/env.d.ts +13 -0
  175. package/dist/types/common/constants/env.d.ts.map +1 -0
  176. package/dist/types/common/constants/env.npm.d.ts +19 -0
  177. package/dist/types/common/constants/env.npm.d.ts.map +1 -0
  178. package/dist/types/common/context/shared-context.d.ts.map +1 -1
  179. package/dist/types/common/event-listener/event-listener-opts.d.ts +2 -2
  180. package/dist/types/common/event-listener/event-listener-opts.d.ts.map +1 -1
  181. package/dist/types/common/harvest/harvest-scheduler.d.ts +1 -0
  182. package/dist/types/common/harvest/harvest-scheduler.d.ts.map +1 -1
  183. package/dist/types/common/harvest/harvest.d.ts.map +1 -1
  184. package/dist/types/common/ids/id.d.ts +11 -1
  185. package/dist/types/common/ids/id.d.ts.map +1 -1
  186. package/dist/types/common/ids/unique-id.d.ts +24 -1
  187. package/dist/types/common/ids/unique-id.d.ts.map +1 -1
  188. package/dist/types/common/session/constants.d.ts +4 -0
  189. package/dist/types/common/session/constants.d.ts.map +1 -0
  190. package/dist/types/common/session/session-entity.d.ts +72 -0
  191. package/dist/types/common/session/session-entity.d.ts.map +1 -0
  192. package/dist/types/common/storage/first-party-cookies.d.ts +8 -0
  193. package/dist/types/common/storage/first-party-cookies.d.ts.map +1 -0
  194. package/dist/types/common/storage/local-memory.d.ts +8 -0
  195. package/dist/types/common/storage/local-memory.d.ts.map +1 -0
  196. package/dist/types/common/storage/local-storage.d.ts +6 -0
  197. package/dist/types/common/storage/local-storage.d.ts.map +1 -0
  198. package/dist/types/common/timer/interaction-timer.d.ts +11 -0
  199. package/dist/types/common/timer/interaction-timer.d.ts.map +1 -0
  200. package/dist/types/common/timer/timer.d.ts +12 -0
  201. package/dist/types/common/timer/timer.d.ts.map +1 -0
  202. package/dist/types/common/timing/nav-timing.d.ts +1 -2
  203. package/dist/types/common/timing/nav-timing.d.ts.map +1 -1
  204. package/dist/types/common/unload/eol.d.ts.map +1 -1
  205. package/dist/types/common/url/location.d.ts +4 -0
  206. package/dist/types/common/url/location.d.ts.map +1 -1
  207. package/dist/types/common/url/parse-url.d.ts.map +1 -1
  208. package/dist/types/common/url/protocol.d.ts +1 -6
  209. package/dist/types/common/url/protocol.d.ts.map +1 -1
  210. package/dist/types/common/util/data-size.d.ts +7 -1
  211. package/dist/types/common/util/data-size.d.ts.map +1 -1
  212. package/dist/types/common/util/global-scope.d.ts.map +1 -1
  213. package/dist/types/common/util/invoke.d.ts +35 -0
  214. package/dist/types/common/util/invoke.d.ts.map +1 -0
  215. package/dist/types/common/util/obfuscate.d.ts.map +1 -1
  216. package/dist/types/common/window/page-visibility.d.ts +1 -1
  217. package/dist/types/common/window/page-visibility.d.ts.map +1 -1
  218. package/dist/types/common/wrap/index.d.ts +1 -2
  219. package/dist/types/common/wrap/index.d.ts.map +1 -1
  220. package/dist/types/common/wrap/wrap-fetch.d.ts.map +1 -1
  221. package/dist/types/common/wrap/wrap-history.d.ts.map +1 -1
  222. package/dist/types/common/wrap/wrap-jsonp.d.ts.map +1 -1
  223. package/dist/types/common/wrap/wrap-mutation.d.ts.map +1 -1
  224. package/dist/types/common/wrap/wrap-promise.d.ts.map +1 -1
  225. package/dist/types/common/wrap/wrap-raf.d.ts.map +1 -1
  226. package/dist/types/common/wrap/wrap-timer.d.ts.map +1 -1
  227. package/dist/types/common/wrap/wrap-xhr.d.ts.map +1 -1
  228. package/dist/types/features/ajax/aggregate/index.d.ts +2 -2
  229. package/dist/types/features/ajax/aggregate/index.d.ts.map +1 -1
  230. package/dist/types/features/jserrors/aggregate/index.d.ts +2 -2
  231. package/dist/types/features/jserrors/aggregate/index.d.ts.map +1 -1
  232. package/dist/types/features/jserrors/instrument/index.d.ts.map +1 -1
  233. package/dist/types/features/metrics/aggregate/index.d.ts +2 -2
  234. package/dist/types/features/metrics/aggregate/index.d.ts.map +1 -1
  235. package/dist/types/features/metrics/instrument/index.d.ts +0 -1
  236. package/dist/types/features/metrics/instrument/index.d.ts.map +1 -1
  237. package/dist/types/features/metrics/instrument/workers-helper.d.ts.map +1 -1
  238. package/dist/types/features/page_action/aggregate/index.d.ts +2 -2
  239. package/dist/types/features/page_action/aggregate/index.d.ts.map +1 -1
  240. package/dist/types/features/page_view_event/aggregate/index.d.ts +2 -2
  241. package/dist/types/features/page_view_event/aggregate/index.d.ts.map +1 -1
  242. package/dist/types/features/page_view_timing/aggregate/index.d.ts +3 -4
  243. package/dist/types/features/page_view_timing/aggregate/index.d.ts.map +1 -1
  244. package/dist/types/features/session_trace/aggregate/index.d.ts +3 -3
  245. package/dist/types/features/session_trace/aggregate/index.d.ts.map +1 -1
  246. package/dist/types/features/session_trace/instrument/index.d.ts.map +1 -1
  247. package/dist/types/features/spa/aggregate/index.d.ts +2 -2
  248. package/dist/types/features/spa/aggregate/index.d.ts.map +1 -1
  249. package/dist/types/features/spa/instrument/index.d.ts.map +1 -1
  250. package/dist/types/features/utils/agent-session.d.ts +2 -0
  251. package/dist/types/features/utils/agent-session.d.ts.map +1 -0
  252. package/dist/types/features/utils/instrument-base.d.ts.map +1 -1
  253. package/dist/types/features/utils/lazy-loader.d.ts +2 -2
  254. package/dist/types/features/utils/lazy-loader.d.ts.map +1 -1
  255. package/dist/types/loaders/api/api.d.ts.map +1 -1
  256. package/dist/types/loaders/api/apiAsync.d.ts.map +1 -1
  257. package/dist/types/loaders/configure/configure.d.ts.map +1 -1
  258. package/package.json +12 -32
  259. package/src/common/browser-version/ios-version.js +4 -3
  260. package/src/common/config/state/configurable.js +26 -19
  261. package/src/common/config/state/init.js +7 -0
  262. package/src/common/config/state/runtime.js +7 -10
  263. package/src/common/constants/env.cdn.js +20 -0
  264. package/src/common/constants/env.js +23 -0
  265. package/src/common/constants/env.npm.js +21 -0
  266. package/src/common/context/shared-context.js +2 -1
  267. package/src/common/event-emitter/contextual-ee.test.js +310 -0
  268. package/src/common/event-emitter/handle.test.js +56 -0
  269. package/src/common/event-emitter/register-handler.test.js +61 -0
  270. package/src/common/event-listener/event-listener-opts.js +4 -4
  271. package/src/common/harvest/harvest-scheduler.js +12 -8
  272. package/src/common/harvest/harvest.js +5 -3
  273. package/src/common/ids/id.js +15 -6
  274. package/src/common/ids/id.test.js +92 -0
  275. package/src/common/ids/unique-id.js +77 -54
  276. package/src/common/ids/unique-id.test.js +58 -0
  277. package/src/common/session/constants.js +3 -0
  278. package/src/common/session/session-entity.js +271 -0
  279. package/src/common/session/session-entity.test.js +317 -0
  280. package/src/common/storage/first-party-cookies.js +31 -0
  281. package/src/common/storage/local-memory.js +30 -0
  282. package/src/common/storage/local-memory.test.js +19 -0
  283. package/src/common/storage/local-storage.js +28 -0
  284. package/src/common/storage/local-storage.test.js +17 -0
  285. package/src/common/timer/interaction-timer.js +75 -0
  286. package/src/common/timer/interaction-timer.test.js +167 -0
  287. package/src/common/timer/timer.js +31 -0
  288. package/src/common/timer/timer.test.js +100 -0
  289. package/src/common/timing/nav-timing.js +50 -30
  290. package/src/common/timing/nav-timing.test.js +161 -0
  291. package/src/common/unload/eol.js +2 -3
  292. package/src/common/url/clean-url.test.js +25 -0
  293. package/src/common/url/encode.test.js +80 -0
  294. package/src/common/url/location.js +4 -0
  295. package/src/common/url/location.test.js +15 -0
  296. package/src/common/url/parse-url.js +1 -2
  297. package/src/common/url/parse-url.test.js +110 -0
  298. package/src/common/url/protocol.js +3 -13
  299. package/src/common/url/protocol.test.js +18 -0
  300. package/src/common/util/data-size.js +6 -0
  301. package/src/common/util/data-size.test.js +50 -0
  302. package/src/common/util/global-scope.js +1 -2
  303. package/src/common/util/invoke.js +55 -0
  304. package/src/common/util/invoke.test.js +65 -0
  305. package/src/common/util/obfuscate.js +2 -6
  306. package/src/common/window/page-visibility.js +3 -3
  307. package/src/common/wrap/index.js +1 -2
  308. package/src/common/wrap/wrap-events.js +5 -5
  309. package/src/common/wrap/wrap-fetch.js +4 -3
  310. package/src/common/wrap/wrap-history.js +6 -3
  311. package/src/common/wrap/wrap-jsonp.js +5 -3
  312. package/src/common/wrap/wrap-mutation.js +6 -3
  313. package/src/common/wrap/wrap-promise.js +7 -6
  314. package/src/common/wrap/wrap-promise.test.js +140 -0
  315. package/src/common/wrap/wrap-raf.js +5 -3
  316. package/src/common/wrap/wrap-timer.js +6 -4
  317. package/src/common/wrap/wrap-xhr.js +4 -3
  318. package/src/features/ajax/aggregate/index.js +2 -2
  319. package/src/features/ajax/instrument/index.js +1 -1
  320. package/src/features/jserrors/aggregate/index.js +3 -3
  321. package/src/features/jserrors/instrument/index.js +4 -2
  322. package/src/features/metrics/aggregate/index.js +21 -7
  323. package/src/features/metrics/instrument/index.js +0 -30
  324. package/src/features/metrics/instrument/workers-helper.js +9 -6
  325. package/src/features/page_action/aggregate/index.js +2 -2
  326. package/src/features/page_view_event/aggregate/index.js +21 -9
  327. package/src/features/page_view_timing/aggregate/index.js +40 -29
  328. package/src/features/page_view_timing/long-tasks.js +10 -10
  329. package/src/features/session_trace/aggregate/index.js +17 -14
  330. package/src/features/session_trace/instrument/index.js +3 -2
  331. package/src/features/spa/aggregate/index.js +5 -5
  332. package/src/features/spa/instrument/index.js +4 -2
  333. package/src/features/utils/agent-session.js +68 -0
  334. package/src/features/utils/feature-base.js +1 -1
  335. package/src/features/utils/instrument-base.js +5 -2
  336. package/src/features/utils/lazy-loader.js +1 -1
  337. package/src/loaders/agent.js +1 -1
  338. package/src/loaders/api/api.js +3 -6
  339. package/src/loaders/api/apiAsync.js +2 -1
  340. package/src/loaders/configure/configure.js +2 -7
  341. package/dist/cjs/common/constants/environment-variables.js +0 -20
  342. package/dist/cjs/common/util/single.js +0 -23
  343. package/dist/cjs/common/window/session-storage.js +0 -87
  344. package/dist/cjs/common/wrap/wrap-console.js +0 -54
  345. package/dist/cjs/features/utils/aggregate-base.js +0 -13
  346. package/dist/esm/common/constants/environment-variables.js +0 -11
  347. package/dist/esm/common/util/single.js +0 -16
  348. package/dist/esm/common/window/session-storage.js +0 -77
  349. package/dist/esm/common/wrap/wrap-console.js +0 -46
  350. package/dist/esm/features/utils/aggregate-base.js +0 -6
  351. package/dist/types/common/constants/environment-variables.d.ts +0 -4
  352. package/dist/types/common/constants/environment-variables.d.ts.map +0 -1
  353. package/dist/types/common/util/single.d.ts +0 -2
  354. package/dist/types/common/util/single.d.ts.map +0 -1
  355. package/dist/types/common/window/session-storage.d.ts +0 -18
  356. package/dist/types/common/window/session-storage.d.ts.map +0 -1
  357. package/dist/types/common/wrap/wrap-console.d.ts +0 -16
  358. package/dist/types/common/wrap/wrap-console.d.ts.map +0 -1
  359. package/dist/types/features/utils/aggregate-base.d.ts +0 -4
  360. package/dist/types/features/utils/aggregate-base.d.ts.map +0 -1
  361. package/src/common/constants/environment-variables.js +0 -11
  362. package/src/common/util/single.js +0 -18
  363. package/src/common/window/session-storage.js +0 -75
  364. package/src/common/wrap/wrap-console.js +0 -47
  365. package/src/features/utils/aggregate-base.js +0 -7
@@ -0,0 +1,310 @@
1
+ import { faker } from '@faker-js/faker'
2
+
3
+ let mockNREUM
4
+ let runtime
5
+
6
+ beforeEach(() => {
7
+ mockNREUM = {}
8
+ runtime = {}
9
+
10
+ jest.doMock('../window/nreum', () => ({
11
+ __esModule: true,
12
+ gosNREUM: jest.fn(() => mockNREUM)
13
+ }))
14
+
15
+ jest.doMock('../config/config', () => ({
16
+ __esModule: true,
17
+ getRuntime: jest.fn(() => runtime)
18
+ }))
19
+ })
20
+
21
+ afterEach(() => {
22
+ jest.resetModules()
23
+ jest.resetAllMocks()
24
+ })
25
+
26
+ describe('global event-emitter', () => {
27
+ test('it returns the event-emitter defined on window.NREUM', async () => {
28
+ const mockEE = {}
29
+ mockNREUM.ee = mockEE
30
+
31
+ const { ee } = await import('./contextual-ee')
32
+
33
+ expect(ee).toEqual(mockEE)
34
+ })
35
+
36
+ test('it sets the global event-emitter on window.NREUM', async () => {
37
+ const { ee } = await import('./contextual-ee')
38
+
39
+ expect(ee).toEqual(mockNREUM.ee)
40
+ })
41
+ })
42
+
43
+ describe('scoping event-emitter', () => {
44
+ test('it creates a new child event-emitter', async () => {
45
+ const { ee } = await import('./contextual-ee')
46
+
47
+ const childName = faker.datatype.uuid()
48
+ const result = ee.get(childName)
49
+
50
+ expect(result).not.toEqual(mockNREUM.ee)
51
+ expect(result).toEqual(ee.get(childName)) // Should always return the same event-emitter
52
+ expect(result.debugId).toEqual(childName)
53
+ })
54
+
55
+ test('it creates a child event-emitter with an isolated backlog', async () => {
56
+ const childName = faker.random.alphaNumeric(16)
57
+
58
+ jest.doMock('../config/config', () => ({
59
+ __esModule: true,
60
+ getRuntime: jest.fn(id => {
61
+ if (id === childName) {
62
+ return { isolatedBacklog: true }
63
+ }
64
+
65
+ return runtime
66
+ })
67
+ }))
68
+
69
+ const { ee } = await import('./contextual-ee')
70
+ const result = ee.get(childName)
71
+
72
+ expect(ee.backlog).not.toBe(result.backlog)
73
+ })
74
+ })
75
+
76
+ describe('event-emitter context', () => {
77
+ test('it returns a new context', async () => {
78
+ const { ee } = await import('./contextual-ee')
79
+
80
+ const result = ee.context()
81
+
82
+ expect(result).toEqual({})
83
+ })
84
+
85
+ test('it returns the same context', async () => {
86
+ const { ee } = await import('./contextual-ee')
87
+
88
+ const result = ee.context()
89
+
90
+ expect(result).toEqual(ee.context(result))
91
+ })
92
+
93
+ test('it adds the context to the provided object', async () => {
94
+ const { ee } = await import('./contextual-ee')
95
+
96
+ const obj = {}
97
+ const result = ee.context(obj)
98
+
99
+ expect(result).toEqual(obj['nr@context'])
100
+ })
101
+ })
102
+
103
+ describe('event-emitter buffer', () => {
104
+ it('it should create a new buffer for the given group', async () => {
105
+ const { ee } = await import('./contextual-ee')
106
+ const eventType = faker.datatype.uuid()
107
+ const group = faker.datatype.uuid()
108
+
109
+ ee.buffer([eventType], group)
110
+
111
+ expect(ee.backlog).toEqual(expect.objectContaining({
112
+ [group]: []
113
+ }))
114
+ expect(ee.isBuffering(eventType)).toEqual(true)
115
+ })
116
+
117
+ it('it should default group to "feature"', async () => {
118
+ const { ee } = await import('./contextual-ee')
119
+ const eventType = faker.datatype.uuid()
120
+
121
+ ee.buffer([eventType])
122
+
123
+ expect(ee.backlog).toEqual(expect.objectContaining({
124
+ feature: []
125
+ }))
126
+ expect(ee.isBuffering(eventType)).toEqual(true)
127
+ })
128
+
129
+ it('it should not create buffer if event-emitter is aborted', async () => {
130
+ const { ee } = await import('./contextual-ee')
131
+ const eventType = faker.datatype.uuid()
132
+ const group = faker.datatype.uuid()
133
+
134
+ ee.backlog = {
135
+ api: ['foo', 'bar', 'baz']
136
+ }
137
+ ee.abort()
138
+ ee.buffer([eventType], group)
139
+
140
+ expect(ee.backlog).toEqual({})
141
+ expect(ee.isBuffering(eventType)).toEqual(false)
142
+ })
143
+ })
144
+
145
+ describe('event-emitter abort', () => {
146
+ test('it aborts if there is an API backlog', async () => {
147
+ const { ee } = await import('./contextual-ee')
148
+
149
+ ee.backlog = {
150
+ api: ['foo', 'bar', 'baz']
151
+ }
152
+ ee.abort()
153
+
154
+ expect(ee.aborted).toEqual(true)
155
+ expect(ee.backlog).toEqual({})
156
+ })
157
+
158
+ test('it aborts if there is a feature backlog', async () => {
159
+ const { ee } = await import('./contextual-ee')
160
+
161
+ ee.backlog = {
162
+ feature: ['foo', 'bar', 'baz']
163
+ }
164
+ ee.abort()
165
+
166
+ expect(ee.aborted).toEqual(true)
167
+ expect(ee.backlog).toEqual({})
168
+ })
169
+ })
170
+
171
+ describe('event-emitter emit', () => {
172
+ it('should execute the listener', async () => {
173
+ const { ee } = await import('./contextual-ee')
174
+ const mockListener = jest.fn()
175
+ const eventType = faker.datatype.uuid()
176
+ const eventArgs = ['a', 'b', 'c']
177
+
178
+ ee.on(eventType, mockListener)
179
+ ee.emit(eventType, eventArgs)
180
+
181
+ expect(mockListener).toHaveBeenCalledWith(eventArgs[0], eventArgs[1], eventArgs[2])
182
+ })
183
+
184
+ it('should not execute the listener after removal', async () => {
185
+ const { ee } = await import('./contextual-ee')
186
+ const mockListener = jest.fn()
187
+ const eventType = faker.datatype.uuid()
188
+ const eventArgs = ['a', 'b', 'c']
189
+
190
+ ee.on(eventType, mockListener)
191
+ ee.emit(eventType, eventArgs)
192
+ ee.removeEventListener(eventType, mockListener)
193
+ ee.emit(eventType, eventArgs)
194
+
195
+ expect(mockListener).toHaveBeenCalledTimes(1)
196
+ })
197
+
198
+ it('should return early if global event-emitter is aborted', async () => {
199
+ const { ee } = await import('./contextual-ee')
200
+ const mockListener = jest.fn()
201
+ const eventType = faker.datatype.uuid()
202
+ const eventArgs = ['a', 'b', 'c']
203
+
204
+ ee.backlog = {
205
+ api: ['foo', 'bar', 'baz']
206
+ }
207
+ ee.abort()
208
+ ee.on(eventType, mockListener)
209
+ ee.emit(eventType, eventArgs)
210
+
211
+ expect(mockListener).toHaveBeenCalledTimes(0)
212
+ })
213
+
214
+ it('should still emit if global event-emitter is aborted but force flag is true', async () => {
215
+ const { ee } = await import('./contextual-ee')
216
+ const scopeEE = ee.get(faker.datatype.uuid())
217
+ const mockScopeListener = jest.fn()
218
+ const eventType = faker.datatype.uuid()
219
+ const eventArgs = ['a', 'b', 'c']
220
+
221
+ ee.backlog = {
222
+ api: ['foo', 'bar', 'baz']
223
+ }
224
+ ee.abort()
225
+ scopeEE.on(eventType, mockScopeListener)
226
+ scopeEE.emit(eventType, eventArgs, {}, true)
227
+
228
+ expect(mockScopeListener).toHaveBeenCalledTimes(1)
229
+ })
230
+
231
+ it('should bubble the event if bubble flag is true', async () => {
232
+ const { ee } = await import('./contextual-ee')
233
+ const scopeEE = ee.get(faker.datatype.uuid())
234
+ const mockListener = jest.fn()
235
+ const mockScopeListener = jest.fn()
236
+ const eventType = faker.datatype.uuid()
237
+ const eventArgs = ['a', 'b', 'c']
238
+
239
+ ee.on(eventType, mockListener)
240
+ scopeEE.on(eventType, mockScopeListener)
241
+ scopeEE.emit(eventType, eventArgs, {}, false, true)
242
+
243
+ expect(mockScopeListener).toHaveBeenCalledTimes(1)
244
+ expect(mockListener).toHaveBeenCalledTimes(1)
245
+ })
246
+
247
+ it('should not bubble the event if bubble flag is false', async () => {
248
+ const { ee } = await import('./contextual-ee')
249
+ const scopeEE = ee.get(faker.datatype.uuid())
250
+ const mockListener = jest.fn()
251
+ const mockScopeListener = jest.fn()
252
+ const eventType = faker.datatype.uuid()
253
+ const eventArgs = ['a', 'b', 'c']
254
+
255
+ ee.on(eventType, mockListener)
256
+ scopeEE.on(eventType, mockScopeListener)
257
+ scopeEE.emit(eventType, eventArgs, {}, false, false)
258
+
259
+ expect(mockScopeListener).toHaveBeenCalledTimes(1)
260
+ expect(mockListener).not.toHaveBeenCalled()
261
+ })
262
+
263
+ it('should buffer the event on the scoped event-emitter', async () => {
264
+ const { ee } = await import('./contextual-ee')
265
+ const scopeEE = ee.get(faker.datatype.uuid())
266
+ const mockListener = jest.fn()
267
+ const mockScopeListener = jest.fn()
268
+ const eventType = faker.datatype.uuid()
269
+ const eventArgs = ['a', 'b', 'c']
270
+
271
+ ee.on(eventType, mockListener)
272
+ ee.buffer([eventType])
273
+ scopeEE.on(eventType, mockScopeListener)
274
+ scopeEE.buffer([eventType])
275
+ scopeEE.emit(eventType, eventArgs, {}, false, false)
276
+
277
+ expect(mockScopeListener).toHaveBeenCalledTimes(1)
278
+ expect(mockListener).not.toHaveBeenCalled()
279
+ expect(scopeEE.backlog.feature).toEqual(expect.arrayContaining([
280
+ expect.arrayContaining([
281
+ scopeEE,
282
+ eventType,
283
+ eventArgs,
284
+ {}
285
+ ])
286
+ ]))
287
+ expect(ee.backlog.feature).toEqual(scopeEE.backlog.feature)
288
+ })
289
+ })
290
+
291
+ describe('getOrSetContext', () => {
292
+ test('it returns a new context', async () => {
293
+ const { getOrSetContext } = await import('./contextual-ee')
294
+
295
+ const obj = {}
296
+ const result = getOrSetContext(obj)
297
+
298
+ expect(result).toEqual({})
299
+ expect(result).toEqual(obj['nr@context'])
300
+ })
301
+
302
+ test('it returns the same context', async () => {
303
+ const { getOrSetContext } = await import('./contextual-ee')
304
+
305
+ const obj = {}
306
+ const result = getOrSetContext(obj)
307
+
308
+ expect(getOrSetContext(obj)).toEqual(result)
309
+ })
310
+ })
@@ -0,0 +1,56 @@
1
+ import { faker } from '@faker-js/faker'
2
+
3
+ jest.mock('./contextual-ee', () => ({
4
+ __esModule: true,
5
+ ee: {
6
+ buffer: jest.fn(),
7
+ emit: jest.fn(),
8
+ get: jest.fn(() => ({
9
+ buffer: jest.fn(),
10
+ emit: jest.fn()
11
+ }))
12
+ }
13
+ }))
14
+
15
+ afterEach(() => {
16
+ jest.resetModules()
17
+ jest.resetAllMocks()
18
+ })
19
+
20
+ test('it should create and use a default event-emitter', async () => {
21
+ const { ee } = await import('./contextual-ee')
22
+ const { handle } = await import('./handle')
23
+
24
+ const handleEE = jest.mocked(ee.get).mock.results[0].value
25
+ const eventType = faker.datatype.uuid()
26
+ const eventArgs = ['a', 'b', 'c']
27
+ const eventContext = {}
28
+ const eventGroup = faker.datatype.uuid()
29
+
30
+ handle(eventType, eventArgs, eventContext, eventGroup)
31
+
32
+ expect(handleEE.buffer).toHaveBeenCalledWith([eventType], eventGroup)
33
+ expect(handleEE.emit).toHaveBeenCalledWith(eventType, eventArgs, eventContext)
34
+ })
35
+
36
+ test('it should use the provided scoped event-emitter', async () => {
37
+ const { ee } = await import('./contextual-ee')
38
+ const { handle } = await import('./handle')
39
+ const scopedEE = {
40
+ buffer: jest.fn(),
41
+ emit: jest.fn()
42
+ }
43
+
44
+ const handleEE = jest.mocked(ee.get).mock.results[0].value
45
+ const eventType = faker.datatype.uuid()
46
+ const eventArgs = ['a', 'b', 'c']
47
+ const eventContext = {}
48
+ const eventGroup = faker.datatype.uuid()
49
+
50
+ handle(eventType, eventArgs, eventContext, eventGroup, scopedEE)
51
+
52
+ expect(handleEE.buffer).not.toHaveBeenCalled()
53
+ expect(handleEE.emit).not.toHaveBeenCalled()
54
+ expect(scopedEE.buffer).toHaveBeenCalledWith([eventType], eventGroup)
55
+ expect(scopedEE.emit).toHaveBeenCalledWith(eventType, eventArgs, eventContext)
56
+ })
@@ -0,0 +1,61 @@
1
+ import { faker } from '@faker-js/faker'
2
+
3
+ jest.mock('./handle', () => ({
4
+ __esModule: true,
5
+ handleEE: {}
6
+ }))
7
+
8
+ afterEach(() => {
9
+ jest.resetModules()
10
+ jest.resetAllMocks()
11
+ })
12
+
13
+ test('should default group to "feature"', async () => {
14
+ const { handleEE } = await import('./handle')
15
+ const { registerHandler } = await import('./register-handler')
16
+
17
+ const eventType = faker.datatype.uuid()
18
+ const eventHandler = jest.fn()
19
+
20
+ registerHandler(eventType, eventHandler)
21
+
22
+ expect(registerHandler.handlers.feature).toEqual(expect.objectContaining({
23
+ [eventType]: [expect.arrayContaining([
24
+ handleEE, eventHandler
25
+ ])]
26
+ }))
27
+ })
28
+
29
+ test('should use the provided group', async () => {
30
+ const { handleEE } = await import('./handle')
31
+ const { registerHandler } = await import('./register-handler')
32
+
33
+ const eventType = faker.datatype.uuid()
34
+ const eventGroup = faker.datatype.uuid()
35
+ const eventHandler = jest.fn()
36
+
37
+ registerHandler(eventType, eventHandler, eventGroup)
38
+
39
+ expect(registerHandler.handlers[eventGroup]).toEqual(expect.objectContaining({
40
+ [eventType]: [expect.arrayContaining([
41
+ handleEE, eventHandler
42
+ ])]
43
+ }))
44
+ })
45
+
46
+ test('should use the provided event-emitter', async () => {
47
+ const { registerHandler } = await import('./register-handler')
48
+
49
+ const scopedEE = {}
50
+ const eventType = faker.datatype.uuid()
51
+ const eventGroup = faker.datatype.uuid()
52
+ const eventHandler = jest.fn()
53
+
54
+ registerHandler(eventType, eventHandler, eventGroup, scopedEE)
55
+
56
+ expect(registerHandler.handlers[eventGroup]).toEqual(expect.objectContaining({
57
+ [eventType]: [expect.arrayContaining([
58
+ scopedEE, eventHandler
59
+ ])]
60
+ }))
61
+ })
@@ -32,10 +32,10 @@ export function eventListenerOpts (useCapture, abortSignal) {
32
32
  }
33
33
 
34
34
  /** Do not use this within the worker context. */
35
- export function windowAddEventListener (event, listener, capture = false) {
36
- window.addEventListener(event, listener, eventListenerOpts(capture))
35
+ export function windowAddEventListener (event, listener, capture = false, abortSignal) {
36
+ window.addEventListener(event, listener, eventListenerOpts(capture, abortSignal))
37
37
  }
38
38
  /** Do not use this within the worker context. */
39
- export function documentAddEventListener (event, listener, capture = false) {
40
- document.addEventListener(event, listener, eventListenerOpts(capture))
39
+ export function documentAddEventListener (event, listener, capture = false, abortSignal) {
40
+ document.addEventListener(event, listener, eventListenerOpts(capture, abortSignal))
41
41
  }
@@ -23,13 +23,18 @@ export class HarvestScheduler extends SharedContext {
23
23
 
24
24
  this.harvest = new Harvest(this.sharedContext)
25
25
 
26
- subscribeToEOL(() => {
27
- if (this.aborted) return
26
+ // unload if EOL mechanism fires
27
+ subscribeToEOL(this.unload.bind(this), getConfigurationValue(this.sharedContext.agentIdentifier, 'allow_bfcache')) // TO DO: remove feature flag after rls stable
28
28
 
29
- // If opts.onUnload is defined, these are special actions to execute before attempting to send the final payload.
30
- if (this.opts.onUnload) this.opts.onUnload()
31
- this.runHarvest({ unload: true })
32
- }, getConfigurationValue(this.sharedContext.agentIdentifier, 'allow_bfcache')) // TO DO: remove feature flag after rls stable
29
+ // unload if session resets
30
+ this.sharedContext?.ee.on('session-reset', this.unload.bind(this))
31
+ }
32
+
33
+ unload () {
34
+ if (this.aborted) return
35
+ // If opts.onUnload is defined, these are special actions to execute before attempting to send the final payload.
36
+ if (this.opts.onUnload) this.opts.onUnload()
37
+ this.runHarvest({ unload: true })
33
38
  }
34
39
 
35
40
  startTimer (interval, initialDelay) {
@@ -76,8 +81,7 @@ export class HarvestScheduler extends SharedContext {
76
81
  }
77
82
  }
78
83
  } else {
79
- const runAfterSending = opts?.unload ? undefined : onHarvestFinished // don't bother running onFinish handler if this is the final harvest
80
- this.harvest.sendX(this.endpoint, opts, runAfterSending)
84
+ this.harvest.sendX(this.endpoint, opts, onHarvestFinished)
81
85
  }
82
86
 
83
87
  if (this.started) {
@@ -15,7 +15,7 @@ import { eventListenerOpts } from '../event-listener/event-listener-opts'
15
15
  import { Obfuscator } from '../util/obfuscate'
16
16
  import { applyFnToProps } from '../util/traverse'
17
17
  import { SharedContext } from '../context/shared-context'
18
- import { VERSION } from '../constants/environment-variables'
18
+ import { VERSION } from '../constants/env'
19
19
  import { isBrowserScope, isWorkerScope } from '../util/global-scope'
20
20
 
21
21
  const haveSendBeacon = !!navigator.sendBeacon // only the web window obj has sendBeacon at this time, so 'false' for other envs
@@ -118,6 +118,8 @@ export class Harvest extends SharedContext {
118
118
 
119
119
  // Get bytes harvested per endpoint as a supportability metric. See metrics aggregator (on unload).
120
120
  agentRuntime.bytesSent[endpoint] = (agentRuntime.bytesSent[endpoint] || 0) + body?.length || 0
121
+ // Get query bytes harvested per endpoint as a supportability metric. See metrics aggregator (on unload).
122
+ agentRuntime.queryBytesSent[endpoint] = (agentRuntime.queryBytesSent[endpoint] || 0) + fullUrl.split('?').slice(-1)[0]?.length || 0
121
123
 
122
124
  /* Since workers don't support sendBeacon right now, or Image(), they can only use XHR method.
123
125
  Because they still do permit synch XHR, the idea is that at final harvest time (worker is closing),
@@ -167,7 +169,7 @@ export class Harvest extends SharedContext {
167
169
  encodeParam('ct', runtime.customTransaction),
168
170
  '&rst=' + now(),
169
171
  '&ck=0', // ck param DEPRECATED - still expected by backend
170
- '&s=' + (runtime.sessionId || '0'), // the 0 id encaps all untrackable and default traffic
172
+ '&s=' + (runtime.session?.value || '0'), // the 0 id encaps all untrackable and default traffic
171
173
  encodeParam('ref', ref),
172
174
  encodeParam('ptid', (runtime.ptid ? '' + runtime.ptid : ''))
173
175
  ].join(''))
@@ -176,7 +178,7 @@ export class Harvest extends SharedContext {
176
178
  createPayload (type, options) {
177
179
  var makeBody = createAccumulator()
178
180
  var makeQueryString = createAccumulator()
179
- var listeners = (this._events[type] && this._events[type] || [])
181
+ var listeners = ((this._events[type] && this._events[type]) || [])
180
182
 
181
183
  for (var i = 0; i < listeners.length; i++) {
182
184
  var singlePayload = listeners[i](options)
@@ -3,17 +3,26 @@
3
3
  * SPDX-License-Identifier: Apache-2.0
4
4
  */
5
5
 
6
- // Start assigning ids at 1 so 0 can always be used for WindowOrWorkerGlobalScope, without
7
- // actually setting it (which would create a global variable).
8
6
  import { getOrSet } from '../util/get-or-set'
9
7
  import { globalScope } from '../util/global-scope'
10
8
 
11
- var index = 1
12
- var prop = 'nr@id'
9
+ // Start assigning ids at 1 so 0 can always be used for Window or WorkerGlobalScope, without
10
+ // actually setting it (which would create a global variable).
11
+ let index = 1
12
+ const prop = 'nr@id'
13
13
 
14
- // Always returns id of obj, may tag obj with an id in the process.
14
+ /**
15
+ * Tags a specified object with an identifier if it does not already
16
+ * have one. If the object is the global scope, zero will be returned
17
+ * and the object will not be modified. If the object already contains
18
+ * an identifier, it will be returned without modification. If the passed
19
+ * value is not an object, function, or array, -1 will be returned without
20
+ * modifying the passed value.
21
+ * @param {object|function|array} obj Object to be tagged with an identifier
22
+ * @returns {number} Identifier of the given object
23
+ */
15
24
  export function id (obj) {
16
- var type = typeof obj
25
+ const type = typeof obj
17
26
  // We can only tag objects, functions, and arrays with ids.
18
27
  // For all primitive values we instead return -1.
19
28
  if (!obj || !(type === 'object' || type === 'function')) return -1
@@ -0,0 +1,92 @@
1
+ let idFn
2
+
3
+ beforeEach(async () => {
4
+ idFn = (await import('./id')).id
5
+ })
6
+
7
+ afterEach(() => {
8
+ jest.resetModules()
9
+ jest.clearAllMocks()
10
+ })
11
+
12
+ test.each([
13
+ { input: undefined, expected: -1, title: 'id of undefined is -1' },
14
+ { input: null, expected: -1, title: 'id of null is -1' },
15
+ { input: 2, expected: -1, title: 'id of number is -1' },
16
+ { input: 'foo', expected: -1, title: 'id of string is -1' }
17
+ ])('$title', ({ input, expected }) => {
18
+ const result = idFn(input)
19
+
20
+ expect(typeof result).toEqual('number')
21
+ expect(result).toEqual(expected)
22
+ })
23
+
24
+ test('id values increment sequentially', () => {
25
+ const inputA = {}
26
+ const inputB = {}
27
+
28
+ const resultA = idFn(inputA)
29
+ const resultB = idFn(inputB)
30
+
31
+ expect(resultA - resultB).toEqual(-1)
32
+ })
33
+
34
+ test('id is correctly assigned to function type', () => {
35
+ const input = jest.fn()
36
+
37
+ const result = idFn(input)
38
+
39
+ expect(result).toEqual(1)
40
+ expect(input['nr@id']).toEqual(1)
41
+ })
42
+
43
+ test('id is correctly assigned to object type', () => {
44
+ const input = {}
45
+
46
+ const result = idFn(input)
47
+
48
+ expect(result).toEqual(1)
49
+ expect(input['nr@id']).toEqual(1)
50
+ })
51
+
52
+ test('id is the same when called twice on the same input', () => {
53
+ const input = {}
54
+
55
+ const result1 = idFn(input)
56
+ const result2 = idFn(input)
57
+
58
+ expect(result1).toEqual(1)
59
+ expect(result2).toEqual(1)
60
+ expect(input['nr@id']).toEqual(1)
61
+ })
62
+
63
+ test('id is zero on global scope', async () => {
64
+ const result = idFn(global)
65
+
66
+ expect(result).toEqual(0)
67
+ })
68
+
69
+ test('id on prototype is correctly inherited', () => {
70
+ const fn = jest.fn()
71
+ const a = {}
72
+
73
+ idFn(a)
74
+ fn.prototype = a
75
+
76
+ const b = new fn()
77
+
78
+ expect(b['nr@id']).toEqual(a['nr@id'])
79
+ })
80
+
81
+ test('id on prototype is different from instance', () => {
82
+ const fn = jest.fn()
83
+ const a = {}
84
+
85
+ idFn(a)
86
+ fn.prototype = a
87
+
88
+ const b = new fn()
89
+ const result = idFn(b)
90
+
91
+ expect(b['nr@id']).toEqual(result)
92
+ })