From 508ab6521995eb044b16f6be15839d64de8c39e5 Mon Sep 17 00:00:00 2001 From: Nikita Indik Date: Thu, 4 May 2023 10:07:42 +0200 Subject: [PATCH] [Security Solution] Maintenance Window callout: Update tests to match the test plan (#156532) ## Summary This PR updates Maintenance Window callout tests to match the test plan. Maintenance Window callout is shown on the Rules Management page when there's a Maintenance Window running. 233624339-9c9b6e3e-9e5e-424d-9d19-9cd7d4e92259 [**Test plan** (internal)](https://docs.google.com/document/d/1NTTbV7FemZR8LVwWBbDW3Jji58Wy2-n-YGycD698RR8/edit?usp=sharing ) [**Maintenance Window Callout issue**](https://github.com/elastic/kibana/issues/155099) with more info about the feature --- .../maintenance_window_callout.test.tsx | 47 ++++++++++++++++--- 1 file changed, 41 insertions(+), 6 deletions(-) diff --git a/x-pack/plugins/security_solution/public/detection_engine/rule_management_ui/components/maintenance_window_callout/maintenance_window_callout.test.tsx b/x-pack/plugins/security_solution/public/detection_engine/rule_management_ui/components/maintenance_window_callout/maintenance_window_callout.test.tsx index 5cd752fcf516d..cc40e53f65667 100644 --- a/x-pack/plugins/security_solution/public/detection_engine/rule_management_ui/components/maintenance_window_callout/maintenance_window_callout.test.tsx +++ b/x-pack/plugins/security_solution/public/detection_engine/rule_management_ui/components/maintenance_window_callout/maintenance_window_callout.test.tsx @@ -13,6 +13,7 @@ import { MAINTENANCE_WINDOW_FEATURE_ID, } from '@kbn/alerting-plugin/common'; import type { MaintenanceWindow } from '@kbn/alerting-plugin/common'; +import type { AsApiContract } from '@kbn/alerting-plugin/server/routes/lib'; import { useKibana } from '../../../../common/lib/kibana'; import { useAppToasts } from '../../../../common/hooks/use_app_toasts'; import { useAppToastsMock } from '../../../../common/hooks/use_app_toasts.mock'; @@ -29,19 +30,38 @@ jest.mock('./api', () => ({ jest.mock('../../../../common/lib/kibana'); const RUNNING_MAINTENANCE_WINDOW_1: Partial = { - title: 'Maintenance window 1', + title: 'Running maintenance window 1', id: '63057284-ac31-42ba-fe22-adfe9732e5ae', status: MaintenanceWindowStatus.Running, events: [{ gte: '2023-04-20T16:27:30.753Z', lte: '2023-04-20T16:57:30.753Z' }], }; const RUNNING_MAINTENANCE_WINDOW_2: Partial = { - title: 'Maintenance window 2', + title: 'Running maintenance window 2', id: '45894340-df98-11ed-ac81-bfcb4982b4fd', status: MaintenanceWindowStatus.Running, events: [{ gte: '2023-04-20T16:47:42.871Z', lte: '2023-04-20T17:11:32.192Z' }], }; +const RECURRING_RUNNING_MAINTENANCE_WINDOW: Partial> = { + title: 'Recurring running maintenance window', + id: 'e2228300-e9ad-11ed-ba37-db17c6e6182b', + status: MaintenanceWindowStatus.Running, + events: [ + { gte: '2023-05-03T12:27:18.569Z', lte: '2023-05-03T12:57:18.569Z' }, + { gte: '2023-05-10T12:27:18.569Z', lte: '2023-05-10T12:57:18.569Z' }, + ], + expiration_date: '2024-05-03T12:27:35.088Z', + r_rule: { + dtstart: '2023-05-03T12:27:18.569Z', + tzid: 'Europe/Amsterdam', + freq: 3, + interval: 1, + count: 2, + byweekday: ['WE'], + }, +}; + const UPCOMING_MAINTENANCE_WINDOW: Partial = { title: 'Upcoming maintenance window', id: '5eafe070-e030-11ed-ac81-bfcb4982b4fd', @@ -85,9 +105,10 @@ describe('MaintenanceWindowCallout', () => { it('should be visible if currently there is at least one "running" maintenance window', async () => { fetchActiveMaintenanceWindowsMock.mockResolvedValue([RUNNING_MAINTENANCE_WINDOW_1]); - const { findByText } = render(, { wrapper: TestProviders }); + const { findAllByText } = render(, { wrapper: TestProviders }); - expect(await findByText('A maintenance window is currently running')).toBeInTheDocument(); + expect(await findAllByText('A maintenance window is currently running')).toHaveLength(1); + expect(fetchActiveMaintenanceWindowsMock).toHaveBeenCalledTimes(1); }); it('should be visible if currently there are multiple "running" maintenance windows', async () => { @@ -99,22 +120,36 @@ describe('MaintenanceWindowCallout', () => { const { findAllByText } = render(, { wrapper: TestProviders }); expect(await findAllByText('A maintenance window is currently running')).toHaveLength(1); + expect(fetchActiveMaintenanceWindowsMock).toHaveBeenCalledTimes(1); + }); + + it('should be visible if currently there is a recurring "running" maintenance window', async () => { + fetchActiveMaintenanceWindowsMock.mockResolvedValue([RECURRING_RUNNING_MAINTENANCE_WINDOW]); + + const { findByText } = render(, { wrapper: TestProviders }); + + expect(await findByText('A maintenance window is currently running')).toBeInTheDocument(); + expect(fetchActiveMaintenanceWindowsMock).toHaveBeenCalledTimes(1); }); it('should NOT be visible if currently there are no active (running or upcoming) maintenance windows', async () => { - fetchActiveMaintenanceWindowsMock.mockResolvedValue([]); + fetchActiveMaintenanceWindowsMock.mockResolvedValue( + [] // API returns an empty array if there are no active maintenance windows + ); const { container } = render(, { wrapper: TestProviders }); expect(container).toBeEmptyDOMElement(); + expect(fetchActiveMaintenanceWindowsMock).toHaveBeenCalledTimes(1); }); - it('should NOT be visible if currently there are no "running" maintenance windows', async () => { + it('should NOT be visible if currently there are only "upcoming" maintenance windows', async () => { fetchActiveMaintenanceWindowsMock.mockResolvedValue([UPCOMING_MAINTENANCE_WINDOW]); const { container } = render(, { wrapper: TestProviders }); expect(container).toBeEmptyDOMElement(); + expect(fetchActiveMaintenanceWindowsMock).toHaveBeenCalledTimes(1); }); it('should see an error toast if there was an error while fetching maintenance windows', async () => {