@oneuptime/common 10.8.1 → 11.0.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 (772) hide show
  1. package/Models/AnalyticsModels/AnalyticsBaseModel/AnalyticsBaseModel.ts +16 -18
  2. package/Models/AnalyticsModels/AuditLog.ts +3 -1
  3. package/Models/AnalyticsModels/ExceptionInstance.ts +200 -82
  4. package/Models/AnalyticsModels/Index.ts +7 -2
  5. package/Models/AnalyticsModels/Log.ts +197 -81
  6. package/Models/AnalyticsModels/Metric.ts +199 -86
  7. package/Models/AnalyticsModels/MetricBaselineHourly.ts +44 -25
  8. package/Models/AnalyticsModels/MetricItemAggMV1m.ts +23 -20
  9. package/Models/AnalyticsModels/{MetricItemAggMV1mByHost.ts → MetricItemAggMV1mByHostV2.ts} +58 -47
  10. package/Models/AnalyticsModels/MonitorLog.ts +5 -1
  11. package/Models/AnalyticsModels/Profile.ts +206 -85
  12. package/Models/AnalyticsModels/ProfileSample.ts +196 -83
  13. package/Models/AnalyticsModels/Span.ts +218 -85
  14. package/Models/DatabaseModels/CloudResourceInstance.ts +1 -2
  15. package/Models/DatabaseModels/CloudResourceOwnerTeam.ts +1 -2
  16. package/Models/DatabaseModels/CloudResourceOwnerUser.ts +1 -2
  17. package/Models/DatabaseModels/Index.ts +4 -0
  18. package/Models/DatabaseModels/Service.ts +29 -0
  19. package/Models/DatabaseModels/TelemetryEntity.ts +393 -0
  20. package/Models/DatabaseModels/TelemetryEntityRelationship.ts +294 -0
  21. package/Models/DatabaseModels/TelemetryException.ts +13 -12
  22. package/Models/DatabaseModels/TelemetryUsageBilling.ts +5 -5
  23. package/Server/API/AIAgentDataAPI.ts +13 -12
  24. package/Server/API/DashboardAPI.ts +2 -2
  25. package/Server/API/TelemetryAPI.ts +656 -141
  26. package/Server/API/TelemetryExceptionAPI.ts +2 -2
  27. package/Server/Infrastructure/ClickhouseConfig.ts +12 -0
  28. package/Server/Infrastructure/Postgres/SchemaMigrations/1780931863719-AddTelemetryResourceMetadataColumns.ts +1 -3
  29. package/Server/Infrastructure/Postgres/SchemaMigrations/1780933132562-AddServerlessFunctionTables.ts +6 -2
  30. package/Server/Infrastructure/Postgres/SchemaMigrations/1780935387827-AddCloudResourceTables.ts +18 -6
  31. package/Server/Infrastructure/Postgres/SchemaMigrations/1781011482945-MigrationName.ts +2317 -0
  32. package/Server/Infrastructure/Postgres/SchemaMigrations/1781100000001-RenameTelemetryServiceIdToPrimaryEntityId.ts +48 -0
  33. package/Server/Infrastructure/Postgres/SchemaMigrations/1781200000000-AddTelemetryEntityTable.ts +70 -0
  34. package/Server/Infrastructure/Postgres/SchemaMigrations/1781200000001-AddTelemetryEntityRelationshipTable.ts +57 -0
  35. package/Server/Infrastructure/Postgres/SchemaMigrations/1781250074195-MigrationName.ts +207 -0
  36. package/Server/Infrastructure/Postgres/SchemaMigrations/1781300000000-AddTelemetryEntityLabels.ts +24 -0
  37. package/Server/Infrastructure/Postgres/SchemaMigrations/1781400000000-AddServiceTelemetrySdkLanguage.ts +25 -0
  38. package/Server/Infrastructure/Postgres/SchemaMigrations/Index.ts +14 -0
  39. package/Server/Infrastructure/Queue.ts +36 -3
  40. package/Server/Middleware/TelemetryIngest.ts +27 -22
  41. package/Server/Services/AlertService.ts +9 -9
  42. package/Server/Services/AnalyticsDatabaseService.ts +204 -35
  43. package/Server/Services/CloudResourceLabelRuleEngineService.ts +4 -1
  44. package/Server/Services/CloudResourceOwnerRuleEngineService.ts +4 -1
  45. package/Server/Services/ExceptionAggregationService.ts +41 -18
  46. package/Server/Services/HostService.ts +2 -1
  47. package/Server/Services/IncidentService.ts +19 -19
  48. package/Server/Services/Index.ts +6 -2
  49. package/Server/Services/LogAggregationService.ts +116 -43
  50. package/Server/Services/MetricAggregationService.ts +29 -14
  51. package/Server/Services/MetricBaselineService.ts +34 -34
  52. package/Server/Services/MetricItemAggMV1mByHostV2Service.ts +30 -0
  53. package/Server/Services/MetricService.ts +119 -31
  54. package/Server/Services/OpenTelemetryIngestService.ts +189 -51
  55. package/Server/Services/ProfileAggregationService.ts +904 -126
  56. package/Server/Services/RumApplicationLabelRuleEngineService.ts +4 -1
  57. package/Server/Services/RumApplicationOwnerRuleEngineService.ts +4 -1
  58. package/Server/Services/ServerlessFunctionInstanceService.ts +4 -2
  59. package/Server/Services/ServerlessFunctionLabelRuleEngineService.ts +7 -2
  60. package/Server/Services/ServerlessFunctionOwnerRuleEngineService.ts +7 -2
  61. package/Server/Services/ServiceService.ts +6 -0
  62. package/Server/Services/SpanService.ts +274 -14
  63. package/Server/Services/TelemetryEntityRelationshipService.ts +71 -0
  64. package/Server/Services/TelemetryEntityService.ts +246 -0
  65. package/Server/Services/TelemetryExceptionService.ts +27 -23
  66. package/Server/Services/TelemetryUsageBillingService.ts +38 -31
  67. package/Server/Services/TraceAggregationService.ts +875 -43
  68. package/Server/Types/AnalyticsDatabase/ModelPermission.ts +43 -2
  69. package/Server/Types/Database/Permissions/AccessControlPermission.ts +47 -2
  70. package/Server/Types/Database/Permissions/BasePermission.ts +37 -1
  71. package/Server/Types/Database/Permissions/OwnedScopePermission.ts +21 -3
  72. package/Server/Types/Database/Permissions/OwnerTableRegistry.ts +1 -0
  73. package/Server/Types/Database/QueryHelper.ts +41 -0
  74. package/Server/Utils/Alert/AlertPrivacyFilter.ts +9 -2
  75. package/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.ts +9 -2
  76. package/Server/Utils/AnalyticsDatabase/QuerySettingsHelper.ts +95 -0
  77. package/Server/Utils/AnalyticsDatabase/StatementGenerator.ts +133 -0
  78. package/Server/Utils/Incident/IncidentPrivacyFilter.ts +9 -2
  79. package/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.ts +9 -2
  80. package/Server/Utils/Monitor/Criteria/EvaluateOverTime.ts +1 -1
  81. package/Server/Utils/Monitor/MonitorLogUtil.ts +1 -2
  82. package/Server/Utils/Monitor/MonitorMetricUtil.ts +3 -4
  83. package/Server/Utils/PrivacyFilterUtil.ts +72 -0
  84. package/Server/Utils/Profile/PprofEncoder.ts +135 -11
  85. package/Server/Utils/Telemetry/EntityRegistry.ts +316 -0
  86. package/Server/Utils/Telemetry/ResourceFacetResolver.ts +9 -3
  87. package/Server/Utils/Telemetry/TelemetryEntity.ts +783 -0
  88. package/Tests/Server/Services/AnalyticsDatabaseService.test.ts +79 -4
  89. package/Tests/Server/Services/LogAggregationService.test.ts +7 -2
  90. package/Tests/Server/Services/ProfileAggregationService.test.ts +280 -0
  91. package/Tests/Server/Services/ProfileBreakdown.test.ts +161 -0
  92. package/Tests/Server/Services/ProfileFunctionFocus.test.ts +349 -0
  93. package/Tests/Server/Services/TelemetryAttributeService.test.ts +1 -1
  94. package/Tests/Server/Services/TraceAggregationService.test.ts +403 -0
  95. package/Tests/Server/Types/AnalyticsDatabase/ModelPermissionOwnedScope.test.ts +114 -0
  96. package/Tests/Server/Types/Database/Permissions/AccessControlPermission.test.ts +189 -0
  97. package/Tests/Server/Types/Database/Permissions/BasePermission.test.ts +118 -0
  98. package/Tests/Server/Types/Database/Permissions/OwnedScopePermission.test.ts +159 -0
  99. package/Tests/Server/Utils/AnalyticsDatabase/StatementGenerator.test.ts +275 -8
  100. package/Tests/Server/Utils/PrivacyFilterUtil.test.ts +177 -0
  101. package/Tests/Server/Utils/Profile/PprofEncoder.test.ts +276 -0
  102. package/Tests/Server/Utils/Telemetry/TelemetryEntity.test.ts +761 -0
  103. package/Tests/Types/Monitor/MonitorStepEntityScope.test.ts +275 -0
  104. package/Tests/Types/Text.test.ts +52 -0
  105. package/Tests/Utils/Telemetry/EntityKey.test.ts +150 -0
  106. package/Tests/Utils/Telemetry/EntityKeySqlParity.test.ts +40 -0
  107. package/Tests/Utils/Telemetry/EntityRelationship.test.ts +150 -0
  108. package/Tests/Utils/UUID.test.ts +47 -0
  109. package/Types/AnalyticsDatabase/AnalyticsTableName.ts +14 -9
  110. package/Types/AnalyticsDatabase/TableColumnType.ts +1 -0
  111. package/Types/Dashboard/DashboardComponentType.ts +1 -0
  112. package/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.ts +37 -0
  113. package/Types/Dashboard/DashboardTemplates.ts +4 -5
  114. package/Types/Log/LogQueryParser.ts +2 -2
  115. package/Types/Log/LogQueryToFilter.ts +2 -2
  116. package/Types/Monitor/MonitorStepExceptionMonitor.ts +19 -1
  117. package/Types/Monitor/MonitorStepLogMonitor.ts +20 -1
  118. package/Types/Monitor/MonitorStepMetricMonitor.ts +27 -0
  119. package/Types/Monitor/MonitorStepProfileMonitor.ts +19 -1
  120. package/Types/Monitor/MonitorStepTraceMonitor.ts +18 -1
  121. package/Types/Monitor/MonitorType.ts +8 -1
  122. package/Types/ObjectID.ts +10 -0
  123. package/Types/Permission.ts +4 -2
  124. package/Types/Telemetry/EntityRelationshipType.ts +31 -0
  125. package/Types/Telemetry/EntityType.ts +33 -0
  126. package/Types/Telemetry/TelemetrySavedViewState.ts +2 -0
  127. package/Types/Text.ts +34 -0
  128. package/Types/Trace/TraceAggregationType.ts +1 -0
  129. package/Types/Trace/TraceRecordingRuleDefinition.ts +74 -0
  130. package/UI/Components/BulkUpdate/BulkLabelActions.tsx +14 -14
  131. package/UI/Components/Forms/Fields/FormField.tsx +18 -12
  132. package/UI/Components/Input/Input.tsx +3 -1
  133. package/UI/Components/LogsViewer/LogsViewer.tsx +12 -9
  134. package/UI/Components/LogsViewer/components/LogDetailsPanel.tsx +10 -9
  135. package/UI/Components/LogsViewer/components/LogSearchBar.tsx +1 -1
  136. package/UI/Components/LogsViewer/components/LogsAnalyticsView.tsx +2 -2
  137. package/UI/Components/LogsViewer/components/LogsFacetSidebar.tsx +4 -4
  138. package/UI/Components/LogsViewer/components/LogsTable.tsx +5 -3
  139. package/UI/Components/Navbar/NavBarMenuModal.tsx +81 -44
  140. package/UI/Components/TelemetryViewer/TelemetryViewer.tsx +33 -10
  141. package/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.tsx +18 -3
  142. package/UI/Components/TelemetryViewer/components/TelemetryHistogram.tsx +91 -68
  143. package/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.tsx +9 -2
  144. package/UI/Components/TextArea/TextArea.tsx +3 -1
  145. package/UI/Components/Toast/Toast.tsx +4 -2
  146. package/UI/Utils/LogExport.ts +2 -2
  147. package/UI/Utils/TelemetryService.ts +20 -20
  148. package/Utils/Dashboard/Components/DashboardTraceChartComponent.ts +134 -0
  149. package/Utils/Dashboard/Components/Index.ts +7 -0
  150. package/Utils/Telemetry/EntityKey.ts +151 -0
  151. package/Utils/Telemetry/EntityRelationship.ts +113 -0
  152. package/Utils/Traces/CriticalPath.ts +7 -7
  153. package/Utils/UUID.ts +57 -0
  154. package/build/dist/Models/AnalyticsModels/AnalyticsBaseModel/AnalyticsBaseModel.js +14 -13
  155. package/build/dist/Models/AnalyticsModels/AnalyticsBaseModel/AnalyticsBaseModel.js.map +1 -1
  156. package/build/dist/Models/AnalyticsModels/AuditLog.js +2 -1
  157. package/build/dist/Models/AnalyticsModels/AuditLog.js.map +1 -1
  158. package/build/dist/Models/AnalyticsModels/ExceptionInstance.js +125 -22
  159. package/build/dist/Models/AnalyticsModels/ExceptionInstance.js.map +1 -1
  160. package/build/dist/Models/AnalyticsModels/Index.js +7 -2
  161. package/build/dist/Models/AnalyticsModels/Index.js.map +1 -1
  162. package/build/dist/Models/AnalyticsModels/Log.js +123 -22
  163. package/build/dist/Models/AnalyticsModels/Log.js.map +1 -1
  164. package/build/dist/Models/AnalyticsModels/Metric.js +125 -27
  165. package/build/dist/Models/AnalyticsModels/Metric.js.map +1 -1
  166. package/build/dist/Models/AnalyticsModels/MetricBaselineHourly.js +38 -21
  167. package/build/dist/Models/AnalyticsModels/MetricBaselineHourly.js.map +1 -1
  168. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1m.js +17 -16
  169. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1m.js.map +1 -1
  170. package/build/dist/Models/AnalyticsModels/{MetricItemAggMV1mByHost.js → MetricItemAggMV1mByHostV2.js} +54 -42
  171. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1mByHostV2.js.map +1 -0
  172. package/build/dist/Models/AnalyticsModels/MonitorLog.js +4 -1
  173. package/build/dist/Models/AnalyticsModels/MonitorLog.js.map +1 -1
  174. package/build/dist/Models/AnalyticsModels/Profile.js +132 -26
  175. package/build/dist/Models/AnalyticsModels/Profile.js.map +1 -1
  176. package/build/dist/Models/AnalyticsModels/ProfileSample.js +121 -23
  177. package/build/dist/Models/AnalyticsModels/ProfileSample.js.map +1 -1
  178. package/build/dist/Models/AnalyticsModels/Span.js +144 -26
  179. package/build/dist/Models/AnalyticsModels/Span.js.map +1 -1
  180. package/build/dist/Models/DatabaseModels/CloudResourceInstance.js.map +1 -1
  181. package/build/dist/Models/DatabaseModels/CloudResourceOwnerTeam.js.map +1 -1
  182. package/build/dist/Models/DatabaseModels/CloudResourceOwnerUser.js.map +1 -1
  183. package/build/dist/Models/DatabaseModels/Index.js +4 -0
  184. package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
  185. package/build/dist/Models/DatabaseModels/Service.js +30 -0
  186. package/build/dist/Models/DatabaseModels/Service.js.map +1 -1
  187. package/build/dist/Models/DatabaseModels/TelemetryEntity.js +419 -0
  188. package/build/dist/Models/DatabaseModels/TelemetryEntity.js.map +1 -0
  189. package/build/dist/Models/DatabaseModels/TelemetryEntityRelationship.js +317 -0
  190. package/build/dist/Models/DatabaseModels/TelemetryEntityRelationship.js.map +1 -0
  191. package/build/dist/Models/DatabaseModels/TelemetryException.js +12 -12
  192. package/build/dist/Models/DatabaseModels/TelemetryException.js.map +1 -1
  193. package/build/dist/Models/DatabaseModels/TelemetryUsageBilling.js +7 -7
  194. package/build/dist/Models/DatabaseModels/TelemetryUsageBilling.js.map +1 -1
  195. package/build/dist/Server/API/AIAgentDataAPI.js +14 -13
  196. package/build/dist/Server/API/AIAgentDataAPI.js.map +1 -1
  197. package/build/dist/Server/API/DashboardAPI.js +2 -2
  198. package/build/dist/Server/API/DashboardAPI.js.map +1 -1
  199. package/build/dist/Server/API/TelemetryAPI.js +425 -129
  200. package/build/dist/Server/API/TelemetryAPI.js.map +1 -1
  201. package/build/dist/Server/API/TelemetryExceptionAPI.js +2 -2
  202. package/build/dist/Server/API/TelemetryExceptionAPI.js.map +1 -1
  203. package/build/dist/Server/Infrastructure/ClickhouseConfig.js +12 -0
  204. package/build/dist/Server/Infrastructure/ClickhouseConfig.js.map +1 -1
  205. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780931863719-AddTelemetryResourceMetadataColumns.js.map +1 -1
  206. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780933132562-AddServerlessFunctionTables.js.map +1 -1
  207. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780935387827-AddCloudResourceTables.js.map +1 -1
  208. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781011482945-MigrationName.js +798 -0
  209. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781011482945-MigrationName.js.map +1 -0
  210. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781100000001-RenameTelemetryServiceIdToPrimaryEntityId.js +29 -0
  211. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781100000001-RenameTelemetryServiceIdToPrimaryEntityId.js.map +1 -0
  212. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000000-AddTelemetryEntityTable.js +38 -0
  213. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000000-AddTelemetryEntityTable.js.map +1 -0
  214. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000001-AddTelemetryEntityRelationshipTable.js +33 -0
  215. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000001-AddTelemetryEntityRelationshipTable.js.map +1 -0
  216. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781250074195-MigrationName.js +78 -0
  217. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781250074195-MigrationName.js.map +1 -0
  218. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781300000000-AddTelemetryEntityLabels.js +19 -0
  219. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781300000000-AddTelemetryEntityLabels.js.map +1 -0
  220. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781400000000-AddServiceTelemetrySdkLanguage.js +18 -0
  221. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781400000000-AddServiceTelemetrySdkLanguage.js.map +1 -0
  222. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +14 -0
  223. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
  224. package/build/dist/Server/Infrastructure/Queue.js +14 -3
  225. package/build/dist/Server/Infrastructure/Queue.js.map +1 -1
  226. package/build/dist/Server/Middleware/TelemetryIngest.js +16 -18
  227. package/build/dist/Server/Middleware/TelemetryIngest.js.map +1 -1
  228. package/build/dist/Server/Services/AlertService.js +9 -9
  229. package/build/dist/Server/Services/AlertService.js.map +1 -1
  230. package/build/dist/Server/Services/AnalyticsDatabaseService.js +115 -40
  231. package/build/dist/Server/Services/AnalyticsDatabaseService.js.map +1 -1
  232. package/build/dist/Server/Services/CloudResourceLabelRuleEngineService.js.map +1 -1
  233. package/build/dist/Server/Services/CloudResourceOwnerRuleEngineService.js.map +1 -1
  234. package/build/dist/Server/Services/ExceptionAggregationService.js +38 -18
  235. package/build/dist/Server/Services/ExceptionAggregationService.js.map +1 -1
  236. package/build/dist/Server/Services/HostService.js +2 -1
  237. package/build/dist/Server/Services/HostService.js.map +1 -1
  238. package/build/dist/Server/Services/IncidentService.js +19 -19
  239. package/build/dist/Server/Services/IncidentService.js.map +1 -1
  240. package/build/dist/Server/Services/Index.js +6 -2
  241. package/build/dist/Server/Services/Index.js.map +1 -1
  242. package/build/dist/Server/Services/LogAggregationService.js +100 -42
  243. package/build/dist/Server/Services/LogAggregationService.js.map +1 -1
  244. package/build/dist/Server/Services/MetricAggregationService.js +27 -14
  245. package/build/dist/Server/Services/MetricAggregationService.js.map +1 -1
  246. package/build/dist/Server/Services/MetricBaselineService.js +28 -28
  247. package/build/dist/Server/Services/MetricBaselineService.js.map +1 -1
  248. package/build/dist/Server/Services/MetricItemAggMV1mByHostV2Service.js +28 -0
  249. package/build/dist/Server/Services/MetricItemAggMV1mByHostV2Service.js.map +1 -0
  250. package/build/dist/Server/Services/MetricService.js +116 -31
  251. package/build/dist/Server/Services/MetricService.js.map +1 -1
  252. package/build/dist/Server/Services/OpenTelemetryIngestService.js +103 -36
  253. package/build/dist/Server/Services/OpenTelemetryIngestService.js.map +1 -1
  254. package/build/dist/Server/Services/ProfileAggregationService.js +613 -105
  255. package/build/dist/Server/Services/ProfileAggregationService.js.map +1 -1
  256. package/build/dist/Server/Services/RumApplicationLabelRuleEngineService.js.map +1 -1
  257. package/build/dist/Server/Services/RumApplicationOwnerRuleEngineService.js.map +1 -1
  258. package/build/dist/Server/Services/ServerlessFunctionInstanceService.js +4 -2
  259. package/build/dist/Server/Services/ServerlessFunctionInstanceService.js.map +1 -1
  260. package/build/dist/Server/Services/ServerlessFunctionLabelRuleEngineService.js +2 -1
  261. package/build/dist/Server/Services/ServerlessFunctionLabelRuleEngineService.js.map +1 -1
  262. package/build/dist/Server/Services/ServerlessFunctionOwnerRuleEngineService.js +2 -1
  263. package/build/dist/Server/Services/ServerlessFunctionOwnerRuleEngineService.js.map +1 -1
  264. package/build/dist/Server/Services/ServiceService.js +9 -5
  265. package/build/dist/Server/Services/ServiceService.js.map +1 -1
  266. package/build/dist/Server/Services/SpanService.js +217 -15
  267. package/build/dist/Server/Services/SpanService.js.map +1 -1
  268. package/build/dist/Server/Services/TelemetryEntityRelationshipService.js +72 -0
  269. package/build/dist/Server/Services/TelemetryEntityRelationshipService.js.map +1 -0
  270. package/build/dist/Server/Services/TelemetryEntityService.js +201 -0
  271. package/build/dist/Server/Services/TelemetryEntityService.js.map +1 -0
  272. package/build/dist/Server/Services/TelemetryExceptionService.js +18 -18
  273. package/build/dist/Server/Services/TelemetryExceptionService.js.map +1 -1
  274. package/build/dist/Server/Services/TelemetryUsageBillingService.js +27 -21
  275. package/build/dist/Server/Services/TelemetryUsageBillingService.js.map +1 -1
  276. package/build/dist/Server/Services/TraceAggregationService.js +568 -43
  277. package/build/dist/Server/Services/TraceAggregationService.js.map +1 -1
  278. package/build/dist/Server/Types/AnalyticsDatabase/ModelPermission.js +38 -2
  279. package/build/dist/Server/Types/AnalyticsDatabase/ModelPermission.js.map +1 -1
  280. package/build/dist/Server/Types/Database/Permissions/AccessControlPermission.js +36 -2
  281. package/build/dist/Server/Types/Database/Permissions/AccessControlPermission.js.map +1 -1
  282. package/build/dist/Server/Types/Database/Permissions/BasePermission.js +25 -1
  283. package/build/dist/Server/Types/Database/Permissions/BasePermission.js.map +1 -1
  284. package/build/dist/Server/Types/Database/Permissions/OwnedScopePermission.js +17 -3
  285. package/build/dist/Server/Types/Database/Permissions/OwnedScopePermission.js.map +1 -1
  286. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js +1 -0
  287. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js.map +1 -1
  288. package/build/dist/Server/Types/Database/QueryHelper.js +31 -0
  289. package/build/dist/Server/Types/Database/QueryHelper.js.map +1 -1
  290. package/build/dist/Server/Utils/Alert/AlertPrivacyFilter.js +3 -2
  291. package/build/dist/Server/Utils/Alert/AlertPrivacyFilter.js.map +1 -1
  292. package/build/dist/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.js +3 -2
  293. package/build/dist/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.js.map +1 -1
  294. package/build/dist/Server/Utils/AnalyticsDatabase/QuerySettingsHelper.js +46 -0
  295. package/build/dist/Server/Utils/AnalyticsDatabase/QuerySettingsHelper.js.map +1 -0
  296. package/build/dist/Server/Utils/AnalyticsDatabase/StatementGenerator.js +97 -3
  297. package/build/dist/Server/Utils/AnalyticsDatabase/StatementGenerator.js.map +1 -1
  298. package/build/dist/Server/Utils/Incident/IncidentPrivacyFilter.js +3 -2
  299. package/build/dist/Server/Utils/Incident/IncidentPrivacyFilter.js.map +1 -1
  300. package/build/dist/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.js +3 -2
  301. package/build/dist/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.js.map +1 -1
  302. package/build/dist/Server/Utils/Monitor/Criteria/EvaluateOverTime.js +1 -1
  303. package/build/dist/Server/Utils/Monitor/Criteria/EvaluateOverTime.js.map +1 -1
  304. package/build/dist/Server/Utils/Monitor/MonitorLogUtil.js +1 -2
  305. package/build/dist/Server/Utils/Monitor/MonitorLogUtil.js.map +1 -1
  306. package/build/dist/Server/Utils/Monitor/MonitorMetricUtil.js +3 -4
  307. package/build/dist/Server/Utils/Monitor/MonitorMetricUtil.js.map +1 -1
  308. package/build/dist/Server/Utils/PrivacyFilterUtil.js +47 -0
  309. package/build/dist/Server/Utils/PrivacyFilterUtil.js.map +1 -0
  310. package/build/dist/Server/Utils/Profile/PprofEncoder.js +132 -4
  311. package/build/dist/Server/Utils/Profile/PprofEncoder.js.map +1 -1
  312. package/build/dist/Server/Utils/Telemetry/EntityRegistry.js +228 -0
  313. package/build/dist/Server/Utils/Telemetry/EntityRegistry.js.map +1 -0
  314. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js +5 -0
  315. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js.map +1 -1
  316. package/build/dist/Server/Utils/Telemetry/TelemetryEntity.js +569 -0
  317. package/build/dist/Server/Utils/Telemetry/TelemetryEntity.js.map +1 -0
  318. package/build/dist/Types/AnalyticsDatabase/AnalyticsTableName.js +14 -9
  319. package/build/dist/Types/AnalyticsDatabase/AnalyticsTableName.js.map +1 -1
  320. package/build/dist/Types/AnalyticsDatabase/TableColumnType.js +1 -0
  321. package/build/dist/Types/AnalyticsDatabase/TableColumnType.js.map +1 -1
  322. package/build/dist/Types/Dashboard/DashboardComponentType.js +1 -0
  323. package/build/dist/Types/Dashboard/DashboardComponentType.js.map +1 -1
  324. package/build/dist/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.js +2 -0
  325. package/build/dist/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.js.map +1 -0
  326. package/build/dist/Types/Dashboard/DashboardTemplates.js +4 -5
  327. package/build/dist/Types/Dashboard/DashboardTemplates.js.map +1 -1
  328. package/build/dist/Types/Log/LogQueryParser.js +2 -2
  329. package/build/dist/Types/Log/LogQueryParser.js.map +1 -1
  330. package/build/dist/Types/Log/LogQueryToFilter.js +1 -1
  331. package/build/dist/Types/Log/LogQueryToFilter.js.map +1 -1
  332. package/build/dist/Types/Monitor/MonitorStepExceptionMonitor.js +9 -1
  333. package/build/dist/Types/Monitor/MonitorStepExceptionMonitor.js.map +1 -1
  334. package/build/dist/Types/Monitor/MonitorStepLogMonitor.js +9 -1
  335. package/build/dist/Types/Monitor/MonitorStepLogMonitor.js.map +1 -1
  336. package/build/dist/Types/Monitor/MonitorStepMetricMonitor.js +13 -0
  337. package/build/dist/Types/Monitor/MonitorStepMetricMonitor.js.map +1 -1
  338. package/build/dist/Types/Monitor/MonitorStepProfileMonitor.js +9 -1
  339. package/build/dist/Types/Monitor/MonitorStepProfileMonitor.js.map +1 -1
  340. package/build/dist/Types/Monitor/MonitorStepTraceMonitor.js +9 -1
  341. package/build/dist/Types/Monitor/MonitorStepTraceMonitor.js.map +1 -1
  342. package/build/dist/Types/Monitor/MonitorType.js +8 -1
  343. package/build/dist/Types/Monitor/MonitorType.js.map +1 -1
  344. package/build/dist/Types/ObjectID.js +9 -0
  345. package/build/dist/Types/ObjectID.js.map +1 -1
  346. package/build/dist/Types/Permission.js.map +1 -1
  347. package/build/dist/Types/Telemetry/EntityRelationshipType.js +32 -0
  348. package/build/dist/Types/Telemetry/EntityRelationshipType.js.map +1 -0
  349. package/build/dist/Types/Telemetry/EntityType.js +34 -0
  350. package/build/dist/Types/Telemetry/EntityType.js.map +1 -0
  351. package/build/dist/Types/Text.js +32 -1
  352. package/build/dist/Types/Text.js.map +1 -1
  353. package/build/dist/Types/Trace/TraceAggregationType.js +1 -0
  354. package/build/dist/Types/Trace/TraceAggregationType.js.map +1 -1
  355. package/build/dist/Types/Trace/TraceRecordingRuleDefinition.js +50 -1
  356. package/build/dist/Types/Trace/TraceRecordingRuleDefinition.js.map +1 -1
  357. package/build/dist/UI/Components/BulkUpdate/BulkLabelActions.js.map +1 -1
  358. package/build/dist/UI/Components/Forms/Fields/FormField.js +15 -12
  359. package/build/dist/UI/Components/Forms/Fields/FormField.js.map +1 -1
  360. package/build/dist/UI/Components/Input/Input.js +3 -1
  361. package/build/dist/UI/Components/Input/Input.js.map +1 -1
  362. package/build/dist/UI/Components/LogsViewer/LogsViewer.js +10 -9
  363. package/build/dist/UI/Components/LogsViewer/LogsViewer.js.map +1 -1
  364. package/build/dist/UI/Components/LogsViewer/components/LogDetailsPanel.js +8 -8
  365. package/build/dist/UI/Components/LogsViewer/components/LogDetailsPanel.js.map +1 -1
  366. package/build/dist/UI/Components/LogsViewer/components/LogSearchBar.js +1 -1
  367. package/build/dist/UI/Components/LogsViewer/components/LogSearchBar.js.map +1 -1
  368. package/build/dist/UI/Components/LogsViewer/components/LogsAnalyticsView.js +2 -2
  369. package/build/dist/UI/Components/LogsViewer/components/LogsAnalyticsView.js.map +1 -1
  370. package/build/dist/UI/Components/LogsViewer/components/LogsFacetSidebar.js +4 -4
  371. package/build/dist/UI/Components/LogsViewer/components/LogsFacetSidebar.js.map +1 -1
  372. package/build/dist/UI/Components/LogsViewer/components/LogsTable.js +3 -3
  373. package/build/dist/UI/Components/LogsViewer/components/LogsTable.js.map +1 -1
  374. package/build/dist/UI/Components/Navbar/NavBarMenuModal.js +43 -30
  375. package/build/dist/UI/Components/Navbar/NavBarMenuModal.js.map +1 -1
  376. package/build/dist/UI/Components/TelemetryViewer/TelemetryViewer.js +6 -2
  377. package/build/dist/UI/Components/TelemetryViewer/TelemetryViewer.js.map +1 -1
  378. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.js +14 -3
  379. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.js.map +1 -1
  380. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogram.js +18 -10
  381. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogram.js.map +1 -1
  382. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.js +4 -2
  383. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.js.map +1 -1
  384. package/build/dist/UI/Components/TextArea/TextArea.js +3 -1
  385. package/build/dist/UI/Components/TextArea/TextArea.js.map +1 -1
  386. package/build/dist/UI/Components/Toast/Toast.js +4 -2
  387. package/build/dist/UI/Components/Toast/Toast.js.map +1 -1
  388. package/build/dist/UI/Utils/LogExport.js +2 -2
  389. package/build/dist/UI/Utils/LogExport.js.map +1 -1
  390. package/build/dist/UI/Utils/TelemetryService.js +16 -16
  391. package/build/dist/UI/Utils/TelemetryService.js.map +1 -1
  392. package/build/dist/Utils/Dashboard/Components/DashboardTraceChartComponent.js +110 -0
  393. package/build/dist/Utils/Dashboard/Components/DashboardTraceChartComponent.js.map +1 -0
  394. package/build/dist/Utils/Dashboard/Components/Index.js +4 -0
  395. package/build/dist/Utils/Dashboard/Components/Index.js.map +1 -1
  396. package/build/dist/Utils/Telemetry/EntityKey.js +115 -0
  397. package/build/dist/Utils/Telemetry/EntityKey.js.map +1 -0
  398. package/build/dist/Utils/Telemetry/EntityRelationship.js +71 -0
  399. package/build/dist/Utils/Telemetry/EntityRelationship.js.map +1 -0
  400. package/build/dist/Utils/Traces/CriticalPath.js +5 -5
  401. package/build/dist/Utils/Traces/CriticalPath.js.map +1 -1
  402. package/build/dist/Utils/UUID.js +50 -0
  403. package/build/dist/Utils/UUID.js.map +1 -1
  404. package/package.json +2 -1
  405. package/tsconfig.json +10 -1
  406. package/Server/Services/MetricItemAggMV1mByHostService.ts +0 -30
  407. package/Types/Profile/ProfileMetricType.ts +0 -16
  408. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1mByHost.js.map +0 -1
  409. package/build/dist/Server/Services/MetricItemAggMV1mByHostService.js +0 -28
  410. package/build/dist/Server/Services/MetricItemAggMV1mByHostService.js.map +0 -1
  411. package/build/dist/Tests/MockType.js +0 -5
  412. package/build/dist/Tests/MockType.js.map +0 -1
  413. package/build/dist/Tests/Models/AnalyticsModels/Log.test.js +0 -12
  414. package/build/dist/Tests/Models/AnalyticsModels/Log.test.js.map +0 -1
  415. package/build/dist/Tests/Models/File.test.js +0 -10
  416. package/build/dist/Tests/Models/File.test.js.map +0 -1
  417. package/build/dist/Tests/Server/API/BaseAPI.test.js +0 -590
  418. package/build/dist/Tests/Server/API/BaseAPI.test.js.map +0 -1
  419. package/build/dist/Tests/Server/API/Helpers.js +0 -27
  420. package/build/dist/Tests/Server/API/Helpers.js.map +0 -1
  421. package/build/dist/Tests/Server/API/ProbeAPI.test.js +0 -84
  422. package/build/dist/Tests/Server/API/ProbeAPI.test.js.map +0 -1
  423. package/build/dist/Tests/Server/API/ProjectAPI.test.js +0 -170
  424. package/build/dist/Tests/Server/API/ProjectAPI.test.js.map +0 -1
  425. package/build/dist/Tests/Server/API/UserSmsApi.test.js +0 -177
  426. package/build/dist/Tests/Server/API/UserSmsApi.test.js.map +0 -1
  427. package/build/dist/Tests/Server/Middleware/BearerTokenAuthorization.test.js +0 -63
  428. package/build/dist/Tests/Server/Middleware/BearerTokenAuthorization.test.js.map +0 -1
  429. package/build/dist/Tests/Server/Middleware/ClusterKeyAuthorization.test.js +0 -58
  430. package/build/dist/Tests/Server/Middleware/ClusterKeyAuthorization.test.js.map +0 -1
  431. package/build/dist/Tests/Server/Middleware/NotificationMiddleware.test.js +0 -101
  432. package/build/dist/Tests/Server/Middleware/NotificationMiddleware.test.js.map +0 -1
  433. package/build/dist/Tests/Server/Middleware/ProjectAuthorization.test.js +0 -160
  434. package/build/dist/Tests/Server/Middleware/ProjectAuthorization.test.js.map +0 -1
  435. package/build/dist/Tests/Server/Middleware/UserAuthorization.test.js +0 -410
  436. package/build/dist/Tests/Server/Middleware/UserAuthorization.test.js.map +0 -1
  437. package/build/dist/Tests/Server/Services/AlertEpisodeMemberService.test.js +0 -165
  438. package/build/dist/Tests/Server/Services/AlertEpisodeMemberService.test.js.map +0 -1
  439. package/build/dist/Tests/Server/Services/AlertEpisodeService.test.js +0 -193
  440. package/build/dist/Tests/Server/Services/AlertEpisodeService.test.js.map +0 -1
  441. package/build/dist/Tests/Server/Services/AlertGroupingEngineService.test.js +0 -435
  442. package/build/dist/Tests/Server/Services/AlertGroupingEngineService.test.js.map +0 -1
  443. package/build/dist/Tests/Server/Services/AlertGroupingRuleService.test.js +0 -320
  444. package/build/dist/Tests/Server/Services/AlertGroupingRuleService.test.js.map +0 -1
  445. package/build/dist/Tests/Server/Services/AnalyticsDatabaseService.test.js +0 -266
  446. package/build/dist/Tests/Server/Services/AnalyticsDatabaseService.test.js.map +0 -1
  447. package/build/dist/Tests/Server/Services/BillingService.test.js +0 -910
  448. package/build/dist/Tests/Server/Services/BillingService.test.js.map +0 -1
  449. package/build/dist/Tests/Server/Services/LogAggregationService.test.js +0 -75
  450. package/build/dist/Tests/Server/Services/LogAggregationService.test.js.map +0 -1
  451. package/build/dist/Tests/Server/Services/ProbeService.test.js +0 -127
  452. package/build/dist/Tests/Server/Services/ProbeService.test.js.map +0 -1
  453. package/build/dist/Tests/Server/Services/ScheduledMaintenanceService.test.js +0 -114
  454. package/build/dist/Tests/Server/Services/ScheduledMaintenanceService.test.js.map +0 -1
  455. package/build/dist/Tests/Server/Services/TeamMemberService.test.js +0 -106
  456. package/build/dist/Tests/Server/Services/TeamMemberService.test.js.map +0 -1
  457. package/build/dist/Tests/Server/Services/TelemetryAttributeService.test.js +0 -50
  458. package/build/dist/Tests/Server/Services/TelemetryAttributeService.test.js.map +0 -1
  459. package/build/dist/Tests/Server/TestingUtils/Init.js +0 -4
  460. package/build/dist/Tests/Server/TestingUtils/Init.js.map +0 -1
  461. package/build/dist/Tests/Server/TestingUtils/Postgres/TestDataSourceOptions.js +0 -9
  462. package/build/dist/Tests/Server/TestingUtils/Postgres/TestDataSourceOptions.js.map +0 -1
  463. package/build/dist/Tests/Server/TestingUtils/Redis/TestRedisOptions.js +0 -16
  464. package/build/dist/Tests/Server/TestingUtils/Redis/TestRedisOptions.js.map +0 -1
  465. package/build/dist/Tests/Server/TestingUtils/Services/BillingServiceHelper.js +0 -125
  466. package/build/dist/Tests/Server/TestingUtils/Services/BillingServiceHelper.js.map +0 -1
  467. package/build/dist/Tests/Server/TestingUtils/Services/ProjectServiceHelper.js +0 -39
  468. package/build/dist/Tests/Server/TestingUtils/Services/ProjectServiceHelper.js.map +0 -1
  469. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceServiceHelper.js +0 -20
  470. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceServiceHelper.js.map +0 -1
  471. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceStateServiceHelper.js +0 -31
  472. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceStateServiceHelper.js.map +0 -1
  473. package/build/dist/Tests/Server/TestingUtils/Services/TeamMemberServiceHelper.js +0 -14
  474. package/build/dist/Tests/Server/TestingUtils/Services/TeamMemberServiceHelper.js.map +0 -1
  475. package/build/dist/Tests/Server/TestingUtils/Services/TeamServiceHelper.js +0 -21
  476. package/build/dist/Tests/Server/TestingUtils/Services/TeamServiceHelper.js.map +0 -1
  477. package/build/dist/Tests/Server/TestingUtils/Services/Types.js +0 -2
  478. package/build/dist/Tests/Server/TestingUtils/Services/Types.js.map +0 -1
  479. package/build/dist/Tests/Server/TestingUtils/Services/UserServiceHelper.js +0 -37
  480. package/build/dist/Tests/Server/TestingUtils/Services/UserServiceHelper.js.map +0 -1
  481. package/build/dist/Tests/Server/TestingUtils/__mocks__/Stripe.mock.js +0 -13
  482. package/build/dist/Tests/Server/TestingUtils/__mocks__/Stripe.mock.js.map +0 -1
  483. package/build/dist/Tests/Server/TestingUtils/__mocks__/TestDatabase.mock.js +0 -22
  484. package/build/dist/Tests/Server/TestingUtils/__mocks__/TestDatabase.mock.js.map +0 -1
  485. package/build/dist/Tests/Server/Types/Domain.test.js +0 -78
  486. package/build/dist/Tests/Server/Types/Domain.test.js.map +0 -1
  487. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/Statement.test.js +0 -94
  488. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/Statement.test.js.map +0 -1
  489. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/StatementGenerator.test.js +0 -459
  490. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/StatementGenerator.test.js.map +0 -1
  491. package/build/dist/Tests/Server/Utils/Cookie.test.js +0 -83
  492. package/build/dist/Tests/Server/Utils/Cookie.test.js.map +0 -1
  493. package/build/dist/Tests/Server/Utils/CronTab.test.js +0 -29
  494. package/build/dist/Tests/Server/Utils/CronTab.test.js.map +0 -1
  495. package/build/dist/Tests/Server/Utils/JsonToCsv.test.js +0 -114
  496. package/build/dist/Tests/Server/Utils/JsonToCsv.test.js.map +0 -1
  497. package/build/dist/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.js +0 -606
  498. package/build/dist/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.js.map +0 -1
  499. package/build/dist/Tests/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.test.js +0 -255
  500. package/build/dist/Tests/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.test.js.map +0 -1
  501. package/build/dist/Tests/Server/Utils/Monitor/MonitorMaintenanceSuppression.test.js +0 -142
  502. package/build/dist/Tests/Server/Utils/Monitor/MonitorMaintenanceSuppression.test.js.map +0 -1
  503. package/build/dist/Tests/Server/Utils/StatusPageResource.test.js +0 -122
  504. package/build/dist/Tests/Server/Utils/StatusPageResource.test.js.map +0 -1
  505. package/build/dist/Tests/Server/Utils/Telemetry/LogExceptionExtractor.test.js +0 -0
  506. package/build/dist/Tests/Server/Utils/Telemetry/LogExceptionExtractor.test.js.map +0 -1
  507. package/build/dist/Tests/Server/Utils/VM/VMAPI.test.js +0 -205
  508. package/build/dist/Tests/Server/Utils/VM/VMAPI.test.js.map +0 -1
  509. package/build/dist/Tests/Spy.js +0 -4
  510. package/build/dist/Tests/Spy.js.map +0 -1
  511. package/build/dist/Tests/Types/API/ErrorResponse.test.js +0 -13
  512. package/build/dist/Tests/Types/API/ErrorResponse.test.js.map +0 -1
  513. package/build/dist/Tests/Types/API/HTTPErrorResponse.test.js +0 -33
  514. package/build/dist/Tests/Types/API/HTTPErrorResponse.test.js.map +0 -1
  515. package/build/dist/Tests/Types/API/HTTPMethod.test.js +0 -16
  516. package/build/dist/Tests/Types/API/HTTPMethod.test.js.map +0 -1
  517. package/build/dist/Tests/Types/API/Headers.test.js +0 -14
  518. package/build/dist/Tests/Types/API/Headers.test.js.map +0 -1
  519. package/build/dist/Tests/Types/API/Hostname.test.js +0 -22
  520. package/build/dist/Tests/Types/API/Hostname.test.js.map +0 -1
  521. package/build/dist/Tests/Types/API/Protocal.test.js +0 -19
  522. package/build/dist/Tests/Types/API/Protocal.test.js.map +0 -1
  523. package/build/dist/Tests/Types/API/Response.test.js +0 -14
  524. package/build/dist/Tests/Types/API/Response.test.js.map +0 -1
  525. package/build/dist/Tests/Types/API/ResponseType.test.js +0 -13
  526. package/build/dist/Tests/Types/API/ResponseType.test.js.map +0 -1
  527. package/build/dist/Tests/Types/API/Route.test.js +0 -30
  528. package/build/dist/Tests/Types/API/Route.test.js.map +0 -1
  529. package/build/dist/Tests/Types/API/StatusCode.test.js +0 -26
  530. package/build/dist/Tests/Types/API/StatusCode.test.js.map +0 -1
  531. package/build/dist/Tests/Types/API/URL.test.js +0 -33
  532. package/build/dist/Tests/Types/API/URL.test.js.map +0 -1
  533. package/build/dist/Tests/Types/Alerts/AlertEventType.test.js +0 -34
  534. package/build/dist/Tests/Types/Alerts/AlertEventType.test.js.map +0 -1
  535. package/build/dist/Tests/Types/Alerts/AlertType.test.js +0 -19
  536. package/build/dist/Tests/Types/Alerts/AlertType.test.js.map +0 -1
  537. package/build/dist/Tests/Types/AppEnvironment.test.js +0 -13
  538. package/build/dist/Tests/Types/AppEnvironment.test.js.map +0 -1
  539. package/build/dist/Tests/Types/ApplicationLog/ApplicationLogType.test.js +0 -13
  540. package/build/dist/Tests/Types/ApplicationLog/ApplicationLogType.test.js.map +0 -1
  541. package/build/dist/Tests/Types/ArrayUtil.test.js +0 -71
  542. package/build/dist/Tests/Types/ArrayUtil.test.js.map +0 -1
  543. package/build/dist/Tests/Types/Billing/SubscriptionPlan.test.js +0 -181
  544. package/build/dist/Tests/Types/Billing/SubscriptionPlan.test.js.map +0 -1
  545. package/build/dist/Tests/Types/BrandColors.test.js +0 -124
  546. package/build/dist/Tests/Types/BrandColors.test.js.map +0 -1
  547. package/build/dist/Tests/Types/Char.test.js +0 -82
  548. package/build/dist/Tests/Types/Char.test.js.map +0 -1
  549. package/build/dist/Tests/Types/Code/CodeType.test.js +0 -13
  550. package/build/dist/Tests/Types/Code/CodeType.test.js.map +0 -1
  551. package/build/dist/Tests/Types/Color.test.js +0 -44
  552. package/build/dist/Tests/Types/Color.test.js.map +0 -1
  553. package/build/dist/Tests/Types/Company/CompanySize.test.js +0 -20
  554. package/build/dist/Tests/Types/Company/CompanySize.test.js.map +0 -1
  555. package/build/dist/Tests/Types/Company/JobRole.test.js +0 -22
  556. package/build/dist/Tests/Types/Company/JobRole.test.js.map +0 -1
  557. package/build/dist/Tests/Types/Countries.test.js +0 -249
  558. package/build/dist/Tests/Types/Countries.test.js.map +0 -1
  559. package/build/dist/Tests/Types/Database/ColumnLength.test.js +0 -43
  560. package/build/dist/Tests/Types/Database/ColumnLength.test.js.map +0 -1
  561. package/build/dist/Tests/Types/Database/ColumnType.test.js +0 -79
  562. package/build/dist/Tests/Types/Database/ColumnType.test.js.map +0 -1
  563. package/build/dist/Tests/Types/Database/Columns.test.js +0 -20
  564. package/build/dist/Tests/Types/Database/Columns.test.js.map +0 -1
  565. package/build/dist/Tests/Types/Database/CompareBase.test.js +0 -37
  566. package/build/dist/Tests/Types/Database/CompareBase.test.js.map +0 -1
  567. package/build/dist/Tests/Types/Database/Date.test.js +0 -62
  568. package/build/dist/Tests/Types/Database/Date.test.js.map +0 -1
  569. package/build/dist/Tests/Types/Database/EqualTo.test.js +0 -65
  570. package/build/dist/Tests/Types/Database/EqualTo.test.js.map +0 -1
  571. package/build/dist/Tests/Types/Database/EqualToOrNull.test.js +0 -62
  572. package/build/dist/Tests/Types/Database/EqualToOrNull.test.js.map +0 -1
  573. package/build/dist/Tests/Types/Database/InBetween.test.js +0 -72
  574. package/build/dist/Tests/Types/Database/InBetween.test.js.map +0 -1
  575. package/build/dist/Tests/Types/Database/LimitMax.test.js +0 -18
  576. package/build/dist/Tests/Types/Database/LimitMax.test.js.map +0 -1
  577. package/build/dist/Tests/Types/Database/NotEqual.test.js +0 -19
  578. package/build/dist/Tests/Types/Database/NotEqual.test.js.map +0 -1
  579. package/build/dist/Tests/Types/Database/Search.test.js +0 -10
  580. package/build/dist/Tests/Types/Database/Search.test.js.map +0 -1
  581. package/build/dist/Tests/Types/DatabaseType.test.js +0 -7
  582. package/build/dist/Tests/Types/DatabaseType.test.js.map +0 -1
  583. package/build/dist/Tests/Types/Date.test.js +0 -194
  584. package/build/dist/Tests/Types/Date.test.js.map +0 -1
  585. package/build/dist/Tests/Types/Dictionary.test.js +0 -25
  586. package/build/dist/Tests/Types/Dictionary.test.js.map +0 -1
  587. package/build/dist/Tests/Types/Domain.test.js +0 -54
  588. package/build/dist/Tests/Types/Domain.test.js.map +0 -1
  589. package/build/dist/Tests/Types/Email/Email.test.js +0 -51
  590. package/build/dist/Tests/Types/Email/Email.test.js.map +0 -1
  591. package/build/dist/Tests/Types/EmailWithName.test.js +0 -36
  592. package/build/dist/Tests/Types/EmailWithName.test.js.map +0 -1
  593. package/build/dist/Tests/Types/EncryptionAlgorithm.test.js +0 -7
  594. package/build/dist/Tests/Types/EncryptionAlgorithm.test.js.map +0 -1
  595. package/build/dist/Tests/Types/Exception/ApiException.test.js +0 -10
  596. package/build/dist/Tests/Types/Exception/ApiException.test.js.map +0 -1
  597. package/build/dist/Tests/Types/Exception/BadDataException.test.js +0 -12
  598. package/build/dist/Tests/Types/Exception/BadDataException.test.js.map +0 -1
  599. package/build/dist/Tests/Types/Exception/BadOperationException.test.js +0 -10
  600. package/build/dist/Tests/Types/Exception/BadOperationException.test.js.map +0 -1
  601. package/build/dist/Tests/Types/Exception/BadRequestException.test.js +0 -12
  602. package/build/dist/Tests/Types/Exception/BadRequestException.test.js.map +0 -1
  603. package/build/dist/Tests/Types/Exception/DatabaseNotConnectedException.test.js +0 -10
  604. package/build/dist/Tests/Types/Exception/DatabaseNotConnectedException.test.js.map +0 -1
  605. package/build/dist/Tests/Types/Exception/Exception.test.js +0 -15
  606. package/build/dist/Tests/Types/Exception/Exception.test.js.map +0 -1
  607. package/build/dist/Tests/Types/Exception/NotImplementedException.test.js +0 -12
  608. package/build/dist/Tests/Types/Exception/NotImplementedException.test.js.map +0 -1
  609. package/build/dist/Tests/Types/File.test.js +0 -22
  610. package/build/dist/Tests/Types/File.test.js.map +0 -1
  611. package/build/dist/Tests/Types/HashedString.test.js +0 -51
  612. package/build/dist/Tests/Types/HashedString.test.js.map +0 -1
  613. package/build/dist/Tests/Types/Html.test.js +0 -8
  614. package/build/dist/Tests/Types/Html.test.js.map +0 -1
  615. package/build/dist/Tests/Types/IP/IP.test.js +0 -65
  616. package/build/dist/Tests/Types/IP/IP.test.js.map +0 -1
  617. package/build/dist/Tests/Types/IP/IPType.test.js +0 -10
  618. package/build/dist/Tests/Types/IP/IPType.test.js.map +0 -1
  619. package/build/dist/Tests/Types/IP/IPv4.test.js +0 -17
  620. package/build/dist/Tests/Types/IP/IPv4.test.js.map +0 -1
  621. package/build/dist/Tests/Types/IP/IPv6.test.js +0 -17
  622. package/build/dist/Tests/Types/IP/IPv6.test.js.map +0 -1
  623. package/build/dist/Tests/Types/JSON.test.js +0 -37
  624. package/build/dist/Tests/Types/JSON.test.js.map +0 -1
  625. package/build/dist/Tests/Types/JSONFunctions.test.js +0 -38
  626. package/build/dist/Tests/Types/JSONFunctions.test.js.map +0 -1
  627. package/build/dist/Tests/Types/ListData.test.js +0 -34
  628. package/build/dist/Tests/Types/ListData.test.js.map +0 -1
  629. package/build/dist/Tests/Types/Monitor/KubernetesAlertTemplates.test.js +0 -121
  630. package/build/dist/Tests/Types/Monitor/KubernetesAlertTemplates.test.js.map +0 -1
  631. package/build/dist/Tests/Types/Name.test.js +0 -26
  632. package/build/dist/Tests/Types/Name.test.js.map +0 -1
  633. package/build/dist/Tests/Types/ObjectID.test.js +0 -12
  634. package/build/dist/Tests/Types/ObjectID.test.js.map +0 -1
  635. package/build/dist/Tests/Types/OnCallDutyPolicy/LayerUtil.test.js +0 -530
  636. package/build/dist/Tests/Types/OnCallDutyPolicy/LayerUtil.test.js.map +0 -1
  637. package/build/dist/Tests/Types/Permission.test.js +0 -99
  638. package/build/dist/Tests/Types/Permission.test.js.map +0 -1
  639. package/build/dist/Tests/Types/Phone.test.js +0 -37
  640. package/build/dist/Tests/Types/Phone.test.js.map +0 -1
  641. package/build/dist/Tests/Types/Port.test.js +0 -35
  642. package/build/dist/Tests/Types/Port.test.js.map +0 -1
  643. package/build/dist/Tests/Types/PositiveNumber.test.js +0 -101
  644. package/build/dist/Tests/Types/PositiveNumber.test.js.map +0 -1
  645. package/build/dist/Tests/Types/SecuritySeverity.test.js +0 -16
  646. package/build/dist/Tests/Types/SecuritySeverity.test.js.map +0 -1
  647. package/build/dist/Tests/Types/SerializableObject.test.js +0 -37
  648. package/build/dist/Tests/Types/SerializableObject.test.js.map +0 -1
  649. package/build/dist/Tests/Types/Sleep.test.js +0 -14
  650. package/build/dist/Tests/Types/Sleep.test.js.map +0 -1
  651. package/build/dist/Tests/Types/Text.test.js +0 -8
  652. package/build/dist/Tests/Types/Text.test.js.map +0 -1
  653. package/build/dist/Tests/Types/Timezone.test.js +0 -596
  654. package/build/dist/Tests/Types/Timezone.test.js.map +0 -1
  655. package/build/dist/Tests/Types/Typeof.test.js +0 -16
  656. package/build/dist/Tests/Types/Typeof.test.js.map +0 -1
  657. package/build/dist/Tests/Types/UserType.test.js +0 -16
  658. package/build/dist/Tests/Types/UserType.test.js.map +0 -1
  659. package/build/dist/Tests/Types/Version.test.js +0 -35
  660. package/build/dist/Tests/Types/Version.test.js.map +0 -1
  661. package/build/dist/Tests/Types/XML.test.js +0 -35
  662. package/build/dist/Tests/Types/XML.test.js.map +0 -1
  663. package/build/dist/Tests/UI/Components/404.test.js +0 -59
  664. package/build/dist/Tests/UI/Components/404.test.js.map +0 -1
  665. package/build/dist/Tests/UI/Components/Alert.test.js +0 -83
  666. package/build/dist/Tests/UI/Components/Alert.test.js.map +0 -1
  667. package/build/dist/Tests/UI/Components/Badge.test.js +0 -59
  668. package/build/dist/Tests/UI/Components/Badge.test.js.map +0 -1
  669. package/build/dist/Tests/UI/Components/BasicForm.test.js +0 -92
  670. package/build/dist/Tests/UI/Components/BasicForm.test.js.map +0 -1
  671. package/build/dist/Tests/UI/Components/Breadcrumbs.test.js +0 -69
  672. package/build/dist/Tests/UI/Components/Breadcrumbs.test.js.map +0 -1
  673. package/build/dist/Tests/UI/Components/Button.test.js +0 -104
  674. package/build/dist/Tests/UI/Components/Button.test.js.map +0 -1
  675. package/build/dist/Tests/UI/Components/Card.test.js +0 -81
  676. package/build/dist/Tests/UI/Components/Card.test.js.map +0 -1
  677. package/build/dist/Tests/UI/Components/ColorViewer.test.js +0 -42
  678. package/build/dist/Tests/UI/Components/ColorViewer.test.js.map +0 -1
  679. package/build/dist/Tests/UI/Components/ComponentsModal.test.js +0 -233
  680. package/build/dist/Tests/UI/Components/ComponentsModal.test.js.map +0 -1
  681. package/build/dist/Tests/UI/Components/ConfirmModal.test.js +0 -57
  682. package/build/dist/Tests/UI/Components/ConfirmModal.test.js.map +0 -1
  683. package/build/dist/Tests/UI/Components/DictionaryOfStrings.test.js +0 -84
  684. package/build/dist/Tests/UI/Components/DictionaryOfStrings.test.js.map +0 -1
  685. package/build/dist/Tests/UI/Components/Dropdown.test.js +0 -146
  686. package/build/dist/Tests/UI/Components/Dropdown.test.js.map +0 -1
  687. package/build/dist/Tests/UI/Components/DuplicateModel.test.js +0 -229
  688. package/build/dist/Tests/UI/Components/DuplicateModel.test.js.map +0 -1
  689. package/build/dist/Tests/UI/Components/EmptyState/EmptyState.test.js +0 -26
  690. package/build/dist/Tests/UI/Components/EmptyState/EmptyState.test.js.map +0 -1
  691. package/build/dist/Tests/UI/Components/ErrorBoundary.test.js +0 -32
  692. package/build/dist/Tests/UI/Components/ErrorBoundary.test.js.map +0 -1
  693. package/build/dist/Tests/UI/Components/FilePicker.test.js +0 -342
  694. package/build/dist/Tests/UI/Components/FilePicker.test.js.map +0 -1
  695. package/build/dist/Tests/UI/Components/HiddenText.test.js +0 -50
  696. package/build/dist/Tests/UI/Components/HiddenText.test.js.map +0 -1
  697. package/build/dist/Tests/UI/Components/Input.test.js +0 -223
  698. package/build/dist/Tests/UI/Components/Input.test.js.map +0 -1
  699. package/build/dist/Tests/UI/Components/Item.test.js +0 -58
  700. package/build/dist/Tests/UI/Components/Item.test.js.map +0 -1
  701. package/build/dist/Tests/UI/Components/List.test.js +0 -83
  702. package/build/dist/Tests/UI/Components/List.test.js.map +0 -1
  703. package/build/dist/Tests/UI/Components/Loader.test.js +0 -19
  704. package/build/dist/Tests/UI/Components/Loader.test.js.map +0 -1
  705. package/build/dist/Tests/UI/Components/MarkdownEditor.test.js +0 -85
  706. package/build/dist/Tests/UI/Components/MarkdownEditor.test.js.map +0 -1
  707. package/build/dist/Tests/UI/Components/MasterPage.test.js +0 -46
  708. package/build/dist/Tests/UI/Components/MasterPage.test.js.map +0 -1
  709. package/build/dist/Tests/UI/Components/Modal.test.js +0 -127
  710. package/build/dist/Tests/UI/Components/Modal.test.js.map +0 -1
  711. package/build/dist/Tests/UI/Components/NavBar.test.js +0 -52
  712. package/build/dist/Tests/UI/Components/NavBar.test.js.map +0 -1
  713. package/build/dist/Tests/UI/Components/OrderedStatesList.test.js +0 -86
  714. package/build/dist/Tests/UI/Components/OrderedStatesList.test.js.map +0 -1
  715. package/build/dist/Tests/UI/Components/Pagination.test.js +0 -137
  716. package/build/dist/Tests/UI/Components/Pagination.test.js.map +0 -1
  717. package/build/dist/Tests/UI/Components/Pill.test.js +0 -55
  718. package/build/dist/Tests/UI/Components/Pill.test.js.map +0 -1
  719. package/build/dist/Tests/UI/Components/Probe.test.js +0 -52
  720. package/build/dist/Tests/UI/Components/Probe.test.js.map +0 -1
  721. package/build/dist/Tests/UI/Components/ProgressBar.test.js +0 -41
  722. package/build/dist/Tests/UI/Components/ProgressBar.test.js.map +0 -1
  723. package/build/dist/Tests/UI/Components/RadioButtons.test.js +0 -66
  724. package/build/dist/Tests/UI/Components/RadioButtons.test.js.map +0 -1
  725. package/build/dist/Tests/UI/Components/SideMenuItem.test.js +0 -99
  726. package/build/dist/Tests/UI/Components/SideMenuItem.test.js.map +0 -1
  727. package/build/dist/Tests/UI/Components/SideOver.test.js +0 -77
  728. package/build/dist/Tests/UI/Components/SideOver.test.js.map +0 -1
  729. package/build/dist/Tests/UI/Components/Tabs.test.js +0 -56
  730. package/build/dist/Tests/UI/Components/Tabs.test.js.map +0 -1
  731. package/build/dist/Tests/UI/Components/Template/Template.test.js +0 -15
  732. package/build/dist/Tests/UI/Components/Template/Template.test.js.map +0 -1
  733. package/build/dist/Tests/UI/Components/TextArea.test.js +0 -112
  734. package/build/dist/Tests/UI/Components/TextArea.test.js.map +0 -1
  735. package/build/dist/Tests/UI/Components/TimePicker/TimePicker.test.js +0 -352
  736. package/build/dist/Tests/UI/Components/TimePicker/TimePicker.test.js.map +0 -1
  737. package/build/dist/Tests/UI/Components/Toast.test.js +0 -48
  738. package/build/dist/Tests/UI/Components/Toast.test.js.map +0 -1
  739. package/build/dist/Tests/UI/Components/Toggle.test.js +0 -95
  740. package/build/dist/Tests/UI/Components/Toggle.test.js.map +0 -1
  741. package/build/dist/Tests/UI/Components/TopSection.test.js +0 -33
  742. package/build/dist/Tests/UI/Components/TopSection.test.js.map +0 -1
  743. package/build/dist/Tests/UI/Components/XAxis.test.js +0 -21
  744. package/build/dist/Tests/UI/Components/XAxis.test.js.map +0 -1
  745. package/build/dist/Tests/UI/Index.js +0 -2
  746. package/build/dist/Tests/UI/Index.js.map +0 -1
  747. package/build/dist/Tests/UI/Mocks/FileMock.js +0 -3
  748. package/build/dist/Tests/UI/Mocks/FileMock.js.map +0 -1
  749. package/build/dist/Tests/Utils/API.test.js +0 -399
  750. package/build/dist/Tests/Utils/API.test.js.map +0 -1
  751. package/build/dist/Tests/Utils/Analytics.test.js +0 -67
  752. package/build/dist/Tests/Utils/Analytics.test.js.map +0 -1
  753. package/build/dist/Tests/Utils/CronTime.test.js +0 -22
  754. package/build/dist/Tests/Utils/CronTime.test.js.map +0 -1
  755. package/build/dist/Tests/Utils/Faker.test.js +0 -27
  756. package/build/dist/Tests/Utils/Faker.test.js.map +0 -1
  757. package/build/dist/Tests/Utils/MetricUnitUtil.test.js +0 -187
  758. package/build/dist/Tests/Utils/MetricUnitUtil.test.js.map +0 -1
  759. package/build/dist/Tests/Utils/Metrics/MetricFormulaEvaluator.test.js +0 -224
  760. package/build/dist/Tests/Utils/Metrics/MetricFormulaEvaluator.test.js.map +0 -1
  761. package/build/dist/Tests/Utils/Metrics/MetricResultUnitConverter.test.js +0 -180
  762. package/build/dist/Tests/Utils/Metrics/MetricResultUnitConverter.test.js.map +0 -1
  763. package/build/dist/Tests/Utils/RecordingRuleExpression.test.js +0 -142
  764. package/build/dist/Tests/Utils/RecordingRuleExpression.test.js.map +0 -1
  765. package/build/dist/Tests/Utils/Slug.test.js +0 -20
  766. package/build/dist/Tests/Utils/Slug.test.js.map +0 -1
  767. package/build/dist/Tests/Utils/UUID.test.js +0 -48
  768. package/build/dist/Tests/Utils/UUID.test.js.map +0 -1
  769. package/build/dist/Tests/jest.setup.js +0 -30
  770. package/build/dist/Tests/jest.setup.js.map +0 -1
  771. package/build/dist/Types/Profile/ProfileMetricType.js +0 -17
  772. package/build/dist/Types/Profile/ProfileMetricType.js.map +0 -1
@@ -0,0 +1,275 @@
1
+ import Includes from "../../../Types/BaseDatabase/Includes";
2
+ import Query from "../../../Types/BaseDatabase/Query";
3
+ import Log from "../../../Models/AnalyticsModels/Log";
4
+ import Span from "../../../Models/AnalyticsModels/Span";
5
+ import ExceptionInstance from "../../../Models/AnalyticsModels/ExceptionInstance";
6
+ import Profile from "../../../Models/AnalyticsModels/Profile";
7
+ import Metric from "../../../Models/AnalyticsModels/Metric";
8
+ import MonitorStepLogMonitor, {
9
+ MonitorStepLogMonitorUtil,
10
+ } from "../../../Types/Monitor/MonitorStepLogMonitor";
11
+ import MonitorStepTraceMonitor, {
12
+ MonitorStepTraceMonitorUtil,
13
+ } from "../../../Types/Monitor/MonitorStepTraceMonitor";
14
+ import MonitorStepExceptionMonitor, {
15
+ MonitorStepExceptionMonitorUtil,
16
+ } from "../../../Types/Monitor/MonitorStepExceptionMonitor";
17
+ import MonitorStepProfileMonitor, {
18
+ MonitorStepProfileMonitorUtil,
19
+ } from "../../../Types/Monitor/MonitorStepProfileMonitor";
20
+ import MonitorStepMetricMonitor, {
21
+ MonitorStepMetricMonitorUtil,
22
+ } from "../../../Types/Monitor/MonitorStepMetricMonitor";
23
+ import { JSONObject } from "../../../Types/JSON";
24
+
25
+ /*
26
+ * Entity scoping on telemetry monitor steps (entityKeys -> hasAny membership
27
+ * predicate). The contract these tests lock in:
28
+ *
29
+ * 1. Backward compatibility — monitors saved before the field existed
30
+ * deserialize with no entityKeys (or an empty array), and the query
31
+ * compile treats undefined/empty as a strict no-op (no `entityKeys`
32
+ * predicate in the generated Query<Model>).
33
+ * 2. When 1+ keys are present, the compile emits an Includes on the
34
+ * `entityKeys` column, which StatementGenerator turns into
35
+ * hasAny(entityKeys, [...]) for Array(String) columns.
36
+ */
37
+
38
+ const TWO_KEYS: Array<string> = ["a1b2c3d4e5f60708", "1122334455667788"];
39
+
40
+ type ExpectIncludesFunction = (
41
+ value: unknown,
42
+ expectedKeys: Array<string>,
43
+ ) => void;
44
+
45
+ const expectIncludes: ExpectIncludesFunction = (
46
+ value: unknown,
47
+ expectedKeys: Array<string>,
48
+ ): void => {
49
+ expect(value).toBeInstanceOf(Includes);
50
+ expect((value as Includes).values).toEqual(expectedKeys);
51
+ };
52
+
53
+ describe("MonitorStepLogMonitorUtil.toQuery entity scoping", () => {
54
+ test("omits entityKeys predicate when field is undefined (pre-existing saved monitors)", () => {
55
+ const step: MonitorStepLogMonitor = MonitorStepLogMonitorUtil.getDefault();
56
+ delete step.entityKeys;
57
+
58
+ const query: Query<Log> = MonitorStepLogMonitorUtil.toQuery(step);
59
+
60
+ expect(query.entityKeys).toBeUndefined();
61
+ expect(Object.keys(query)).not.toContain("entityKeys");
62
+ });
63
+
64
+ test("omits entityKeys predicate when field is an empty array", () => {
65
+ const step: MonitorStepLogMonitor = MonitorStepLogMonitorUtil.getDefault();
66
+ step.entityKeys = [];
67
+
68
+ const query: Query<Log> = MonitorStepLogMonitorUtil.toQuery(step);
69
+
70
+ expect(query.entityKeys).toBeUndefined();
71
+ });
72
+
73
+ test("compiles two entity keys to an Includes on entityKeys", () => {
74
+ const step: MonitorStepLogMonitor = MonitorStepLogMonitorUtil.getDefault();
75
+ step.entityKeys = TWO_KEYS;
76
+
77
+ const query: Query<Log> = MonitorStepLogMonitorUtil.toQuery(step);
78
+
79
+ expectIncludes(query.entityKeys, TWO_KEYS);
80
+ });
81
+
82
+ test("fromJSON tolerates legacy JSON without entityKeys and round-trips keys", () => {
83
+ const legacyJson: JSONObject = MonitorStepLogMonitorUtil.toJSON(
84
+ MonitorStepLogMonitorUtil.getDefault(),
85
+ );
86
+ delete legacyJson["entityKeys"];
87
+
88
+ const legacyStep: MonitorStepLogMonitor =
89
+ MonitorStepLogMonitorUtil.fromJSON(legacyJson);
90
+ expect(legacyStep.entityKeys).toEqual([]);
91
+
92
+ const stepWithKeys: MonitorStepLogMonitor =
93
+ MonitorStepLogMonitorUtil.getDefault();
94
+ stepWithKeys.entityKeys = TWO_KEYS;
95
+
96
+ const roundTripped: MonitorStepLogMonitor =
97
+ MonitorStepLogMonitorUtil.fromJSON(
98
+ MonitorStepLogMonitorUtil.toJSON(stepWithKeys),
99
+ );
100
+ expect(roundTripped.entityKeys).toEqual(TWO_KEYS);
101
+ });
102
+ });
103
+
104
+ describe("MonitorStepTraceMonitorUtil.toQuery entity scoping", () => {
105
+ test("omits entityKeys predicate when field is undefined", () => {
106
+ const step: MonitorStepTraceMonitor =
107
+ MonitorStepTraceMonitorUtil.getDefault();
108
+ delete step.entityKeys;
109
+
110
+ const query: Query<Span> = MonitorStepTraceMonitorUtil.toQuery(step);
111
+
112
+ expect(query.entityKeys).toBeUndefined();
113
+ });
114
+
115
+ test("omits entityKeys predicate when field is an empty array", () => {
116
+ const step: MonitorStepTraceMonitor =
117
+ MonitorStepTraceMonitorUtil.getDefault();
118
+ step.entityKeys = [];
119
+
120
+ const query: Query<Span> = MonitorStepTraceMonitorUtil.toQuery(step);
121
+
122
+ expect(query.entityKeys).toBeUndefined();
123
+ });
124
+
125
+ test("compiles two entity keys to an Includes on entityKeys", () => {
126
+ const step: MonitorStepTraceMonitor =
127
+ MonitorStepTraceMonitorUtil.getDefault();
128
+ step.entityKeys = TWO_KEYS;
129
+
130
+ const query: Query<Span> = MonitorStepTraceMonitorUtil.toQuery(step);
131
+
132
+ expectIncludes(query.entityKeys, TWO_KEYS);
133
+ });
134
+
135
+ test("fromJSON tolerates legacy JSON without entityKeys", () => {
136
+ const legacyJson: JSONObject = MonitorStepTraceMonitorUtil.toJSON(
137
+ MonitorStepTraceMonitorUtil.getDefault(),
138
+ );
139
+ delete legacyJson["entityKeys"];
140
+
141
+ const legacyStep: MonitorStepTraceMonitor =
142
+ MonitorStepTraceMonitorUtil.fromJSON(legacyJson);
143
+ expect(legacyStep.entityKeys).toEqual([]);
144
+ });
145
+ });
146
+
147
+ describe("MonitorStepExceptionMonitorUtil.toAnalyticsQuery entity scoping", () => {
148
+ test("omits entityKeys predicate when field is undefined", () => {
149
+ const step: MonitorStepExceptionMonitor =
150
+ MonitorStepExceptionMonitorUtil.getDefault();
151
+ delete step.entityKeys;
152
+
153
+ const query: Query<ExceptionInstance> =
154
+ MonitorStepExceptionMonitorUtil.toAnalyticsQuery(step);
155
+
156
+ expect(query.entityKeys).toBeUndefined();
157
+ });
158
+
159
+ test("omits entityKeys predicate when field is an empty array", () => {
160
+ const step: MonitorStepExceptionMonitor =
161
+ MonitorStepExceptionMonitorUtil.getDefault();
162
+ step.entityKeys = [];
163
+
164
+ const query: Query<ExceptionInstance> =
165
+ MonitorStepExceptionMonitorUtil.toAnalyticsQuery(step);
166
+
167
+ expect(query.entityKeys).toBeUndefined();
168
+ });
169
+
170
+ test("compiles two entity keys to an Includes on entityKeys", () => {
171
+ const step: MonitorStepExceptionMonitor =
172
+ MonitorStepExceptionMonitorUtil.getDefault();
173
+ step.entityKeys = TWO_KEYS;
174
+
175
+ const query: Query<ExceptionInstance> =
176
+ MonitorStepExceptionMonitorUtil.toAnalyticsQuery(step);
177
+
178
+ expectIncludes(query.entityKeys, TWO_KEYS);
179
+ });
180
+
181
+ test("fromJSON tolerates legacy JSON without entityKeys", () => {
182
+ const legacyJson: JSONObject = MonitorStepExceptionMonitorUtil.toJSON(
183
+ MonitorStepExceptionMonitorUtil.getDefault(),
184
+ );
185
+ delete legacyJson["entityKeys"];
186
+
187
+ const legacyStep: MonitorStepExceptionMonitor =
188
+ MonitorStepExceptionMonitorUtil.fromJSON(legacyJson);
189
+ expect(legacyStep.entityKeys).toEqual([]);
190
+ });
191
+ });
192
+
193
+ describe("MonitorStepProfileMonitorUtil.toQuery entity scoping", () => {
194
+ test("omits entityKeys predicate when field is undefined", () => {
195
+ const step: MonitorStepProfileMonitor =
196
+ MonitorStepProfileMonitorUtil.getDefault();
197
+ delete step.entityKeys;
198
+
199
+ const query: Query<Profile> = MonitorStepProfileMonitorUtil.toQuery(step);
200
+
201
+ expect(query.entityKeys).toBeUndefined();
202
+ });
203
+
204
+ test("omits entityKeys predicate when field is an empty array", () => {
205
+ const step: MonitorStepProfileMonitor =
206
+ MonitorStepProfileMonitorUtil.getDefault();
207
+ step.entityKeys = [];
208
+
209
+ const query: Query<Profile> = MonitorStepProfileMonitorUtil.toQuery(step);
210
+
211
+ expect(query.entityKeys).toBeUndefined();
212
+ });
213
+
214
+ test("compiles two entity keys to an Includes on entityKeys", () => {
215
+ const step: MonitorStepProfileMonitor =
216
+ MonitorStepProfileMonitorUtil.getDefault();
217
+ step.entityKeys = TWO_KEYS;
218
+
219
+ const query: Query<Profile> = MonitorStepProfileMonitorUtil.toQuery(step);
220
+
221
+ expectIncludes(query.entityKeys, TWO_KEYS);
222
+ });
223
+ });
224
+
225
+ describe("MonitorStepMetricMonitorUtil.applyEntityScopeToQuery", () => {
226
+ test("is a no-op when entityKeys is undefined (pre-existing saved monitors)", () => {
227
+ const step: MonitorStepMetricMonitor =
228
+ MonitorStepMetricMonitorUtil.getDefault();
229
+ delete step.entityKeys;
230
+
231
+ const query: Query<Metric> = {};
232
+ MonitorStepMetricMonitorUtil.applyEntityScopeToQuery(query, step);
233
+
234
+ expect(query.entityKeys).toBeUndefined();
235
+ expect(Object.keys(query)).toHaveLength(0);
236
+ });
237
+
238
+ test("is a no-op when entityKeys is an empty array", () => {
239
+ const step: MonitorStepMetricMonitor =
240
+ MonitorStepMetricMonitorUtil.getDefault();
241
+ step.entityKeys = [];
242
+
243
+ const query: Query<Metric> = {};
244
+ MonitorStepMetricMonitorUtil.applyEntityScopeToQuery(query, step);
245
+
246
+ expect(query.entityKeys).toBeUndefined();
247
+ });
248
+
249
+ test("stamps an Includes on entityKeys for two keys and preserves other predicates", () => {
250
+ const step: MonitorStepMetricMonitor =
251
+ MonitorStepMetricMonitorUtil.getDefault();
252
+ step.entityKeys = TWO_KEYS;
253
+
254
+ const query: Query<Metric> = { name: "cpu.usage" };
255
+ const returned: Query<Metric> =
256
+ MonitorStepMetricMonitorUtil.applyEntityScopeToQuery(query, step);
257
+
258
+ expect(returned).toBe(query);
259
+ expect(query.name).toBe("cpu.usage");
260
+ expectIncludes(query.entityKeys, TWO_KEYS);
261
+ });
262
+
263
+ test("fromJSON preserves entityKeys (pass-through serialization)", () => {
264
+ const step: MonitorStepMetricMonitor =
265
+ MonitorStepMetricMonitorUtil.getDefault();
266
+ step.entityKeys = TWO_KEYS;
267
+
268
+ const roundTripped: MonitorStepMetricMonitor =
269
+ MonitorStepMetricMonitorUtil.fromJSON(
270
+ MonitorStepMetricMonitorUtil.toJSON(step),
271
+ );
272
+
273
+ expect(roundTripped.entityKeys).toEqual(TWO_KEYS);
274
+ });
275
+ });
@@ -5,4 +5,56 @@ describe("class Text", () => {
5
5
  expect(Text.uppercaseFirstLetter("text")).toEqual("Text");
6
6
  expect(Text.uppercaseFirstLetter("another test")).toEqual("Another test");
7
7
  });
8
+
9
+ describe("Text.convertOtlpIdToHex", () => {
10
+ test("passes 32-char hex trace ids through, normalised to lowercase", () => {
11
+ const hexTraceId: string = "4BF92F3577B34DA6A3CE929D0E0E4736";
12
+ expect(Text.convertOtlpIdToHex(hexTraceId)).toEqual(
13
+ "4bf92f3577b34da6a3ce929d0e0e4736",
14
+ );
15
+ expect(
16
+ Text.convertOtlpIdToHex("4bf92f3577b34da6a3ce929d0e0e4736"),
17
+ ).toEqual("4bf92f3577b34da6a3ce929d0e0e4736");
18
+ });
19
+
20
+ test("passes 16-char hex span ids through, normalised to lowercase", () => {
21
+ expect(Text.convertOtlpIdToHex("00F067AA0BA902B7")).toEqual(
22
+ "00f067aa0ba902b7",
23
+ );
24
+ });
25
+
26
+ test("decodes base64 ids (the OTLP/protobuf wire form) to hex", () => {
27
+ // 16-byte trace id -> 24-char base64 -> 32-char hex
28
+ const traceIdBytes: Buffer = Buffer.from(
29
+ "4bf92f3577b34da6a3ce929d0e0e4736",
30
+ "hex",
31
+ );
32
+ expect(Text.convertOtlpIdToHex(traceIdBytes.toString("base64"))).toEqual(
33
+ "4bf92f3577b34da6a3ce929d0e0e4736",
34
+ );
35
+
36
+ // 8-byte span id -> 12-char base64 -> 16-char hex
37
+ const spanIdBytes: Buffer = Buffer.from("00f067aa0ba902b7", "hex");
38
+ expect(Text.convertOtlpIdToHex(spanIdBytes.toString("base64"))).toEqual(
39
+ "00f067aa0ba902b7",
40
+ );
41
+ });
42
+
43
+ test("returns empty string for missing ids", () => {
44
+ expect(Text.convertOtlpIdToHex(undefined)).toEqual("");
45
+ expect(Text.convertOtlpIdToHex("")).toEqual("");
46
+ });
47
+
48
+ test("hex detection requires the exact id lengths — other hex-looking strings still take the base64 path", () => {
49
+ /*
50
+ * A 24-char hex-only string is a valid base64 payload and is NOT
51
+ * an OTLP hex id (ids are exactly 16 or 32 chars), so it must be
52
+ * treated as base64 — same behaviour as convertBase64ToHex.
53
+ */
54
+ const ambiguous: string = "abcdefabcdefabcdefabcdef";
55
+ expect(Text.convertOtlpIdToHex(ambiguous)).toEqual(
56
+ Text.convertBase64ToHex(ambiguous),
57
+ );
58
+ });
59
+ });
8
60
  });
@@ -0,0 +1,150 @@
1
+ import {
2
+ canonicalizeEntityValue,
3
+ computeEntityKey,
4
+ keyForService,
5
+ setSha256Provider,
6
+ } from "../../../Utils/Telemetry/EntityKey";
7
+ import Crypto from "../../../Utils/Crypto";
8
+ import EntityType from "../../../Types/Telemetry/EntityType";
9
+ import { describe, expect, test } from "@jest/globals";
10
+ import { createHash } from "crypto";
11
+ import CryptoJS from "crypto-js";
12
+
13
+ const PROJECT: string = "proj1";
14
+
15
+ describe("canonicalizeEntityValue", () => {
16
+ test("trims and lowercases", () => {
17
+ expect(canonicalizeEntityValue(" Web-1 ")).toBe("web-1");
18
+ expect(canonicalizeEntityValue("PRIMARY01")).toBe("primary01");
19
+ });
20
+
21
+ test("undefined coerces to empty string", () => {
22
+ expect(canonicalizeEntityValue(undefined)).toBe("");
23
+ });
24
+ });
25
+
26
+ describe("computeEntityKey — preimage escaping", () => {
27
+ test("values containing separators do not collide with structurally different identity sets", () => {
28
+ /*
29
+ * Without escaping, both would build the preimage
30
+ * `proj1|service|service.name=a|service.namespace=b`.
31
+ */
32
+ const smuggled: string = computeEntityKey({
33
+ projectId: PROJECT,
34
+ entityType: EntityType.Service,
35
+ identifyingAttributes: { "service.name": "a|service.namespace=b" },
36
+ });
37
+ const split: string = computeEntityKey({
38
+ projectId: PROJECT,
39
+ entityType: EntityType.Service,
40
+ identifyingAttributes: {
41
+ "service.name": "a",
42
+ "service.namespace": "b",
43
+ },
44
+ });
45
+ expect(smuggled).not.toBe(split);
46
+ });
47
+
48
+ test("the escape character itself is escaped (no backslash smuggling)", () => {
49
+ /*
50
+ * A literal backslash in a value must be doubled in the preimage, so a
51
+ * trailing backslash cannot masquerade as an escape of the following
52
+ * separator.
53
+ */
54
+ const trailingBackslash: string = computeEntityKey({
55
+ projectId: PROJECT,
56
+ entityType: EntityType.Service,
57
+ identifyingAttributes: { a: "x\\", b: "y" },
58
+ });
59
+ expect(trailingBackslash).toBe(
60
+ createHash("sha256")
61
+ .update("proj1|service|a=x\\\\|b=y")
62
+ .digest("hex")
63
+ .slice(0, 16),
64
+ );
65
+ const literalSeparators: string = computeEntityKey({
66
+ projectId: PROJECT,
67
+ entityType: EntityType.Service,
68
+ identifyingAttributes: { a: "x\\|b=y" },
69
+ });
70
+ expect(trailingBackslash).not.toBe(literalSeparators);
71
+ });
72
+
73
+ test("normal values keep the historical preimage (already-stamped keys unchanged)", () => {
74
+ const key: string = computeEntityKey({
75
+ projectId: PROJECT,
76
+ entityType: EntityType.Service,
77
+ identifyingAttributes: { "service.name": "checkout" },
78
+ });
79
+ // Unescaped preimage, exactly as stamped before escaping existed.
80
+ const historical: string = createHash("sha256")
81
+ .update("proj1|service|service.name=checkout")
82
+ .digest("hex")
83
+ .slice(0, 16);
84
+ expect(key).toBe(historical);
85
+ /*
86
+ * Pinned so any preimage drift (separator, ordering, hash, slice
87
+ * length) fails loudly — this exact key is stamped in ClickHouse rows.
88
+ */
89
+ expect(key).toBe("904989abd67aec3f");
90
+ expect(keyForService(PROJECT, "checkout")).toBe("904989abd67aec3f");
91
+ });
92
+ });
93
+
94
+ describe("sha256 provider injection", () => {
95
+ test("node:crypto and crypto-js produce identical hex for the same input", () => {
96
+ const inputs: Array<string> = [
97
+ "proj1|service|service.name=checkout",
98
+ "projB|k8s.cluster|k8s.cluster.name=prod-us",
99
+ "p|host|host.name=ünïcode-höst",
100
+ ];
101
+ for (const input of inputs) {
102
+ expect(CryptoJS.SHA256(input).toString()).toBe(
103
+ createHash("sha256").update(input).digest("hex"),
104
+ );
105
+ }
106
+ });
107
+
108
+ test("setSha256Provider is honored by computeEntityKey", () => {
109
+ try {
110
+ setSha256Provider(() => {
111
+ return "f".repeat(64);
112
+ });
113
+ expect(
114
+ computeEntityKey({
115
+ projectId: PROJECT,
116
+ entityType: EntityType.Host,
117
+ identifyingAttributes: { "host.name": "web-1" },
118
+ }),
119
+ ).toBe("f".repeat(16));
120
+ } finally {
121
+ setSha256Provider((input: string) => {
122
+ return Crypto.getSha256Hash(input);
123
+ });
124
+ }
125
+ });
126
+
127
+ test("swapping in the node:crypto provider does not change keys", () => {
128
+ const before: string = computeEntityKey({
129
+ projectId: PROJECT,
130
+ entityType: EntityType.Host,
131
+ identifyingAttributes: { "host.name": "web-1" },
132
+ });
133
+ try {
134
+ setSha256Provider((input: string) => {
135
+ return createHash("sha256").update(input).digest("hex");
136
+ });
137
+ expect(
138
+ computeEntityKey({
139
+ projectId: PROJECT,
140
+ entityType: EntityType.Host,
141
+ identifyingAttributes: { "host.name": "web-1" },
142
+ }),
143
+ ).toBe(before);
144
+ } finally {
145
+ setSha256Provider((input: string) => {
146
+ return Crypto.getSha256Hash(input);
147
+ });
148
+ }
149
+ });
150
+ });
@@ -0,0 +1,40 @@
1
+ import { keyForHost } from "../../../Utils/Telemetry/EntityKey";
2
+ import { describe, expect, test } from "@jest/globals";
3
+
4
+ /*
5
+ * Pins keyForHost against the ClickHouse SQL formula used by the
6
+ * RekeyMetricHostRollupToEntityKey migration to backfill
7
+ * MetricItemAggMV1mByHostV2 from the old hostIdentifier-keyed rollup:
8
+ *
9
+ * substring(lower(hex(SHA256(concat(
10
+ * projectId, '|host|host.name=', lower(trimBoth(hostIdentifier))
11
+ * )))), 1, 16)
12
+ *
13
+ * The expected values below are the literal outputs of that SQL run on a
14
+ * live ClickHouse (25.7) — if keyForHost's canonicalization, preimage
15
+ * layout, hash, or slice length ever drifts, this fails loudly and the
16
+ * backfilled rollup rows stop matching ingest-stamped hostEntityKeys.
17
+ *
18
+ * (Hostnames containing '\\', '|' or '=' are escaped by keyForHost but
19
+ * not by the SQL — a documented, vanishingly-rare caveat of the backfill,
20
+ * deliberately not pinned here.)
21
+ */
22
+ describe("keyForHost — parity with the migration's SQL key computation", () => {
23
+ test("matches ClickHouse-computed keys for representative hostnames", () => {
24
+ // [projectId, raw hostIdentifier, SQL-computed key from live ClickHouse]
25
+ const vectors: Array<[string, string, string]> = [
26
+ // Mixed case + trailing whitespace exercise canonicalization.
27
+ ["proj-123", "Web-Server-01 ", "dba90fb9cca1242e"],
28
+ [
29
+ "8f3c2a1e-0000-4a4a-9c9c-aabbccddeeff",
30
+ "ip-10-0-1-23.ec2.internal",
31
+ "7f5d90eeeeb0b48b",
32
+ ],
33
+ ["proj-xyz", "NODE.example.COM", "8825a6c0687b16d9"],
34
+ ];
35
+
36
+ for (const [projectId, hostIdentifier, sqlKey] of vectors) {
37
+ expect(keyForHost(projectId, hostIdentifier)).toBe(sqlKey);
38
+ }
39
+ });
40
+ });
@@ -0,0 +1,150 @@
1
+ import {
2
+ EntityRelationshipEdge,
3
+ deriveRelationships,
4
+ inferRelationshipType,
5
+ } from "../../../Utils/Telemetry/EntityRelationship";
6
+ import EntityRelationshipType from "../../../Types/Telemetry/EntityRelationshipType";
7
+ import EntityType from "../../../Types/Telemetry/EntityType";
8
+ import { describe, expect, test } from "@jest/globals";
9
+
10
+ describe("inferRelationshipType", () => {
11
+ test("infers documented directed relationships", () => {
12
+ expect(
13
+ inferRelationshipType(
14
+ EntityType.KubernetesPod,
15
+ EntityType.KubernetesNode,
16
+ ),
17
+ ).toBe(EntityRelationshipType.RunsOn);
18
+ expect(
19
+ inferRelationshipType(
20
+ EntityType.KubernetesPod,
21
+ EntityType.KubernetesCluster,
22
+ ),
23
+ ).toBe(EntityRelationshipType.MemberOf);
24
+ expect(inferRelationshipType(EntityType.Service, EntityType.Host)).toBe(
25
+ EntityRelationshipType.HostedOn,
26
+ );
27
+ expect(
28
+ inferRelationshipType(EntityType.Container, EntityType.KubernetesPod),
29
+ ).toBe(EntityRelationshipType.PartOf);
30
+ expect(
31
+ inferRelationshipType(EntityType.ServiceInstance, EntityType.Service),
32
+ ).toBe(EntityRelationshipType.InstanceOf);
33
+ });
34
+
35
+ test("is directional (the reverse pair yields nothing)", () => {
36
+ expect(
37
+ inferRelationshipType(
38
+ EntityType.KubernetesNode,
39
+ EntityType.KubernetesPod,
40
+ ),
41
+ ).toBeNull();
42
+ expect(
43
+ inferRelationshipType(EntityType.Host, EntityType.Service),
44
+ ).toBeNull();
45
+ });
46
+
47
+ test("unrelated or self type pairs yield null", () => {
48
+ expect(
49
+ inferRelationshipType(EntityType.TelemetrySdk, EntityType.Host),
50
+ ).toBeNull();
51
+ expect(
52
+ inferRelationshipType(EntityType.Service, EntityType.Service),
53
+ ).toBeNull();
54
+ });
55
+
56
+ test("depends-on is never inferred from co-occurrence (span-derived only)", () => {
57
+ /*
58
+ * Service → service dependency edges come from cross-service
59
+ * parent/child span pairs (the ComputeServiceDependencies cron) —
60
+ * a caller and its callee never share one resource, so no ordered
61
+ * type pair may ever infer DependsOn.
62
+ */
63
+ const types: Array<EntityType> = Object.values(EntityType);
64
+ for (const fromType of types) {
65
+ for (const toType of types) {
66
+ expect(inferRelationshipType(fromType, toType)).not.toBe(
67
+ EntityRelationshipType.DependsOn,
68
+ );
69
+ }
70
+ }
71
+ });
72
+ });
73
+
74
+ describe("EntityRelationshipType", () => {
75
+ test("pins the depends-on wire value (stored in Postgres rows)", () => {
76
+ expect(EntityRelationshipType.DependsOn).toBe("depends-on");
77
+ });
78
+ });
79
+
80
+ describe("deriveRelationships", () => {
81
+ function hasEdge(
82
+ edges: Array<EntityRelationshipEdge>,
83
+ from: string,
84
+ to: string,
85
+ rel: EntityRelationshipType,
86
+ ): boolean {
87
+ return edges.some((e: EntityRelationshipEdge) => {
88
+ return (
89
+ e.fromEntityKey === from &&
90
+ e.toEntityKey === to &&
91
+ e.relationshipType === rel
92
+ );
93
+ });
94
+ }
95
+
96
+ test("derives the full directed edge set for a k8s resource", () => {
97
+ const edges: Array<EntityRelationshipEdge> = deriveRelationships([
98
+ { entityType: EntityType.Service, entityKey: "svc" },
99
+ { entityType: EntityType.Host, entityKey: "host" },
100
+ { entityType: EntityType.KubernetesPod, entityKey: "pod" },
101
+ { entityType: EntityType.KubernetesNode, entityKey: "node" },
102
+ { entityType: EntityType.KubernetesCluster, entityKey: "cluster" },
103
+ { entityType: EntityType.Container, entityKey: "ctr" },
104
+ ]);
105
+
106
+ expect(hasEdge(edges, "svc", "host", EntityRelationshipType.HostedOn)).toBe(
107
+ true,
108
+ );
109
+ expect(hasEdge(edges, "svc", "pod", EntityRelationshipType.RunsOn)).toBe(
110
+ true,
111
+ );
112
+ expect(hasEdge(edges, "pod", "node", EntityRelationshipType.RunsOn)).toBe(
113
+ true,
114
+ );
115
+ expect(
116
+ hasEdge(edges, "pod", "cluster", EntityRelationshipType.MemberOf),
117
+ ).toBe(true);
118
+ expect(
119
+ hasEdge(edges, "node", "cluster", EntityRelationshipType.MemberOf),
120
+ ).toBe(true);
121
+ expect(hasEdge(edges, "ctr", "pod", EntityRelationshipType.PartOf)).toBe(
122
+ true,
123
+ );
124
+ // No reverse edge.
125
+ expect(hasEdge(edges, "host", "svc", EntityRelationshipType.HostedOn)).toBe(
126
+ false,
127
+ );
128
+ });
129
+
130
+ test("empty / single-entity sets produce no edges", () => {
131
+ expect(deriveRelationships([])).toEqual([]);
132
+ expect(
133
+ deriveRelationships([{ entityType: EntityType.Host, entityKey: "h" }]),
134
+ ).toEqual([]);
135
+ });
136
+
137
+ test("deduplicates repeated entities", () => {
138
+ const edges: Array<EntityRelationshipEdge> = deriveRelationships([
139
+ { entityType: EntityType.KubernetesPod, entityKey: "pod" },
140
+ { entityType: EntityType.KubernetesCluster, entityKey: "cluster" },
141
+ { entityType: EntityType.KubernetesCluster, entityKey: "cluster" },
142
+ ]);
143
+ const memberEdges: Array<EntityRelationshipEdge> = edges.filter(
144
+ (e: EntityRelationshipEdge) => {
145
+ return e.relationshipType === EntityRelationshipType.MemberOf;
146
+ },
147
+ );
148
+ expect(memberEdges.length).toBe(1);
149
+ });
150
+ });