@oneuptime/common 10.0.63 → 10.0.66
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.
- package/Models/DatabaseModels/AIAgent.ts +36 -0
- package/Models/DatabaseModels/AIAgentOwnerTeam.ts +35 -0
- package/Models/DatabaseModels/AIAgentOwnerUser.ts +35 -0
- package/Models/DatabaseModels/AIAgentTask.ts +48 -0
- package/Models/DatabaseModels/AIAgentTaskLog.ts +9 -0
- package/Models/DatabaseModels/AIAgentTaskPullRequest.ts +19 -0
- package/Models/DatabaseModels/AIAgentTaskTelemetryException.ts +11 -0
- package/Models/DatabaseModels/Alert.ts +104 -0
- package/Models/DatabaseModels/AlertCustomField.ts +20 -0
- package/Models/DatabaseModels/AlertEpisode.ts +118 -0
- package/Models/DatabaseModels/AlertEpisodeFeed.ts +42 -0
- package/Models/DatabaseModels/AlertEpisodeInternalNote.ts +36 -0
- package/Models/DatabaseModels/AlertEpisodeMember.ts +51 -0
- package/Models/DatabaseModels/AlertEpisodeOwnerTeam.ts +36 -0
- package/Models/DatabaseModels/AlertEpisodeOwnerUser.ts +36 -0
- package/Models/DatabaseModels/AlertEpisodeStateTimeline.ts +44 -0
- package/Models/DatabaseModels/AlertFeed.ts +42 -0
- package/Models/DatabaseModels/AlertGroupingRule.ts +82 -0
- package/Models/DatabaseModels/AlertInternalNote.ts +36 -0
- package/Models/DatabaseModels/AlertNoteTemplate.ts +29 -0
- package/Models/DatabaseModels/AlertOwnerTeam.ts +36 -0
- package/Models/DatabaseModels/AlertOwnerUser.ts +36 -0
- package/Models/DatabaseModels/AlertSeverity.ts +39 -0
- package/Models/DatabaseModels/AlertState.ts +49 -0
- package/Models/DatabaseModels/AlertStateTimeline.ts +44 -0
- package/Models/DatabaseModels/BillingPaymentMethod.ts +24 -0
- package/Models/DatabaseModels/CallLog.ts +31 -0
- package/Models/DatabaseModels/CodeRepository.ts +50 -0
- package/Models/DatabaseModels/Dashboard.ts +46 -0
- package/Models/DatabaseModels/DashboardDomain.ts +57 -0
- package/Models/DatabaseModels/DataMigration.ts +1 -0
- package/Models/DatabaseModels/DockerHost.ts +53 -0
- package/Models/DatabaseModels/DockerHostOwnerTeam.ts +464 -0
- package/Models/DatabaseModels/DockerHostOwnerUser.ts +463 -0
- package/Models/DatabaseModels/Domain.ts +23 -0
- package/Models/DatabaseModels/EmailLog.ts +32 -0
- package/Models/DatabaseModels/Incident.ts +152 -0
- package/Models/DatabaseModels/IncidentCustomField.ts +20 -0
- package/Models/DatabaseModels/IncidentEpisode.ts +135 -0
- package/Models/DatabaseModels/IncidentEpisodeFeed.ts +42 -0
- package/Models/DatabaseModels/IncidentEpisodeInternalNote.ts +36 -0
- package/Models/DatabaseModels/IncidentEpisodeMember.ts +51 -0
- package/Models/DatabaseModels/IncidentEpisodeOwnerTeam.ts +36 -0
- package/Models/DatabaseModels/IncidentEpisodeOwnerUser.ts +36 -0
- package/Models/DatabaseModels/IncidentEpisodePublicNote.ts +51 -0
- package/Models/DatabaseModels/IncidentEpisodeRoleMember.ts +45 -0
- package/Models/DatabaseModels/IncidentEpisodeStateTimeline.ts +51 -0
- package/Models/DatabaseModels/IncidentFeed.ts +42 -0
- package/Models/DatabaseModels/IncidentGroupingRule.ts +88 -0
- package/Models/DatabaseModels/IncidentInternalNote.ts +36 -0
- package/Models/DatabaseModels/IncidentMember.ts +45 -0
- package/Models/DatabaseModels/IncidentNoteTemplate.ts +29 -0
- package/Models/DatabaseModels/IncidentOwnerTeam.ts +35 -0
- package/Models/DatabaseModels/IncidentOwnerUser.ts +36 -0
- package/Models/DatabaseModels/IncidentPostmortemTemplate.ts +29 -0
- package/Models/DatabaseModels/IncidentPublicNote.ts +51 -0
- package/Models/DatabaseModels/IncidentRole.ts +47 -0
- package/Models/DatabaseModels/IncidentSeverity.ts +39 -0
- package/Models/DatabaseModels/IncidentSla.ts +36 -0
- package/Models/DatabaseModels/IncidentSlaRule.ts +44 -0
- package/Models/DatabaseModels/IncidentState.ts +51 -0
- package/Models/DatabaseModels/IncidentStateTimeline.ts +55 -0
- package/Models/DatabaseModels/IncidentTemplate.ts +73 -0
- package/Models/DatabaseModels/IncidentTemplateOwnerTeam.ts +35 -0
- package/Models/DatabaseModels/IncidentTemplateOwnerUser.ts +59 -0
- package/Models/DatabaseModels/IncomingCallLog.ts +20 -0
- package/Models/DatabaseModels/IncomingCallLogItem.ts +17 -0
- package/Models/DatabaseModels/IncomingCallPolicy.ts +74 -0
- package/Models/DatabaseModels/IncomingCallPolicyEscalationRule.ts +55 -0
- package/Models/DatabaseModels/Index.ts +24 -0
- package/Models/DatabaseModels/KubernetesCluster.ts +53 -0
- package/Models/DatabaseModels/KubernetesClusterOwnerTeam.ts +464 -0
- package/Models/DatabaseModels/KubernetesClusterOwnerUser.ts +463 -0
- package/Models/DatabaseModels/KubernetesResource.ts +548 -0
- package/Models/DatabaseModels/Label.ts +22 -0
- package/Models/DatabaseModels/LlmLog.ts +28 -0
- package/Models/DatabaseModels/LlmProvider.ts +23 -0
- package/Models/DatabaseModels/LogDropFilter.ts +28 -0
- package/Models/DatabaseModels/LogPipeline.ts +24 -0
- package/Models/DatabaseModels/LogPipelineProcessor.ts +24 -0
- package/Models/DatabaseModels/LogSavedView.ts +14 -0
- package/Models/DatabaseModels/LogScrubRule.ts +30 -0
- package/Models/DatabaseModels/MetricPipelineRule.ts +804 -0
- package/Models/DatabaseModels/MetricRecordingRule.ts +470 -0
- package/Models/DatabaseModels/MetricType.ts +26 -0
- package/Models/DatabaseModels/Monitor.ts +107 -0
- package/Models/DatabaseModels/MonitorCustomField.ts +20 -0
- package/Models/DatabaseModels/MonitorFeed.ts +42 -0
- package/Models/DatabaseModels/MonitorGroup.ts +31 -0
- package/Models/DatabaseModels/MonitorGroupOwnerTeam.ts +35 -0
- package/Models/DatabaseModels/MonitorGroupOwnerUser.ts +35 -0
- package/Models/DatabaseModels/MonitorGroupResource.ts +31 -0
- package/Models/DatabaseModels/MonitorOwnerTeam.ts +36 -0
- package/Models/DatabaseModels/MonitorOwnerUser.ts +36 -0
- package/Models/DatabaseModels/MonitorProbe.ts +33 -0
- package/Models/DatabaseModels/MonitorStatus.ts +47 -0
- package/Models/DatabaseModels/MonitorStatusTimeline.ts +44 -0
- package/Models/DatabaseModels/MonitorTest.ts +50 -0
- package/Models/DatabaseModels/OnCallDutyPolicy.ts +44 -0
- package/Models/DatabaseModels/OnCallDutyPolicyCustomField.ts +20 -0
- package/Models/DatabaseModels/OnCallDutyPolicyEscalationRule.ts +39 -0
- package/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleSchedule.ts +35 -0
- package/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleTeam.ts +35 -0
- package/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleUser.ts +35 -0
- package/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.ts +87 -0
- package/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.ts +62 -0
- package/Models/DatabaseModels/OnCallDutyPolicyFeed.ts +42 -0
- package/Models/DatabaseModels/OnCallDutyPolicyOwnerTeam.ts +35 -0
- package/Models/DatabaseModels/OnCallDutyPolicyOwnerUser.ts +35 -0
- package/Models/DatabaseModels/OnCallDutyPolicySchedule.ts +50 -0
- package/Models/DatabaseModels/OnCallDutyPolicyScheduleLayer.ts +51 -0
- package/Models/DatabaseModels/OnCallDutyPolicyScheduleLayerUser.ts +43 -0
- package/Models/DatabaseModels/OnCallDutyPolicyTimeLog.ts +44 -0
- package/Models/DatabaseModels/OnCallDutyPolicyUserOverride.ts +41 -0
- package/Models/DatabaseModels/Probe.ts +38 -0
- package/Models/DatabaseModels/ProbeOwnerTeam.ts +35 -0
- package/Models/DatabaseModels/ProbeOwnerUser.ts +35 -0
- package/Models/DatabaseModels/Project.ts +97 -0
- package/Models/DatabaseModels/ProjectCallSMSConfig.ts +28 -0
- package/Models/DatabaseModels/ProjectSCIM.ts +26 -0
- package/Models/DatabaseModels/ProjectSCIMLog.ts +14 -0
- package/Models/DatabaseModels/ProjectSmtpConfig.ts +42 -0
- package/Models/DatabaseModels/ProjectSso.ts +26 -0
- package/Models/DatabaseModels/ProjectUserProfile.ts +10 -0
- package/Models/DatabaseModels/PromoCode.ts +10 -0
- package/Models/DatabaseModels/PushNotificationLog.ts +31 -0
- package/Models/DatabaseModels/ScheduledMaintenance.ts +103 -0
- package/Models/DatabaseModels/ScheduledMaintenanceCustomField.ts +20 -0
- package/Models/DatabaseModels/ScheduledMaintenanceFeed.ts +42 -0
- package/Models/DatabaseModels/ScheduledMaintenanceInternalNote.ts +36 -0
- package/Models/DatabaseModels/ScheduledMaintenanceNoteTemplate.ts +29 -0
- package/Models/DatabaseModels/ScheduledMaintenanceOwnerTeam.ts +35 -0
- package/Models/DatabaseModels/ScheduledMaintenanceOwnerUser.ts +35 -0
- package/Models/DatabaseModels/ScheduledMaintenancePublicNote.ts +51 -0
- package/Models/DatabaseModels/ScheduledMaintenanceState.ts +55 -0
- package/Models/DatabaseModels/ScheduledMaintenanceStateTimeline.ts +50 -0
- package/Models/DatabaseModels/ScheduledMaintenanceTemplate.ts +98 -0
- package/Models/DatabaseModels/ScheduledMaintenanceTemplateOwnerTeam.ts +33 -0
- package/Models/DatabaseModels/ScheduledMaintenanceTemplateOwnerUser.ts +33 -0
- package/Models/DatabaseModels/Service.ts +154 -0
- package/Models/DatabaseModels/ServiceCodeRepository.ts +49 -0
- package/Models/DatabaseModels/ServiceDependency.ts +55 -0
- package/Models/DatabaseModels/ServiceMonitor.ts +55 -0
- package/Models/DatabaseModels/ServiceOwnerTeam.ts +31 -0
- package/Models/DatabaseModels/ServiceOwnerUser.ts +31 -0
- package/Models/DatabaseModels/SmsLog.ts +31 -0
- package/Models/DatabaseModels/StatusPage.ts +270 -0
- package/Models/DatabaseModels/StatusPageAnnouncement.ts +61 -0
- package/Models/DatabaseModels/StatusPageAnnouncementTemplate.ts +46 -0
- package/Models/DatabaseModels/StatusPageCustomField.ts +20 -0
- package/Models/DatabaseModels/StatusPageDomain.ts +57 -0
- package/Models/DatabaseModels/StatusPageFooterLink.ts +37 -0
- package/Models/DatabaseModels/StatusPageGroup.ts +53 -0
- package/Models/DatabaseModels/StatusPageHeaderLink.ts +37 -0
- package/Models/DatabaseModels/StatusPageHistoryChartBarColorRule.ts +35 -0
- package/Models/DatabaseModels/StatusPageOwnerTeam.ts +33 -0
- package/Models/DatabaseModels/StatusPageOwnerUser.ts +34 -0
- package/Models/DatabaseModels/StatusPagePrivateUser.ts +36 -0
- package/Models/DatabaseModels/StatusPageResource.ts +79 -0
- package/Models/DatabaseModels/StatusPageSCIM.ts +13 -0
- package/Models/DatabaseModels/StatusPageSCIMLog.ts +15 -0
- package/Models/DatabaseModels/StatusPageSso.ts +6 -0
- package/Models/DatabaseModels/StatusPageSubscriber.ts +79 -0
- package/Models/DatabaseModels/StatusPageSubscriberNotificationTemplate.ts +42 -0
- package/Models/DatabaseModels/StatusPageSubscriberNotificationTemplateStatusPage.ts +32 -0
- package/Models/DatabaseModels/TableView.ts +26 -0
- package/Models/DatabaseModels/Team.ts +25 -0
- package/Models/DatabaseModels/TeamComplianceSetting.ts +10 -0
- package/Models/DatabaseModels/TeamMember.ts +16 -0
- package/Models/DatabaseModels/TeamMemberCustomField.ts +20 -0
- package/Models/DatabaseModels/TeamPermission.ts +22 -0
- package/Models/DatabaseModels/TelemetryException.ts +62 -0
- package/Models/DatabaseModels/TraceDropFilter.ts +508 -0
- package/Models/DatabaseModels/TracePipeline.ts +436 -0
- package/Models/DatabaseModels/TracePipelineProcessor.ts +454 -0
- package/Models/DatabaseModels/TraceRecordingRule.ts +470 -0
- package/Models/DatabaseModels/TraceScrubRule.ts +546 -0
- package/Models/DatabaseModels/WhatsAppLog.ts +32 -0
- package/Models/DatabaseModels/Workflow.ts +39 -0
- package/Models/DatabaseModels/WorkflowLog.ts +18 -0
- package/Models/DatabaseModels/WorkflowVariable.ts +24 -0
- package/Models/DatabaseModels/WorkspaceNotificationLog.ts +37 -0
- package/Models/DatabaseModels/WorkspaceNotificationRule.ts +47 -0
- package/Models/DatabaseModels/WorkspaceNotificationSummary.ts +87 -0
- package/Models/DatabaseModels/WorkspaceProjectAuthToken.ts +10 -0
- package/Server/API/KubernetesResourceAPI.ts +129 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/1776504277320-MigrationName.ts +399 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/1776505976155-AddTracePipelineTables.ts +205 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/1776509413763-MigrationName.ts +335 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/1776541018853-MigrationName.ts +29 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/1776544084793-MigrationName.ts +53 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/Index.ts +10 -1
- package/Server/Services/DockerHostOwnerTeamService.ts +10 -0
- package/Server/Services/DockerHostOwnerUserService.ts +10 -0
- package/Server/Services/KubernetesClusterOwnerTeamService.ts +10 -0
- package/Server/Services/KubernetesClusterOwnerUserService.ts +10 -0
- package/Server/Services/KubernetesResourceService.ts +351 -0
- package/Server/Services/MetricPipelineRuleService.ts +10 -0
- package/Server/Services/MetricRecordingRuleService.ts +10 -0
- package/Server/Services/TraceDropFilterService.ts +10 -0
- package/Server/Services/TracePipelineProcessorService.ts +10 -0
- package/Server/Services/TracePipelineService.ts +10 -0
- package/Server/Services/TraceRecordingRuleService.ts +10 -0
- package/Server/Services/TraceScrubRuleService.ts +10 -0
- package/Server/Utils/Monitor/Criteria/CompareCriteria.ts +71 -9
- package/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.ts +483 -75
- package/Server/Utils/Monitor/MonitorCriteriaEvaluator.ts +379 -6
- package/Server/Utils/Monitor/MonitorResource.ts +9 -0
- package/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.ts +502 -0
- package/Tests/UI/Components/ProgressBar.test.tsx +1 -6
- package/Tests/Utils/MetricUnitUtil.test.ts +216 -0
- package/Tests/Utils/Metrics/MetricFormulaEvaluator.test.ts +269 -0
- package/Tests/Utils/Metrics/MetricResultUnitConverter.test.ts +231 -0
- package/Tests/Utils/RecordingRuleExpression.test.ts +177 -0
- package/Types/Kubernetes/KubernetesInventoryExtractor.ts +327 -0
- package/Types/Kubernetes/KubernetesObjectParser.ts +1949 -0
- package/Types/Metrics/MetricDownsamplingRetentionDays.ts +49 -0
- package/Types/Metrics/MetricFormulaConfigData.ts +4 -0
- package/Types/Metrics/MetricPipelineRuleFilterCondition.ts +136 -0
- package/Types/Metrics/MetricPipelineRuleType.ts +27 -0
- package/Types/Metrics/RecordingRuleDefinition.ts +180 -0
- package/Types/Monitor/CriteriaFilter.ts +43 -0
- package/Types/Monitor/MetricMonitor/MetricCriteriaContext.ts +70 -0
- package/Types/Permission.ts +1321 -22
- package/Types/Trace/TraceAggregationType.ts +17 -0
- package/Types/Trace/TraceDropFilterAction.ts +6 -0
- package/Types/Trace/TracePipelineProcessorType.ts +56 -0
- package/Types/Trace/TraceRecordingRuleDefinition.ts +218 -0
- package/Types/Trace/TraceScrubAction.ts +7 -0
- package/Types/Trace/TraceScrubField.ts +8 -0
- package/Types/Trace/TraceScrubPatternType.ts +10 -0
- package/UI/Components/BulkUpdate/BulkLabelActions.tsx +288 -0
- package/UI/Components/BulkUpdate/BulkUpdateForm.tsx +14 -6
- package/UI/Components/CSVFileUpload/CSVFileUpload.tsx +352 -0
- package/UI/Components/CardSelect/CardSelect.tsx +9 -1
- package/UI/Components/Charts/ChartGroup/ChartGroup.tsx +6 -10
- package/UI/Components/Forms/Fields/FormField.tsx +1 -0
- package/UI/Components/Forms/Types/Field.ts +1 -0
- package/UI/Components/Markdown.tsx/MarkdownViewer.tsx +57 -0
- package/UI/Components/Page/Page.tsx +6 -0
- package/UI/Components/ProgressBar/ProgressBar.tsx +22 -22
- package/Utils/MetricUnitUtil.ts +289 -0
- package/Utils/Metrics/MetricFormulaEvaluator.ts +610 -0
- package/Utils/Metrics/MetricResultUnitConverter.ts +91 -0
- package/Utils/Metrics/RecordingRuleExpression.ts +359 -0
- package/Utils/ValueFormatter.ts +137 -13
- package/build/dist/Models/DatabaseModels/AIAgent.js +36 -0
- package/build/dist/Models/DatabaseModels/AIAgent.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AIAgentOwnerTeam.js +35 -0
- package/build/dist/Models/DatabaseModels/AIAgentOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AIAgentOwnerUser.js +35 -0
- package/build/dist/Models/DatabaseModels/AIAgentOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AIAgentTask.js +48 -0
- package/build/dist/Models/DatabaseModels/AIAgentTask.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AIAgentTaskLog.js +9 -0
- package/build/dist/Models/DatabaseModels/AIAgentTaskLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AIAgentTaskPullRequest.js +19 -0
- package/build/dist/Models/DatabaseModels/AIAgentTaskPullRequest.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AIAgentTaskTelemetryException.js +11 -0
- package/build/dist/Models/DatabaseModels/AIAgentTaskTelemetryException.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Alert.js +104 -0
- package/build/dist/Models/DatabaseModels/Alert.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertCustomField.js +20 -0
- package/build/dist/Models/DatabaseModels/AlertCustomField.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertEpisode.js +118 -0
- package/build/dist/Models/DatabaseModels/AlertEpisode.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertEpisodeFeed.js +42 -0
- package/build/dist/Models/DatabaseModels/AlertEpisodeFeed.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertEpisodeInternalNote.js +36 -0
- package/build/dist/Models/DatabaseModels/AlertEpisodeInternalNote.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertEpisodeMember.js +51 -0
- package/build/dist/Models/DatabaseModels/AlertEpisodeMember.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertEpisodeOwnerTeam.js +36 -0
- package/build/dist/Models/DatabaseModels/AlertEpisodeOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertEpisodeOwnerUser.js +36 -0
- package/build/dist/Models/DatabaseModels/AlertEpisodeOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertEpisodeStateTimeline.js +44 -0
- package/build/dist/Models/DatabaseModels/AlertEpisodeStateTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertFeed.js +42 -0
- package/build/dist/Models/DatabaseModels/AlertFeed.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertGroupingRule.js +82 -0
- package/build/dist/Models/DatabaseModels/AlertGroupingRule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertInternalNote.js +36 -0
- package/build/dist/Models/DatabaseModels/AlertInternalNote.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertNoteTemplate.js +29 -0
- package/build/dist/Models/DatabaseModels/AlertNoteTemplate.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertOwnerTeam.js +36 -0
- package/build/dist/Models/DatabaseModels/AlertOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertOwnerUser.js +36 -0
- package/build/dist/Models/DatabaseModels/AlertOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertSeverity.js +39 -0
- package/build/dist/Models/DatabaseModels/AlertSeverity.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertState.js +49 -0
- package/build/dist/Models/DatabaseModels/AlertState.js.map +1 -1
- package/build/dist/Models/DatabaseModels/AlertStateTimeline.js +44 -0
- package/build/dist/Models/DatabaseModels/AlertStateTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/BillingPaymentMethod.js +24 -0
- package/build/dist/Models/DatabaseModels/BillingPaymentMethod.js.map +1 -1
- package/build/dist/Models/DatabaseModels/CallLog.js +31 -0
- package/build/dist/Models/DatabaseModels/CallLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/CodeRepository.js +50 -0
- package/build/dist/Models/DatabaseModels/CodeRepository.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Dashboard.js +46 -0
- package/build/dist/Models/DatabaseModels/Dashboard.js.map +1 -1
- package/build/dist/Models/DatabaseModels/DashboardDomain.js +57 -0
- package/build/dist/Models/DatabaseModels/DashboardDomain.js.map +1 -1
- package/build/dist/Models/DatabaseModels/DataMigration.js +1 -0
- package/build/dist/Models/DatabaseModels/DataMigration.js.map +1 -1
- package/build/dist/Models/DatabaseModels/DockerHost.js +53 -0
- package/build/dist/Models/DatabaseModels/DockerHost.js.map +1 -1
- package/build/dist/Models/DatabaseModels/DockerHostOwnerTeam.js +480 -0
- package/build/dist/Models/DatabaseModels/DockerHostOwnerTeam.js.map +1 -0
- package/build/dist/Models/DatabaseModels/DockerHostOwnerUser.js +479 -0
- package/build/dist/Models/DatabaseModels/DockerHostOwnerUser.js.map +1 -0
- package/build/dist/Models/DatabaseModels/Domain.js +23 -0
- package/build/dist/Models/DatabaseModels/Domain.js.map +1 -1
- package/build/dist/Models/DatabaseModels/EmailLog.js +32 -0
- package/build/dist/Models/DatabaseModels/EmailLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Incident.js +152 -0
- package/build/dist/Models/DatabaseModels/Incident.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentCustomField.js +20 -0
- package/build/dist/Models/DatabaseModels/IncidentCustomField.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisode.js +135 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisode.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisodeFeed.js +42 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeFeed.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisodeInternalNote.js +36 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeInternalNote.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisodeMember.js +51 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeMember.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerTeam.js +36 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerUser.js +36 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisodePublicNote.js +51 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodePublicNote.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisodeRoleMember.js +45 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeRoleMember.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisodeStateTimeline.js +51 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeStateTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentFeed.js +42 -0
- package/build/dist/Models/DatabaseModels/IncidentFeed.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentGroupingRule.js +88 -0
- package/build/dist/Models/DatabaseModels/IncidentGroupingRule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentInternalNote.js +36 -0
- package/build/dist/Models/DatabaseModels/IncidentInternalNote.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentMember.js +45 -0
- package/build/dist/Models/DatabaseModels/IncidentMember.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentNoteTemplate.js +29 -0
- package/build/dist/Models/DatabaseModels/IncidentNoteTemplate.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentOwnerTeam.js +35 -0
- package/build/dist/Models/DatabaseModels/IncidentOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentOwnerUser.js +36 -0
- package/build/dist/Models/DatabaseModels/IncidentOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentPostmortemTemplate.js +29 -0
- package/build/dist/Models/DatabaseModels/IncidentPostmortemTemplate.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentPublicNote.js +51 -0
- package/build/dist/Models/DatabaseModels/IncidentPublicNote.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentRole.js +47 -0
- package/build/dist/Models/DatabaseModels/IncidentRole.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentSeverity.js +39 -0
- package/build/dist/Models/DatabaseModels/IncidentSeverity.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentSla.js +36 -0
- package/build/dist/Models/DatabaseModels/IncidentSla.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentSlaRule.js +44 -0
- package/build/dist/Models/DatabaseModels/IncidentSlaRule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentState.js +51 -0
- package/build/dist/Models/DatabaseModels/IncidentState.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentStateTimeline.js +55 -0
- package/build/dist/Models/DatabaseModels/IncidentStateTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentTemplate.js +73 -0
- package/build/dist/Models/DatabaseModels/IncidentTemplate.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentTemplateOwnerTeam.js +35 -0
- package/build/dist/Models/DatabaseModels/IncidentTemplateOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentTemplateOwnerUser.js +59 -0
- package/build/dist/Models/DatabaseModels/IncidentTemplateOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncomingCallLog.js +20 -0
- package/build/dist/Models/DatabaseModels/IncomingCallLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncomingCallLogItem.js +17 -0
- package/build/dist/Models/DatabaseModels/IncomingCallLogItem.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncomingCallPolicy.js +74 -0
- package/build/dist/Models/DatabaseModels/IncomingCallPolicy.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncomingCallPolicyEscalationRule.js +55 -0
- package/build/dist/Models/DatabaseModels/IncomingCallPolicyEscalationRule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Index.js +24 -0
- package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
- package/build/dist/Models/DatabaseModels/KubernetesCluster.js +53 -0
- package/build/dist/Models/DatabaseModels/KubernetesCluster.js.map +1 -1
- package/build/dist/Models/DatabaseModels/KubernetesClusterOwnerTeam.js +480 -0
- package/build/dist/Models/DatabaseModels/KubernetesClusterOwnerTeam.js.map +1 -0
- package/build/dist/Models/DatabaseModels/KubernetesClusterOwnerUser.js +479 -0
- package/build/dist/Models/DatabaseModels/KubernetesClusterOwnerUser.js.map +1 -0
- package/build/dist/Models/DatabaseModels/KubernetesResource.js +590 -0
- package/build/dist/Models/DatabaseModels/KubernetesResource.js.map +1 -0
- package/build/dist/Models/DatabaseModels/Label.js +22 -0
- package/build/dist/Models/DatabaseModels/Label.js.map +1 -1
- package/build/dist/Models/DatabaseModels/LlmLog.js +28 -0
- package/build/dist/Models/DatabaseModels/LlmLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/LlmProvider.js +23 -0
- package/build/dist/Models/DatabaseModels/LlmProvider.js.map +1 -1
- package/build/dist/Models/DatabaseModels/LogDropFilter.js +28 -0
- package/build/dist/Models/DatabaseModels/LogDropFilter.js.map +1 -1
- package/build/dist/Models/DatabaseModels/LogPipeline.js +24 -0
- package/build/dist/Models/DatabaseModels/LogPipeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/LogPipelineProcessor.js +24 -0
- package/build/dist/Models/DatabaseModels/LogPipelineProcessor.js.map +1 -1
- package/build/dist/Models/DatabaseModels/LogSavedView.js +14 -0
- package/build/dist/Models/DatabaseModels/LogSavedView.js.map +1 -1
- package/build/dist/Models/DatabaseModels/LogScrubRule.js +30 -0
- package/build/dist/Models/DatabaseModels/LogScrubRule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MetricPipelineRule.js +836 -0
- package/build/dist/Models/DatabaseModels/MetricPipelineRule.js.map +1 -0
- package/build/dist/Models/DatabaseModels/MetricRecordingRule.js +497 -0
- package/build/dist/Models/DatabaseModels/MetricRecordingRule.js.map +1 -0
- package/build/dist/Models/DatabaseModels/MetricType.js +26 -0
- package/build/dist/Models/DatabaseModels/MetricType.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Monitor.js +107 -0
- package/build/dist/Models/DatabaseModels/Monitor.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorCustomField.js +20 -0
- package/build/dist/Models/DatabaseModels/MonitorCustomField.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorFeed.js +42 -0
- package/build/dist/Models/DatabaseModels/MonitorFeed.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorGroup.js +31 -0
- package/build/dist/Models/DatabaseModels/MonitorGroup.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorGroupOwnerTeam.js +35 -0
- package/build/dist/Models/DatabaseModels/MonitorGroupOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorGroupOwnerUser.js +35 -0
- package/build/dist/Models/DatabaseModels/MonitorGroupOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorGroupResource.js +31 -0
- package/build/dist/Models/DatabaseModels/MonitorGroupResource.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorOwnerTeam.js +36 -0
- package/build/dist/Models/DatabaseModels/MonitorOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorOwnerUser.js +36 -0
- package/build/dist/Models/DatabaseModels/MonitorOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorProbe.js +33 -0
- package/build/dist/Models/DatabaseModels/MonitorProbe.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorStatus.js +47 -0
- package/build/dist/Models/DatabaseModels/MonitorStatus.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorStatusTimeline.js +44 -0
- package/build/dist/Models/DatabaseModels/MonitorStatusTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/MonitorTest.js +50 -0
- package/build/dist/Models/DatabaseModels/MonitorTest.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicy.js +44 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicy.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyCustomField.js +20 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyCustomField.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyEscalationRule.js +39 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyEscalationRule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleSchedule.js +35 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleSchedule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleTeam.js +35 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleUser.js +35 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyEscalationRuleUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.js +87 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.js +62 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyFeed.js +42 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyFeed.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyOwnerTeam.js +35 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyOwnerUser.js +35 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicySchedule.js +50 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicySchedule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyScheduleLayer.js +51 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyScheduleLayer.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyScheduleLayerUser.js +43 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyScheduleLayerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyTimeLog.js +44 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyTimeLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyUserOverride.js +41 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyUserOverride.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Probe.js +38 -0
- package/build/dist/Models/DatabaseModels/Probe.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ProbeOwnerTeam.js +35 -0
- package/build/dist/Models/DatabaseModels/ProbeOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ProbeOwnerUser.js +35 -0
- package/build/dist/Models/DatabaseModels/ProbeOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Project.js +97 -0
- package/build/dist/Models/DatabaseModels/Project.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ProjectCallSMSConfig.js +28 -0
- package/build/dist/Models/DatabaseModels/ProjectCallSMSConfig.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ProjectSCIM.js +26 -0
- package/build/dist/Models/DatabaseModels/ProjectSCIM.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ProjectSCIMLog.js +14 -0
- package/build/dist/Models/DatabaseModels/ProjectSCIMLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ProjectSmtpConfig.js +42 -0
- package/build/dist/Models/DatabaseModels/ProjectSmtpConfig.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ProjectSso.js +26 -0
- package/build/dist/Models/DatabaseModels/ProjectSso.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ProjectUserProfile.js +10 -0
- package/build/dist/Models/DatabaseModels/ProjectUserProfile.js.map +1 -1
- package/build/dist/Models/DatabaseModels/PromoCode.js +10 -0
- package/build/dist/Models/DatabaseModels/PromoCode.js.map +1 -1
- package/build/dist/Models/DatabaseModels/PushNotificationLog.js +31 -0
- package/build/dist/Models/DatabaseModels/PushNotificationLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenance.js +103 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenance.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceCustomField.js +20 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceCustomField.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceFeed.js +42 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceFeed.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceInternalNote.js +36 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceInternalNote.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceNoteTemplate.js +29 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceNoteTemplate.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceOwnerTeam.js +35 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceOwnerUser.js +35 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenancePublicNote.js +51 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenancePublicNote.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceState.js +55 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceState.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceStateTimeline.js +50 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceStateTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceTemplate.js +98 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceTemplate.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceTemplateOwnerTeam.js +33 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceTemplateOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceTemplateOwnerUser.js +33 -0
- package/build/dist/Models/DatabaseModels/ScheduledMaintenanceTemplateOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Service.js +154 -0
- package/build/dist/Models/DatabaseModels/Service.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ServiceCodeRepository.js +49 -0
- package/build/dist/Models/DatabaseModels/ServiceCodeRepository.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ServiceDependency.js +55 -0
- package/build/dist/Models/DatabaseModels/ServiceDependency.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ServiceMonitor.js +55 -0
- package/build/dist/Models/DatabaseModels/ServiceMonitor.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ServiceOwnerTeam.js +31 -0
- package/build/dist/Models/DatabaseModels/ServiceOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/ServiceOwnerUser.js +31 -0
- package/build/dist/Models/DatabaseModels/ServiceOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/SmsLog.js +31 -0
- package/build/dist/Models/DatabaseModels/SmsLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPage.js +270 -0
- package/build/dist/Models/DatabaseModels/StatusPage.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageAnnouncement.js +61 -0
- package/build/dist/Models/DatabaseModels/StatusPageAnnouncement.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageAnnouncementTemplate.js +46 -0
- package/build/dist/Models/DatabaseModels/StatusPageAnnouncementTemplate.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageCustomField.js +20 -0
- package/build/dist/Models/DatabaseModels/StatusPageCustomField.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageDomain.js +57 -0
- package/build/dist/Models/DatabaseModels/StatusPageDomain.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageFooterLink.js +37 -0
- package/build/dist/Models/DatabaseModels/StatusPageFooterLink.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageGroup.js +53 -0
- package/build/dist/Models/DatabaseModels/StatusPageGroup.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageHeaderLink.js +37 -0
- package/build/dist/Models/DatabaseModels/StatusPageHeaderLink.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageHistoryChartBarColorRule.js +35 -0
- package/build/dist/Models/DatabaseModels/StatusPageHistoryChartBarColorRule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageOwnerTeam.js +33 -0
- package/build/dist/Models/DatabaseModels/StatusPageOwnerTeam.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageOwnerUser.js +34 -0
- package/build/dist/Models/DatabaseModels/StatusPageOwnerUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPagePrivateUser.js +36 -0
- package/build/dist/Models/DatabaseModels/StatusPagePrivateUser.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageResource.js +79 -0
- package/build/dist/Models/DatabaseModels/StatusPageResource.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageSCIM.js +13 -0
- package/build/dist/Models/DatabaseModels/StatusPageSCIM.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageSCIMLog.js +15 -0
- package/build/dist/Models/DatabaseModels/StatusPageSCIMLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageSso.js +6 -0
- package/build/dist/Models/DatabaseModels/StatusPageSso.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageSubscriber.js +79 -0
- package/build/dist/Models/DatabaseModels/StatusPageSubscriber.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageSubscriberNotificationTemplate.js +42 -0
- package/build/dist/Models/DatabaseModels/StatusPageSubscriberNotificationTemplate.js.map +1 -1
- package/build/dist/Models/DatabaseModels/StatusPageSubscriberNotificationTemplateStatusPage.js +32 -0
- package/build/dist/Models/DatabaseModels/StatusPageSubscriberNotificationTemplateStatusPage.js.map +1 -1
- package/build/dist/Models/DatabaseModels/TableView.js +26 -0
- package/build/dist/Models/DatabaseModels/TableView.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Team.js +25 -0
- package/build/dist/Models/DatabaseModels/Team.js.map +1 -1
- package/build/dist/Models/DatabaseModels/TeamComplianceSetting.js +10 -0
- package/build/dist/Models/DatabaseModels/TeamComplianceSetting.js.map +1 -1
- package/build/dist/Models/DatabaseModels/TeamMember.js +16 -0
- package/build/dist/Models/DatabaseModels/TeamMember.js.map +1 -1
- package/build/dist/Models/DatabaseModels/TeamMemberCustomField.js +20 -0
- package/build/dist/Models/DatabaseModels/TeamMemberCustomField.js.map +1 -1
- package/build/dist/Models/DatabaseModels/TeamPermission.js +22 -0
- package/build/dist/Models/DatabaseModels/TeamPermission.js.map +1 -1
- package/build/dist/Models/DatabaseModels/TelemetryException.js +62 -0
- package/build/dist/Models/DatabaseModels/TelemetryException.js.map +1 -1
- package/build/dist/Models/DatabaseModels/TraceDropFilter.js +536 -0
- package/build/dist/Models/DatabaseModels/TraceDropFilter.js.map +1 -0
- package/build/dist/Models/DatabaseModels/TracePipeline.js +462 -0
- package/build/dist/Models/DatabaseModels/TracePipeline.js.map +1 -0
- package/build/dist/Models/DatabaseModels/TracePipelineProcessor.js +476 -0
- package/build/dist/Models/DatabaseModels/TracePipelineProcessor.js.map +1 -0
- package/build/dist/Models/DatabaseModels/TraceRecordingRule.js +497 -0
- package/build/dist/Models/DatabaseModels/TraceRecordingRule.js.map +1 -0
- package/build/dist/Models/DatabaseModels/TraceScrubRule.js +575 -0
- package/build/dist/Models/DatabaseModels/TraceScrubRule.js.map +1 -0
- package/build/dist/Models/DatabaseModels/WhatsAppLog.js +32 -0
- package/build/dist/Models/DatabaseModels/WhatsAppLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/Workflow.js +39 -0
- package/build/dist/Models/DatabaseModels/Workflow.js.map +1 -1
- package/build/dist/Models/DatabaseModels/WorkflowLog.js +18 -0
- package/build/dist/Models/DatabaseModels/WorkflowLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/WorkflowVariable.js +24 -0
- package/build/dist/Models/DatabaseModels/WorkflowVariable.js.map +1 -1
- package/build/dist/Models/DatabaseModels/WorkspaceNotificationLog.js +37 -0
- package/build/dist/Models/DatabaseModels/WorkspaceNotificationLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/WorkspaceNotificationRule.js +47 -0
- package/build/dist/Models/DatabaseModels/WorkspaceNotificationRule.js.map +1 -1
- package/build/dist/Models/DatabaseModels/WorkspaceNotificationSummary.js +87 -0
- package/build/dist/Models/DatabaseModels/WorkspaceNotificationSummary.js.map +1 -1
- package/build/dist/Models/DatabaseModels/WorkspaceProjectAuthToken.js +10 -0
- package/build/dist/Models/DatabaseModels/WorkspaceProjectAuthToken.js.map +1 -1
- package/build/dist/Server/API/KubernetesResourceAPI.js +98 -0
- package/build/dist/Server/API/KubernetesResourceAPI.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776504277320-MigrationName.js +144 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776504277320-MigrationName.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776505976155-AddTracePipelineTables.js +82 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776505976155-AddTracePipelineTables.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776509413763-MigrationName.js +118 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776509413763-MigrationName.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776541018853-MigrationName.js +16 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776541018853-MigrationName.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776544084793-MigrationName.js +24 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1776544084793-MigrationName.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +10 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
- package/build/dist/Server/Services/DockerHostOwnerTeamService.js +9 -0
- package/build/dist/Server/Services/DockerHostOwnerTeamService.js.map +1 -0
- package/build/dist/Server/Services/DockerHostOwnerUserService.js +9 -0
- package/build/dist/Server/Services/DockerHostOwnerUserService.js.map +1 -0
- package/build/dist/Server/Services/KubernetesClusterOwnerTeamService.js +9 -0
- package/build/dist/Server/Services/KubernetesClusterOwnerTeamService.js.map +1 -0
- package/build/dist/Server/Services/KubernetesClusterOwnerUserService.js +9 -0
- package/build/dist/Server/Services/KubernetesClusterOwnerUserService.js.map +1 -0
- package/build/dist/Server/Services/KubernetesResourceService.js +237 -0
- package/build/dist/Server/Services/KubernetesResourceService.js.map +1 -0
- package/build/dist/Server/Services/MetricPipelineRuleService.js +9 -0
- package/build/dist/Server/Services/MetricPipelineRuleService.js.map +1 -0
- package/build/dist/Server/Services/MetricRecordingRuleService.js +9 -0
- package/build/dist/Server/Services/MetricRecordingRuleService.js.map +1 -0
- package/build/dist/Server/Services/TraceDropFilterService.js +9 -0
- package/build/dist/Server/Services/TraceDropFilterService.js.map +1 -0
- package/build/dist/Server/Services/TracePipelineProcessorService.js +9 -0
- package/build/dist/Server/Services/TracePipelineProcessorService.js.map +1 -0
- package/build/dist/Server/Services/TracePipelineService.js +9 -0
- package/build/dist/Server/Services/TracePipelineService.js.map +1 -0
- package/build/dist/Server/Services/TraceRecordingRuleService.js +9 -0
- package/build/dist/Server/Services/TraceRecordingRuleService.js.map +1 -0
- package/build/dist/Server/Services/TraceScrubRuleService.js +9 -0
- package/build/dist/Server/Services/TraceScrubRuleService.js.map +1 -0
- package/build/dist/Server/Utils/Monitor/Criteria/CompareCriteria.js +56 -9
- package/build/dist/Server/Utils/Monitor/Criteria/CompareCriteria.js.map +1 -1
- package/build/dist/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.js +335 -53
- package/build/dist/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.js.map +1 -1
- package/build/dist/Server/Utils/Monitor/MonitorCriteriaEvaluator.js +277 -5
- package/build/dist/Server/Utils/Monitor/MonitorCriteriaEvaluator.js.map +1 -1
- package/build/dist/Server/Utils/Monitor/MonitorResource.js +8 -0
- package/build/dist/Server/Utils/Monitor/MonitorResource.js.map +1 -1
- package/build/dist/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.js +407 -0
- package/build/dist/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.js.map +1 -0
- package/build/dist/Tests/UI/Components/ProgressBar.test.js +1 -4
- package/build/dist/Tests/UI/Components/ProgressBar.test.js.map +1 -1
- package/build/dist/Tests/Utils/MetricUnitUtil.test.js +159 -0
- package/build/dist/Tests/Utils/MetricUnitUtil.test.js.map +1 -0
- package/build/dist/Tests/Utils/Metrics/MetricFormulaEvaluator.test.js +224 -0
- package/build/dist/Tests/Utils/Metrics/MetricFormulaEvaluator.test.js.map +1 -0
- package/build/dist/Tests/Utils/Metrics/MetricResultUnitConverter.test.js +180 -0
- package/build/dist/Tests/Utils/Metrics/MetricResultUnitConverter.test.js.map +1 -0
- package/build/dist/Tests/Utils/RecordingRuleExpression.test.js +142 -0
- package/build/dist/Tests/Utils/RecordingRuleExpression.test.js.map +1 -0
- package/build/dist/Types/Kubernetes/KubernetesInventoryExtractor.js +200 -0
- package/build/dist/Types/Kubernetes/KubernetesInventoryExtractor.js.map +1 -0
- package/build/dist/Types/Kubernetes/KubernetesObjectParser.js +1205 -0
- package/build/dist/Types/Kubernetes/KubernetesObjectParser.js.map +1 -0
- package/build/dist/Types/Metrics/MetricDownsamplingRetentionDays.js +32 -0
- package/build/dist/Types/Metrics/MetricDownsamplingRetentionDays.js.map +1 -0
- package/build/dist/Types/Metrics/MetricPipelineRuleFilterCondition.js +103 -0
- package/build/dist/Types/Metrics/MetricPipelineRuleFilterCondition.js.map +1 -0
- package/build/dist/Types/Metrics/MetricPipelineRuleType.js +27 -0
- package/build/dist/Types/Metrics/MetricPipelineRuleType.js.map +1 -0
- package/build/dist/Types/Metrics/RecordingRuleDefinition.js +110 -0
- package/build/dist/Types/Metrics/RecordingRuleDefinition.js.map +1 -0
- package/build/dist/Types/Monitor/CriteriaFilter.js +22 -0
- package/build/dist/Types/Monitor/CriteriaFilter.js.map +1 -1
- package/build/dist/Types/Monitor/MetricMonitor/MetricCriteriaContext.js +2 -0
- package/build/dist/Types/Monitor/MetricMonitor/MetricCriteriaContext.js.map +1 -0
- package/build/dist/Types/Permission.js +1241 -22
- package/build/dist/Types/Permission.js.map +1 -1
- package/build/dist/Types/Trace/TraceAggregationType.js +18 -0
- package/build/dist/Types/Trace/TraceAggregationType.js.map +1 -0
- package/build/dist/Types/Trace/TraceDropFilterAction.js +7 -0
- package/build/dist/Types/Trace/TraceDropFilterAction.js.map +1 -0
- package/build/dist/Types/Trace/TracePipelineProcessorType.js +10 -0
- package/build/dist/Types/Trace/TracePipelineProcessorType.js.map +1 -0
- package/build/dist/Types/Trace/TraceRecordingRuleDefinition.js +145 -0
- package/build/dist/Types/Trace/TraceRecordingRuleDefinition.js.map +1 -0
- package/build/dist/Types/Trace/TraceScrubAction.js +8 -0
- package/build/dist/Types/Trace/TraceScrubAction.js.map +1 -0
- package/build/dist/Types/Trace/TraceScrubField.js +9 -0
- package/build/dist/Types/Trace/TraceScrubField.js.map +1 -0
- package/build/dist/Types/Trace/TraceScrubPatternType.js +11 -0
- package/build/dist/Types/Trace/TraceScrubPatternType.js.map +1 -0
- package/build/dist/UI/Components/BulkUpdate/BulkLabelActions.js +211 -0
- package/build/dist/UI/Components/BulkUpdate/BulkLabelActions.js.map +1 -0
- package/build/dist/UI/Components/BulkUpdate/BulkUpdateForm.js +3 -1
- package/build/dist/UI/Components/BulkUpdate/BulkUpdateForm.js.map +1 -1
- package/build/dist/UI/Components/CSVFileUpload/CSVFileUpload.js +210 -0
- package/build/dist/UI/Components/CSVFileUpload/CSVFileUpload.js.map +1 -0
- package/build/dist/UI/Components/CardSelect/CardSelect.js +3 -1
- package/build/dist/UI/Components/CardSelect/CardSelect.js.map +1 -1
- package/build/dist/UI/Components/Charts/ChartGroup/ChartGroup.js +6 -9
- package/build/dist/UI/Components/Charts/ChartGroup/ChartGroup.js.map +1 -1
- package/build/dist/UI/Components/Forms/Fields/FormField.js +1 -1
- package/build/dist/UI/Components/Forms/Fields/FormField.js.map +1 -1
- package/build/dist/UI/Components/Markdown.tsx/MarkdownViewer.js +30 -0
- package/build/dist/UI/Components/Markdown.tsx/MarkdownViewer.js.map +1 -1
- package/build/dist/UI/Components/Page/Page.js +1 -0
- package/build/dist/UI/Components/Page/Page.js.map +1 -1
- package/build/dist/UI/Components/ProgressBar/ProgressBar.js +11 -9
- package/build/dist/UI/Components/ProgressBar/ProgressBar.js.map +1 -1
- package/build/dist/Utils/MetricUnitUtil.js +232 -0
- package/build/dist/Utils/MetricUnitUtil.js.map +1 -0
- package/build/dist/Utils/Metrics/MetricFormulaEvaluator.js +453 -0
- package/build/dist/Utils/Metrics/MetricFormulaEvaluator.js.map +1 -0
- package/build/dist/Utils/Metrics/MetricResultUnitConverter.js +61 -0
- package/build/dist/Utils/Metrics/MetricResultUnitConverter.js.map +1 -0
- package/build/dist/Utils/Metrics/RecordingRuleExpression.js +298 -0
- package/build/dist/Utils/Metrics/RecordingRuleExpression.js.map +1 -0
- package/build/dist/Utils/ValueFormatter.js +123 -13
- package/build/dist/Utils/ValueFormatter.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,407 @@
|
|
|
1
|
+
import MetricMonitorCriteria from "../../../../../Server/Utils/Monitor/Criteria/MetricMonitorCriteria";
|
|
2
|
+
import { CheckOn, EvaluateOverTimeType, FilterType, NoDataPolicy, } from "../../../../../Types/Monitor/CriteriaFilter";
|
|
3
|
+
import MetricFormulaEvaluator from "../../../../../Utils/Metrics/MetricFormulaEvaluator";
|
|
4
|
+
import MonitorStep from "../../../../../Types/Monitor/MonitorStep";
|
|
5
|
+
import RollingTime from "../../../../../Types/RollingTime/RollingTime";
|
|
6
|
+
import ObjectID from "../../../../../Types/ObjectID";
|
|
7
|
+
/*
|
|
8
|
+
* Light helper that assembles a MonitorStep + MetricMonitorResponse pair
|
|
9
|
+
* for a single metric alias "a" with the supplied native unit, so each
|
|
10
|
+
* test can just tweak the criteria filter + sample values.
|
|
11
|
+
*/
|
|
12
|
+
function buildInputs(input) {
|
|
13
|
+
const aliasData = {
|
|
14
|
+
metricVariable: "a",
|
|
15
|
+
title: "Response Time",
|
|
16
|
+
description: undefined,
|
|
17
|
+
legend: undefined,
|
|
18
|
+
legendUnit: input.metricNativeUnit,
|
|
19
|
+
};
|
|
20
|
+
const queryConfig = {
|
|
21
|
+
metricAliasData: aliasData,
|
|
22
|
+
metricQueryData: {
|
|
23
|
+
filterData: {
|
|
24
|
+
metricName: "response_time",
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
};
|
|
28
|
+
const metricViewConfig = {
|
|
29
|
+
queryConfigs: [queryConfig],
|
|
30
|
+
formulaConfigs: [],
|
|
31
|
+
};
|
|
32
|
+
const monitorStep = new MonitorStep();
|
|
33
|
+
monitorStep.data = {
|
|
34
|
+
id: ObjectID.generate().toString(),
|
|
35
|
+
monitorCriteria: { data: undefined },
|
|
36
|
+
};
|
|
37
|
+
monitorStep.data.metricMonitor = {
|
|
38
|
+
metricViewConfig,
|
|
39
|
+
rollingTime: RollingTime.Past1Minute,
|
|
40
|
+
};
|
|
41
|
+
const aggregated = {
|
|
42
|
+
data: input.sampleValues.map((v) => {
|
|
43
|
+
return {
|
|
44
|
+
timestamp: new Date(),
|
|
45
|
+
value: v,
|
|
46
|
+
};
|
|
47
|
+
}),
|
|
48
|
+
};
|
|
49
|
+
const dataToProcess = {
|
|
50
|
+
projectId: ObjectID.generate(),
|
|
51
|
+
metricResult: [aggregated],
|
|
52
|
+
metricViewConfig,
|
|
53
|
+
monitorId: ObjectID.generate(),
|
|
54
|
+
};
|
|
55
|
+
return {
|
|
56
|
+
criteriaFilter: input.criteriaFilter,
|
|
57
|
+
monitorStep,
|
|
58
|
+
dataToProcess,
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
describe("MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet", () => {
|
|
62
|
+
test("no thresholdUnit → threshold evaluated in metric's native unit (backward compatible)", async () => {
|
|
63
|
+
var _a, _b, _c;
|
|
64
|
+
const criteriaFilter = {
|
|
65
|
+
checkOn: CheckOn.MetricValue,
|
|
66
|
+
filterType: FilterType.GreaterThan,
|
|
67
|
+
value: "2000",
|
|
68
|
+
metricMonitorOptions: {
|
|
69
|
+
metricAlias: "a",
|
|
70
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
71
|
+
},
|
|
72
|
+
};
|
|
73
|
+
const inputs = buildInputs({
|
|
74
|
+
metricNativeUnit: "ms",
|
|
75
|
+
sampleValues: [2500],
|
|
76
|
+
criteriaFilter,
|
|
77
|
+
});
|
|
78
|
+
const message = await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
79
|
+
expect(message).toBeTruthy();
|
|
80
|
+
expect(message).toContain("greater than 2000 ms");
|
|
81
|
+
expect(message).toContain("2500 ms");
|
|
82
|
+
expect((_a = criteriaFilter.metricCriteriaContext) === null || _a === void 0 ? void 0 : _a.unit).toBe("ms");
|
|
83
|
+
expect((_c = (_b = criteriaFilter.metricCriteriaContext) === null || _b === void 0 ? void 0 : _b.breachingSample) === null || _c === void 0 ? void 0 : _c.value).toBe(2500);
|
|
84
|
+
});
|
|
85
|
+
test("thresholdUnit 'sec' with metric in 'ms' converts samples to sec for the comparison + message", async () => {
|
|
86
|
+
var _a, _b, _c;
|
|
87
|
+
const criteriaFilter = {
|
|
88
|
+
checkOn: CheckOn.MetricValue,
|
|
89
|
+
filterType: FilterType.GreaterThan,
|
|
90
|
+
value: "2",
|
|
91
|
+
metricMonitorOptions: {
|
|
92
|
+
metricAlias: "a",
|
|
93
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
94
|
+
thresholdUnit: "sec",
|
|
95
|
+
},
|
|
96
|
+
};
|
|
97
|
+
// 2500 ms == 2.5 sec — should breach "greater than 2 sec"
|
|
98
|
+
const inputs = buildInputs({
|
|
99
|
+
metricNativeUnit: "ms",
|
|
100
|
+
sampleValues: [2500],
|
|
101
|
+
criteriaFilter,
|
|
102
|
+
});
|
|
103
|
+
const message = await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
104
|
+
expect(message).toBeTruthy();
|
|
105
|
+
expect(message).toContain("greater than 2 sec");
|
|
106
|
+
expect(message).toContain("2.5 sec");
|
|
107
|
+
expect((_a = criteriaFilter.metricCriteriaContext) === null || _a === void 0 ? void 0 : _a.unit).toBe("sec");
|
|
108
|
+
expect((_c = (_b = criteriaFilter.metricCriteriaContext) === null || _b === void 0 ? void 0 : _b.breachingSample) === null || _c === void 0 ? void 0 : _c.value).toBe(2.5);
|
|
109
|
+
});
|
|
110
|
+
test("thresholdUnit 'GB' with metric in 'bytes' breaches on 2.5 GB > 2 GB", async () => {
|
|
111
|
+
var _a;
|
|
112
|
+
const criteriaFilter = {
|
|
113
|
+
checkOn: CheckOn.MetricValue,
|
|
114
|
+
filterType: FilterType.GreaterThan,
|
|
115
|
+
value: "2",
|
|
116
|
+
metricMonitorOptions: {
|
|
117
|
+
metricAlias: "a",
|
|
118
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
119
|
+
thresholdUnit: "GB",
|
|
120
|
+
},
|
|
121
|
+
};
|
|
122
|
+
const inputs = buildInputs({
|
|
123
|
+
metricNativeUnit: "bytes",
|
|
124
|
+
sampleValues: [2.5e9],
|
|
125
|
+
criteriaFilter,
|
|
126
|
+
});
|
|
127
|
+
const message = await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
128
|
+
expect(message).toBeTruthy();
|
|
129
|
+
expect(message).toContain("greater than 2 GB");
|
|
130
|
+
expect(message).toContain("2.5 GB");
|
|
131
|
+
expect((_a = criteriaFilter.metricCriteriaContext) === null || _a === void 0 ? void 0 : _a.unit).toBe("GB");
|
|
132
|
+
});
|
|
133
|
+
test("thresholdUnit 'GB' — under-threshold samples do not trigger", async () => {
|
|
134
|
+
const criteriaFilter = {
|
|
135
|
+
checkOn: CheckOn.MetricValue,
|
|
136
|
+
filterType: FilterType.GreaterThan,
|
|
137
|
+
value: "2",
|
|
138
|
+
metricMonitorOptions: {
|
|
139
|
+
metricAlias: "a",
|
|
140
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
141
|
+
thresholdUnit: "GB",
|
|
142
|
+
},
|
|
143
|
+
};
|
|
144
|
+
// 1.5 GB = 1.5e9 bytes — under 2 GB, should NOT breach.
|
|
145
|
+
const inputs = buildInputs({
|
|
146
|
+
metricNativeUnit: "bytes",
|
|
147
|
+
sampleValues: [1.5e9],
|
|
148
|
+
criteriaFilter,
|
|
149
|
+
});
|
|
150
|
+
const message = await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
151
|
+
expect(message).toBeNull();
|
|
152
|
+
});
|
|
153
|
+
test("thresholdUnit in an incompatible family falls back gracefully (no conversion)", async () => {
|
|
154
|
+
/*
|
|
155
|
+
* User incorrectly picked 'MB' but metric is in ms. Conversion should
|
|
156
|
+
* no-op and comparison proceeds in the user's raw unit.
|
|
157
|
+
*/
|
|
158
|
+
const criteriaFilter = {
|
|
159
|
+
checkOn: CheckOn.MetricValue,
|
|
160
|
+
filterType: FilterType.GreaterThan,
|
|
161
|
+
value: "1000",
|
|
162
|
+
metricMonitorOptions: {
|
|
163
|
+
metricAlias: "a",
|
|
164
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
165
|
+
thresholdUnit: "MB",
|
|
166
|
+
},
|
|
167
|
+
};
|
|
168
|
+
const inputs = buildInputs({
|
|
169
|
+
metricNativeUnit: "ms",
|
|
170
|
+
sampleValues: [5000],
|
|
171
|
+
criteriaFilter,
|
|
172
|
+
});
|
|
173
|
+
const message = await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
174
|
+
/*
|
|
175
|
+
* No conversion possible, so the displayed unit/values use user's MB
|
|
176
|
+
* label but values are passed through.
|
|
177
|
+
*/
|
|
178
|
+
expect(message).toBeTruthy();
|
|
179
|
+
expect(message).toContain("MB");
|
|
180
|
+
});
|
|
181
|
+
test("no data + NoDataPolicy.Trigger triggers regardless of threshold", async () => {
|
|
182
|
+
const criteriaFilter = {
|
|
183
|
+
checkOn: CheckOn.MetricValue,
|
|
184
|
+
filterType: FilterType.GreaterThan,
|
|
185
|
+
value: "2",
|
|
186
|
+
metricMonitorOptions: {
|
|
187
|
+
metricAlias: "a",
|
|
188
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
189
|
+
thresholdUnit: "GB",
|
|
190
|
+
onNoDataPolicy: NoDataPolicy.Trigger,
|
|
191
|
+
},
|
|
192
|
+
};
|
|
193
|
+
const inputs = buildInputs({
|
|
194
|
+
metricNativeUnit: "bytes",
|
|
195
|
+
sampleValues: [],
|
|
196
|
+
criteriaFilter,
|
|
197
|
+
});
|
|
198
|
+
const message = await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
199
|
+
expect(message).toBeTruthy();
|
|
200
|
+
expect(message).toContain("No data received");
|
|
201
|
+
});
|
|
202
|
+
test("breaching sample value is recorded in the user's chosen display unit", async () => {
|
|
203
|
+
var _a, _b, _c;
|
|
204
|
+
const criteriaFilter = {
|
|
205
|
+
checkOn: CheckOn.MetricValue,
|
|
206
|
+
filterType: FilterType.GreaterThan,
|
|
207
|
+
value: "1",
|
|
208
|
+
metricMonitorOptions: {
|
|
209
|
+
metricAlias: "a",
|
|
210
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
211
|
+
thresholdUnit: "sec",
|
|
212
|
+
},
|
|
213
|
+
};
|
|
214
|
+
const inputs = buildInputs({
|
|
215
|
+
metricNativeUnit: "ms",
|
|
216
|
+
sampleValues: [500, 3000, 800],
|
|
217
|
+
criteriaFilter,
|
|
218
|
+
});
|
|
219
|
+
await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
220
|
+
expect((_b = (_a = criteriaFilter.metricCriteriaContext) === null || _a === void 0 ? void 0 : _a.breachingSample) === null || _b === void 0 ? void 0 : _b.value).toBe(3);
|
|
221
|
+
expect((_c = criteriaFilter.metricCriteriaContext) === null || _c === void 0 ? void 0 : _c.unit).toBe("sec");
|
|
222
|
+
});
|
|
223
|
+
test("collects every breaching sample and totalSamplesInWindow", async () => {
|
|
224
|
+
var _a, _b;
|
|
225
|
+
const criteriaFilter = {
|
|
226
|
+
checkOn: CheckOn.MetricValue,
|
|
227
|
+
filterType: FilterType.GreaterThan,
|
|
228
|
+
value: "100",
|
|
229
|
+
metricMonitorOptions: {
|
|
230
|
+
metricAlias: "a",
|
|
231
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
232
|
+
},
|
|
233
|
+
};
|
|
234
|
+
const inputs = buildInputs({
|
|
235
|
+
metricNativeUnit: "ms",
|
|
236
|
+
// 4 breach (>100), 1 does not
|
|
237
|
+
sampleValues: [120, 150, 80, 200, 300],
|
|
238
|
+
criteriaFilter,
|
|
239
|
+
});
|
|
240
|
+
await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
241
|
+
const ctx = criteriaFilter.metricCriteriaContext;
|
|
242
|
+
expect(ctx.totalSamplesInWindow).toBe(5);
|
|
243
|
+
expect(ctx.breachingSamples).toBeDefined();
|
|
244
|
+
expect((_a = ctx.breachingSamples) === null || _a === void 0 ? void 0 : _a.length).toBe(4);
|
|
245
|
+
expect((_b = ctx.breachingSamples) === null || _b === void 0 ? void 0 : _b.map((s) => {
|
|
246
|
+
return s.value;
|
|
247
|
+
})).toEqual([120, 150, 200, 300]);
|
|
248
|
+
});
|
|
249
|
+
test("formula criteria populates components and per-sample component values", async () => {
|
|
250
|
+
var _a, _b, _c, _d;
|
|
251
|
+
// Build two query configs (a: ms, b: ms) and a formula c = a + b (ms).
|
|
252
|
+
const sharedTimestamps = [
|
|
253
|
+
new Date("2026-04-20T11:00:00.000Z"),
|
|
254
|
+
new Date("2026-04-20T11:01:00.000Z"),
|
|
255
|
+
];
|
|
256
|
+
const queryA = {
|
|
257
|
+
metricAliasData: {
|
|
258
|
+
metricVariable: "a",
|
|
259
|
+
title: "",
|
|
260
|
+
description: "",
|
|
261
|
+
legend: "",
|
|
262
|
+
legendUnit: "ms",
|
|
263
|
+
},
|
|
264
|
+
metricQueryData: {
|
|
265
|
+
filterData: {
|
|
266
|
+
metricName: "request_latency",
|
|
267
|
+
},
|
|
268
|
+
},
|
|
269
|
+
};
|
|
270
|
+
const queryB = {
|
|
271
|
+
metricAliasData: {
|
|
272
|
+
metricVariable: "b",
|
|
273
|
+
title: "",
|
|
274
|
+
description: "",
|
|
275
|
+
legend: "",
|
|
276
|
+
legendUnit: "ms",
|
|
277
|
+
},
|
|
278
|
+
metricQueryData: {
|
|
279
|
+
filterData: {
|
|
280
|
+
metricName: "db_latency",
|
|
281
|
+
},
|
|
282
|
+
},
|
|
283
|
+
};
|
|
284
|
+
const formulaC = {
|
|
285
|
+
metricAliasData: {
|
|
286
|
+
metricVariable: "c",
|
|
287
|
+
title: "",
|
|
288
|
+
description: "",
|
|
289
|
+
legend: "",
|
|
290
|
+
legendUnit: "ms",
|
|
291
|
+
},
|
|
292
|
+
metricFormulaData: {
|
|
293
|
+
metricFormula: "a + b",
|
|
294
|
+
},
|
|
295
|
+
};
|
|
296
|
+
const queryAResult = {
|
|
297
|
+
data: [
|
|
298
|
+
{ timestamp: sharedTimestamps[0], value: 40 },
|
|
299
|
+
{ timestamp: sharedTimestamps[1], value: 60 },
|
|
300
|
+
],
|
|
301
|
+
};
|
|
302
|
+
const queryBResult = {
|
|
303
|
+
data: [
|
|
304
|
+
{ timestamp: sharedTimestamps[0], value: 70 },
|
|
305
|
+
{ timestamp: sharedTimestamps[1], value: 80 },
|
|
306
|
+
],
|
|
307
|
+
};
|
|
308
|
+
/*
|
|
309
|
+
* c = a + b, evaluated via the shared evaluator so the synthetic series
|
|
310
|
+
* matches the production code path exactly.
|
|
311
|
+
*/
|
|
312
|
+
const formulaCResult = MetricFormulaEvaluator.evaluateFormula({
|
|
313
|
+
formula: "a + b",
|
|
314
|
+
queryConfigs: [queryA, queryB],
|
|
315
|
+
formulaConfigs: [],
|
|
316
|
+
results: [queryAResult, queryBResult],
|
|
317
|
+
});
|
|
318
|
+
const metricViewConfig = {
|
|
319
|
+
queryConfigs: [queryA, queryB],
|
|
320
|
+
formulaConfigs: [formulaC],
|
|
321
|
+
};
|
|
322
|
+
const monitorStep = new MonitorStep();
|
|
323
|
+
monitorStep.data = {
|
|
324
|
+
id: ObjectID.generate().toString(),
|
|
325
|
+
monitorCriteria: { data: undefined },
|
|
326
|
+
};
|
|
327
|
+
monitorStep.data.metricMonitor = {
|
|
328
|
+
metricViewConfig,
|
|
329
|
+
rollingTime: RollingTime.Past1Minute,
|
|
330
|
+
};
|
|
331
|
+
const dataToProcess = {
|
|
332
|
+
projectId: ObjectID.generate(),
|
|
333
|
+
metricResult: [queryAResult, queryBResult, formulaCResult],
|
|
334
|
+
metricViewConfig,
|
|
335
|
+
monitorId: ObjectID.generate(),
|
|
336
|
+
};
|
|
337
|
+
const criteriaFilter = {
|
|
338
|
+
checkOn: CheckOn.MetricValue,
|
|
339
|
+
filterType: FilterType.GreaterThan,
|
|
340
|
+
value: "100",
|
|
341
|
+
metricMonitorOptions: {
|
|
342
|
+
metricAlias: "c",
|
|
343
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
344
|
+
},
|
|
345
|
+
};
|
|
346
|
+
await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet({
|
|
347
|
+
criteriaFilter,
|
|
348
|
+
monitorStep,
|
|
349
|
+
dataToProcess,
|
|
350
|
+
});
|
|
351
|
+
const ctx = criteriaFilter.metricCriteriaContext;
|
|
352
|
+
expect(ctx.isFormula).toBe(true);
|
|
353
|
+
expect(ctx.formulaExpression).toBe("a + b");
|
|
354
|
+
// Components describe each formula variable with its source metric + unit.
|
|
355
|
+
expect(ctx.components).toBeDefined();
|
|
356
|
+
expect((_a = ctx.components) === null || _a === void 0 ? void 0 : _a.length).toBe(2);
|
|
357
|
+
expect((_b = ctx.components) === null || _b === void 0 ? void 0 : _b[0]).toMatchObject({
|
|
358
|
+
alias: "a",
|
|
359
|
+
name: "request_latency",
|
|
360
|
+
unit: "ms",
|
|
361
|
+
isFormula: false,
|
|
362
|
+
});
|
|
363
|
+
expect((_c = ctx.components) === null || _c === void 0 ? void 0 : _c[1]).toMatchObject({
|
|
364
|
+
alias: "b",
|
|
365
|
+
name: "db_latency",
|
|
366
|
+
unit: "ms",
|
|
367
|
+
});
|
|
368
|
+
// Both formula points breach > 100 (40+70=110, 60+80=140).
|
|
369
|
+
expect((_d = ctx.breachingSamples) === null || _d === void 0 ? void 0 : _d.length).toBe(2);
|
|
370
|
+
const first = ctx.breachingSamples[0];
|
|
371
|
+
expect(first.value).toBe(110);
|
|
372
|
+
expect(first.componentValues).toBeDefined();
|
|
373
|
+
expect(first.componentValues).toEqual([
|
|
374
|
+
{ alias: "a", value: 40 },
|
|
375
|
+
{ alias: "b", value: 70 },
|
|
376
|
+
]);
|
|
377
|
+
const second = ctx.breachingSamples[1];
|
|
378
|
+
expect(second.value).toBe(140);
|
|
379
|
+
expect(second.componentValues).toEqual([
|
|
380
|
+
{ alias: "a", value: 60 },
|
|
381
|
+
{ alias: "b", value: 80 },
|
|
382
|
+
]);
|
|
383
|
+
});
|
|
384
|
+
test("summarises Filter Conditions Met when more than 5 values breach", async () => {
|
|
385
|
+
const criteriaFilter = {
|
|
386
|
+
checkOn: CheckOn.MetricValue,
|
|
387
|
+
filterType: FilterType.GreaterThan,
|
|
388
|
+
value: "100",
|
|
389
|
+
metricMonitorOptions: {
|
|
390
|
+
metricAlias: "a",
|
|
391
|
+
metricAggregationType: EvaluateOverTimeType.AnyValue,
|
|
392
|
+
},
|
|
393
|
+
};
|
|
394
|
+
const inputs = buildInputs({
|
|
395
|
+
metricNativeUnit: "ms",
|
|
396
|
+
sampleValues: [110, 120, 130, 140, 150, 160, 170, 180, 190, 200],
|
|
397
|
+
criteriaFilter,
|
|
398
|
+
});
|
|
399
|
+
const message = await MetricMonitorCriteria.isMonitorInstanceCriteriaFilterMet(inputs);
|
|
400
|
+
expect(message).toBeTruthy();
|
|
401
|
+
expect(message).toContain("10 samples between 110 and 200");
|
|
402
|
+
expect(message).toContain("greater than 100 ms");
|
|
403
|
+
// The raw comma-joined dump is no longer in the message
|
|
404
|
+
expect(message).not.toContain("110, 120, 130, 140, 150, 160");
|
|
405
|
+
});
|
|
406
|
+
});
|
|
407
|
+
//# sourceMappingURL=MetricMonitorCriteria.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetricMonitorCriteria.test.js","sourceRoot":"","sources":["../../../../../../../Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -19,11 +19,8 @@ describe("ProgressBar Component", () => {
|
|
|
19
19
|
test("should display the correct count and total count with suffix", () => {
|
|
20
20
|
render(React.createElement(ProgressBar, { count: 30, totalCount: 99, suffix: "items" }));
|
|
21
21
|
const countText = screen.getByTestId("progress-bar-count");
|
|
22
|
-
const totalCountText = screen.getByTestId("progress-bar-total-count");
|
|
23
22
|
expect(countText).toBeInTheDocument();
|
|
24
|
-
expect(
|
|
25
|
-
expect(countText.innerHTML).toEqual("30 items");
|
|
26
|
-
expect(totalCountText.innerHTML).toEqual("99 items");
|
|
23
|
+
expect(countText.innerHTML).toEqual("30 of 99 items");
|
|
27
24
|
});
|
|
28
25
|
test("should handle zero total count without crashing", () => {
|
|
29
26
|
render(React.createElement(ProgressBar, { count: 30, totalCount: 0, suffix: "items" }));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProgressBar.test.js","sourceRoot":"","sources":["../../../../../Tests/UI/Components/ProgressBar.test.tsx"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,gDAAgD,CAAC;AACzE,OAAO,yCAAyC,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAEvD,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,SAAS,cAAc;QACrB,MAAM,OAAO,GAAgB,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;QAChE,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,WAAW,CAAC;QACpB,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,IAAI,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC/D,MAAM,CAAC,oBAAC,WAAW,IAAC,KAAK,EAAE,CAAC,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,EAAC,OAAO,GAAG,CAAC,CAAC;QAClE,MAAM,WAAW,GAAgB,cAAc,EAAE,CAAC;QAClD,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8DAA8D,EAAE,GAAG,EAAE;QACxE,MAAM,CAAC,oBAAC,WAAW,IAAC,KAAK,EAAE,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,MAAM,EAAC,OAAO,GAAG,CAAC,CAAC;QAClE,MAAM,SAAS,GAAgB,MAAM,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAAC;QACxE,MAAM,
|
|
1
|
+
{"version":3,"file":"ProgressBar.test.js","sourceRoot":"","sources":["../../../../../Tests/UI/Components/ProgressBar.test.tsx"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,gDAAgD,CAAC;AACzE,OAAO,yCAAyC,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAEvD,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,SAAS,cAAc;QACrB,MAAM,OAAO,GAAgB,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;QAChE,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,WAAW,CAAC;QACpB,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,IAAI,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC/D,MAAM,CAAC,oBAAC,WAAW,IAAC,KAAK,EAAE,CAAC,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,EAAC,OAAO,GAAG,CAAC,CAAC;QAClE,MAAM,WAAW,GAAgB,cAAc,EAAE,CAAC;QAClD,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8DAA8D,EAAE,GAAG,EAAE;QACxE,MAAM,CAAC,oBAAC,WAAW,IAAC,KAAK,EAAE,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,MAAM,EAAC,OAAO,GAAG,CAAC,CAAC;QAClE,MAAM,SAAS,GAAgB,MAAM,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAAC;QACxE,MAAM,CAAC,SAAS,CAAC,CAAC,iBAAiB,EAAE,CAAC;QAEtC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iDAAiD,EAAE,GAAG,EAAE;QAC3D,MAAM,CAAC,oBAAC,WAAW,IAAC,KAAK,EAAE,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,MAAM,EAAC,OAAO,GAAG,CAAC,CAAC;QACjE,MAAM,WAAW,GAAgB,cAAc,EAAE,CAAC;QAClD,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,uDAAuD,EAAE,GAAG,EAAE;QACjE,MAAM,CAAC,oBAAC,WAAW,IAAC,KAAK,EAAE,EAAE,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,EAAC,OAAO,GAAG,CAAC,CAAC;QACnE,MAAM,WAAW,GAAgB,cAAc,EAAE,CAAC;QAClD,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACzE,MAAM,CAAC,oBAAC,WAAW,IAAC,KAAK,EAAE,GAAG,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,EAAC,OAAO,GAAG,CAAC,CAAC;QACpE,MAAM,WAAW,GAAgB,cAAc,EAAE,CAAC;QAClD,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import MetricUnitUtil from "../../Utils/MetricUnitUtil";
|
|
2
|
+
describe("MetricUnitUtil", () => {
|
|
3
|
+
describe("getCompatibleUnits", () => {
|
|
4
|
+
test("returns empty array for undefined / empty unit", () => {
|
|
5
|
+
expect(MetricUnitUtil.getCompatibleUnits(undefined)).toEqual([]);
|
|
6
|
+
expect(MetricUnitUtil.getCompatibleUnits("")).toEqual([]);
|
|
7
|
+
expect(MetricUnitUtil.getCompatibleUnits(" ")).toEqual([]);
|
|
8
|
+
});
|
|
9
|
+
test("returns byte family for 'bytes'", () => {
|
|
10
|
+
const options = MetricUnitUtil.getCompatibleUnits("bytes");
|
|
11
|
+
const values = options.map((o) => {
|
|
12
|
+
return o.value;
|
|
13
|
+
});
|
|
14
|
+
expect(values).toEqual(["B", "KB", "MB", "GB", "TB", "PB"]);
|
|
15
|
+
});
|
|
16
|
+
test("returns byte family for UCUM 'By' code", () => {
|
|
17
|
+
const options = MetricUnitUtil.getCompatibleUnits("By");
|
|
18
|
+
expect(options.length).toBe(6);
|
|
19
|
+
expect(options[0].value).toBe("B");
|
|
20
|
+
});
|
|
21
|
+
test("returns time family for 'ms'", () => {
|
|
22
|
+
const values = MetricUnitUtil.getCompatibleUnits("ms").map((o) => {
|
|
23
|
+
return o.value;
|
|
24
|
+
});
|
|
25
|
+
expect(values).toEqual(["ns", "µs", "ms", "sec", "min", "hours", "days"]);
|
|
26
|
+
});
|
|
27
|
+
test("returns time family for 's'", () => {
|
|
28
|
+
const values = MetricUnitUtil.getCompatibleUnits("s").map((o) => {
|
|
29
|
+
return o.value;
|
|
30
|
+
});
|
|
31
|
+
expect(values).toContain("sec");
|
|
32
|
+
expect(values).toContain("ms");
|
|
33
|
+
expect(values).toContain("hours");
|
|
34
|
+
});
|
|
35
|
+
test("returns percent family for '%'", () => {
|
|
36
|
+
const options = MetricUnitUtil.getCompatibleUnits("%");
|
|
37
|
+
expect(options).toEqual([{ value: "%", label: "Percent (%)" }]);
|
|
38
|
+
});
|
|
39
|
+
test("returns raw unit as sole option for unknown unit", () => {
|
|
40
|
+
const options = MetricUnitUtil.getCompatibleUnits("widgets");
|
|
41
|
+
expect(options).toEqual([{ value: "widgets", label: "widgets" }]);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
describe("getCanonicalUnitValue", () => {
|
|
45
|
+
test("returns canonical value for aliases", () => {
|
|
46
|
+
expect(MetricUnitUtil.getCanonicalUnitValue("bytes")).toBe("B");
|
|
47
|
+
expect(MetricUnitUtil.getCanonicalUnitValue("Byte")).toBe("B");
|
|
48
|
+
expect(MetricUnitUtil.getCanonicalUnitValue("MB")).toBe("MB");
|
|
49
|
+
expect(MetricUnitUtil.getCanonicalUnitValue("milliseconds")).toBe("ms");
|
|
50
|
+
expect(MetricUnitUtil.getCanonicalUnitValue("second")).toBe("sec");
|
|
51
|
+
expect(MetricUnitUtil.getCanonicalUnitValue("percent")).toBe("%");
|
|
52
|
+
});
|
|
53
|
+
test("passes through unknown units", () => {
|
|
54
|
+
expect(MetricUnitUtil.getCanonicalUnitValue("widgets")).toBe("widgets");
|
|
55
|
+
});
|
|
56
|
+
test("returns undefined for empty", () => {
|
|
57
|
+
expect(MetricUnitUtil.getCanonicalUnitValue(undefined)).toBeUndefined();
|
|
58
|
+
expect(MetricUnitUtil.getCanonicalUnitValue("")).toBeUndefined();
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
describe("convertToMetricUnit", () => {
|
|
62
|
+
test("no conversion when units match", () => {
|
|
63
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
64
|
+
value: 123,
|
|
65
|
+
fromUnit: "MB",
|
|
66
|
+
metricUnit: "MB",
|
|
67
|
+
})).toBe(123);
|
|
68
|
+
});
|
|
69
|
+
test("converts MB to bytes", () => {
|
|
70
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
71
|
+
value: 2,
|
|
72
|
+
fromUnit: "MB",
|
|
73
|
+
metricUnit: "bytes",
|
|
74
|
+
})).toBe(2e6);
|
|
75
|
+
});
|
|
76
|
+
test("converts bytes to GB", () => {
|
|
77
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
78
|
+
value: 5e9,
|
|
79
|
+
fromUnit: "bytes",
|
|
80
|
+
metricUnit: "GB",
|
|
81
|
+
})).toBe(5);
|
|
82
|
+
});
|
|
83
|
+
test("converts sec to ms", () => {
|
|
84
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
85
|
+
value: 2,
|
|
86
|
+
fromUnit: "sec",
|
|
87
|
+
metricUnit: "ms",
|
|
88
|
+
})).toBe(2000);
|
|
89
|
+
});
|
|
90
|
+
test("converts ms to sec", () => {
|
|
91
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
92
|
+
value: 1500,
|
|
93
|
+
fromUnit: "ms",
|
|
94
|
+
metricUnit: "sec",
|
|
95
|
+
})).toBe(1.5);
|
|
96
|
+
});
|
|
97
|
+
test("converts min to sec", () => {
|
|
98
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
99
|
+
value: 2,
|
|
100
|
+
fromUnit: "min",
|
|
101
|
+
metricUnit: "sec",
|
|
102
|
+
})).toBe(120);
|
|
103
|
+
});
|
|
104
|
+
test("converts hours to ms", () => {
|
|
105
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
106
|
+
value: 1,
|
|
107
|
+
fromUnit: "hours",
|
|
108
|
+
metricUnit: "ms",
|
|
109
|
+
})).toBe(3600000);
|
|
110
|
+
});
|
|
111
|
+
test("returns value unchanged when units are from different families", () => {
|
|
112
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
113
|
+
value: 100,
|
|
114
|
+
fromUnit: "MB",
|
|
115
|
+
metricUnit: "sec",
|
|
116
|
+
})).toBe(100);
|
|
117
|
+
});
|
|
118
|
+
test("returns value unchanged when metric unit is unknown", () => {
|
|
119
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
120
|
+
value: 100,
|
|
121
|
+
fromUnit: "MB",
|
|
122
|
+
metricUnit: "widgets",
|
|
123
|
+
})).toBe(100);
|
|
124
|
+
});
|
|
125
|
+
test("returns value unchanged when either unit is missing", () => {
|
|
126
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
127
|
+
value: 100,
|
|
128
|
+
fromUnit: undefined,
|
|
129
|
+
metricUnit: "bytes",
|
|
130
|
+
})).toBe(100);
|
|
131
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
132
|
+
value: 100,
|
|
133
|
+
fromUnit: "MB",
|
|
134
|
+
metricUnit: undefined,
|
|
135
|
+
})).toBe(100);
|
|
136
|
+
});
|
|
137
|
+
test("handles case-insensitive unit matching", () => {
|
|
138
|
+
expect(MetricUnitUtil.convertToMetricUnit({
|
|
139
|
+
value: 2,
|
|
140
|
+
fromUnit: "gb",
|
|
141
|
+
metricUnit: "BYTES",
|
|
142
|
+
})).toBe(2e9);
|
|
143
|
+
});
|
|
144
|
+
});
|
|
145
|
+
describe("hasCompatibleUnitFamily", () => {
|
|
146
|
+
test("true for known families", () => {
|
|
147
|
+
expect(MetricUnitUtil.hasCompatibleUnitFamily("bytes")).toBe(true);
|
|
148
|
+
expect(MetricUnitUtil.hasCompatibleUnitFamily("ms")).toBe(true);
|
|
149
|
+
expect(MetricUnitUtil.hasCompatibleUnitFamily("%")).toBe(true);
|
|
150
|
+
expect(MetricUnitUtil.hasCompatibleUnitFamily("GB")).toBe(true);
|
|
151
|
+
});
|
|
152
|
+
test("false for unknown or empty", () => {
|
|
153
|
+
expect(MetricUnitUtil.hasCompatibleUnitFamily(undefined)).toBe(false);
|
|
154
|
+
expect(MetricUnitUtil.hasCompatibleUnitFamily("")).toBe(false);
|
|
155
|
+
expect(MetricUnitUtil.hasCompatibleUnitFamily("widgets")).toBe(false);
|
|
156
|
+
});
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
//# sourceMappingURL=MetricUnitUtil.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetricUnitUtil.test.js","sourceRoot":"","sources":["../../../../Tests/Utils/MetricUnitUtil.test.ts"],"names":[],"mappings":"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"}
|