Skip to content

Commit

Permalink
[Synthetics] Remove extra overview route (elastic#192449)
Browse files Browse the repository at this point in the history
## Summary

Remove extra overview route !!

### Testing
Test overview page with filters and paging etc 

<img width="1728" alt="image"
src="https://github.com/user-attachments/assets/a64f7c04-f834-4496-a377-b8bd74542d21">

---------

Co-authored-by: kibanamachine <[email protected]>
  • Loading branch information
shahzad31 and kibanamachine authored Sep 23, 2024
1 parent 2304fb6 commit 5fcc495
Show file tree
Hide file tree
Showing 57 changed files with 1,111 additions and 1,261 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ export enum SYNTHETICS_API_URLS {
SYNTHETICS_PROJECT_APIKEY = '/internal/synthetics/service/api_key',
SYNTHETICS_HAS_INTEGRATION_MONITORS = '/internal/synthetics/fleet/has_integration_monitors',

SYNTHETICS_OVERVIEW = '/internal/synthetics/overview',
PINGS = '/internal/synthetics/pings',
MONITOR_STATUS_HEATMAP = '/internal/synthetics/ping_heatmap',
OVERVIEW_TRENDS = '/internal/synthetics/overview_trends',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
*/

import * as t from 'io-ts';
import { OverviewPingCodec } from '../monitor_management/synthetics_overview_status';

export const SyntheticsCommonStateCodec = t.intersection([
t.partial({
Expand Down Expand Up @@ -36,3 +37,49 @@ export const SyntheticsMonitorStatusAlertStateCodec = t.type({
export type SyntheticsMonitorStatusAlertState = t.TypeOf<
typeof SyntheticsMonitorStatusAlertStateCodec
>;

export const AlertStatusMetaDataCodec = t.interface({
monitorQueryId: t.string,
configId: t.string,
status: t.string,
locationId: t.string,
timestamp: t.string,
ping: OverviewPingCodec,
});

export const StaleAlertStatusMetaDataCodec = t.intersection([
AlertStatusMetaDataCodec,
t.partial({
isDeleted: t.boolean,
isLocationRemoved: t.boolean,
}),
]);

export const AlertPendingStatusMetaDataCodec = t.intersection([
t.interface({
monitorQueryId: t.string,
configId: t.string,
status: t.string,
locationId: t.string,
}),
t.partial({
timestamp: t.string,
ping: OverviewPingCodec,
}),
]);

export const AlertStatusCodec = t.interface({
up: t.number,
down: t.number,
pending: t.number,
upConfigs: t.record(t.string, AlertStatusMetaDataCodec),
downConfigs: t.record(t.string, AlertStatusMetaDataCodec),
pendingConfigs: t.record(t.string, AlertPendingStatusMetaDataCodec),
enabledMonitorQueryIds: t.array(t.string),
staleDownConfigs: t.record(t.string, StaleAlertStatusMetaDataCodec),
});

export type AlertPendingStatusMetaData = t.TypeOf<typeof AlertPendingStatusMetaDataCodec>;
export type StaleDownConfig = t.TypeOf<typeof StaleAlertStatusMetaDataCodec>;
export type AlertStatusMetaData = t.TypeOf<typeof AlertStatusMetaDataCodec>;
export type AlertOverviewStatus = t.TypeOf<typeof AlertStatusCodec>;
Original file line number Diff line number Diff line change
Expand Up @@ -383,30 +383,6 @@ export const MonitorManagementListResultCodec = t.type({
syncErrors: t.union([ServiceLocationErrors, t.null]),
});

export const MonitorOverviewItemCodec = t.intersection([
t.interface({
name: t.string,
id: t.string,
configId: t.string,
location: MonitorServiceLocationCodec,
isEnabled: t.boolean,
isStatusAlertEnabled: t.boolean,
type: t.string,
tags: t.array(t.string),
schedule: t.string,
}),
t.partial({
status: t.string,
projectId: t.string,
}),
]);

export const MonitorOverviewResultCodec = t.type({
total: t.number,
allMonitorIds: t.array(t.string),
monitors: t.array(MonitorOverviewItemCodec),
});

export const SyntheticsMonitorWithSecretsCodec = t.intersection([
EncryptedSyntheticsMonitorCodec,
t.interface({
Expand All @@ -431,8 +407,6 @@ export type EncryptedSyntheticsSavedMonitor = t.TypeOf<typeof EncryptedSynthetic
export type HeartbeatConfig = t.TypeOf<typeof HeartbeatConfigCodec>;
export type MonitorDefaults = t.TypeOf<typeof MonitorDefaultsCodec>;
export type MonitorManagementListResult = t.TypeOf<typeof MonitorManagementListResultCodec>;
export type MonitorOverviewItem = t.TypeOf<typeof MonitorOverviewItemCodec>;
export type MonitorOverviewResult = t.TypeOf<typeof MonitorOverviewResultCodec>;
export type Secret = (typeof secretKeys)[number];
export type SyntheticsMonitorWithSecrets = Omit<
t.TypeOf<typeof SyntheticsMonitorWithSecretsCodec>,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,25 +30,25 @@ export const OverviewPingCodec = t.intersection([
}),
]);

export const OverviewStatusMetaDataCodec = t.interface({
monitorQueryId: t.string,
configId: t.string,
status: t.string,
locationId: t.string,
timestamp: t.string,
ping: OverviewPingCodec,
});

export const OverviewPendingStatusMetaDataCodec = t.intersection([
export const OverviewStatusMetaDataCodec = t.intersection([
t.interface({
monitorQueryId: t.string,
configId: t.string,
status: t.string,
locationId: t.string,
locationLabel: t.string,
name: t.string,
schedule: t.string,
isEnabled: t.boolean,
tags: t.array(t.string),
isStatusAlertEnabled: t.boolean,
type: t.string,
}),
t.partial({
timestamp: t.string,
projectId: t.string,
updated_at: t.string,
ping: OverviewPingCodec,
timestamp: t.string,
}),
]);

Expand All @@ -62,21 +62,13 @@ export const OverviewStatusCodec = t.interface({
disabledCount: t.number,
upConfigs: t.record(t.string, OverviewStatusMetaDataCodec),
downConfigs: t.record(t.string, OverviewStatusMetaDataCodec),
pendingConfigs: t.record(t.string, OverviewPendingStatusMetaDataCodec),
pendingConfigs: t.record(t.string, OverviewStatusMetaDataCodec),
enabledMonitorQueryIds: t.array(t.string),
disabledMonitorQueryIds: t.array(t.string),
allIds: t.array(t.string),
});

export const OverviewStatusStateCodec = t.intersection([
OverviewStatusCodec,
t.interface({
allConfigs: t.record(t.string, OverviewStatusMetaDataCodec),
}),
]);

export type OverviewPing = t.TypeOf<typeof OverviewPingCodec>;
export type OverviewStatus = t.TypeOf<typeof OverviewStatusCodec>;
export type OverviewStatusState = t.TypeOf<typeof OverviewStatusStateCodec>;
export type OverviewStatusState = t.TypeOf<typeof OverviewStatusCodec>;
export type OverviewStatusMetaData = t.TypeOf<typeof OverviewStatusMetaDataCodec>;
export type OverviewPendingStatusMetaData = t.TypeOf<typeof OverviewPendingStatusMetaDataCodec>;
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,19 @@
* 2.0.
*/

import { expect, journey, step } from '@elastic/synthetics';
import { before, expect, journey, step } from '@elastic/synthetics';
import { cleanTestMonitors } from './services/add_monitor';
import { syntheticsAppPageProvider } from '../page_objects/synthetics_app';

journey('TestMonitorDetailFlyout', async ({ page, params }) => {
const syntheticsApp = syntheticsAppPageProvider({ page, kibanaUrl: params.kibanaUrl, params });
const monitorName = 'test-flyout-http-monitor';
const locationId = 'us_central';

before(async () => {
await cleanTestMonitors(params);
});

step('Go to monitor-management', async () => {
await syntheticsApp.navigateToAddMonitor();
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,6 @@ journey('OverviewSorting', async ({ page, params }) => {
await page.waitForSelector(`[data-test-subj="syntheticsOverviewGridItem"]`);
await page.click('[data-test-subj="syntheticsOverviewSortButton"]');
await page.click('button:has-text("Alphabetical")');
await page.waitForSelector(`[data-test-subj="syntheticsOverviewMonitorsLoading"]`);
await page.waitForSelector(`text=${testMonitor1}`);
await page.waitForSelector(`text=${testMonitor2}`);
await page.waitForSelector(`text=${testMonitor3}`);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,12 @@ export const AddToDashboard = ({
data-test-subj="syntheticsEmbeddablePanelWrapperButton"
iconType="boxesHorizontal"
onClick={() => setIsPopoverOpen(!isPopoverOpen)}
aria-label={i18n.translate(
'xpack.synthetics.embeddablePanelWrapper.shareButtonAriaLabel',
{
defaultMessage: 'Add to dashboard',
}
)}
/>
}
isOpen={isPopoverOpen}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,18 +7,21 @@

import { useSelector } from 'react-redux';
import { useKibana } from '@kbn/kibana-react-plugin/public';
import { selectServiceLocationsState } from '../../../state';
import { selectOverviewStatus } from '../../../state/overview_status';
import { useEnablement } from '../../../hooks';
import { selectOverviewState } from '../../../state';

export const useCanUsePublicLocById = (configId: string) => {
const {
data: { monitors },
} = useSelector(selectOverviewState);
const { allConfigs } = useSelector(selectOverviewStatus);

const { isServiceAllowed } = useEnablement();

const hasManagedLocation = monitors?.filter(
(mon) => mon.configId === configId && mon.location.isServiceManaged
const { locations: allLocations } = useSelector(selectServiceLocationsState);

const listIds = allLocations?.filter((loc) => loc.isServiceManaged).map((loc) => loc.id) ?? [];

const hasManagedLocation = allConfigs?.filter(
(mon) => mon.configId === configId && listIds.includes(mon.locationId)
);

const canUsePublicLocations =
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ import {
export function useOverviewStatus({ scopeStatusByLocation }: { scopeStatusByLocation: boolean }) {
const pageState = useSelector(selectOverviewPageState);

const { status, error, loaded, loading } = useSelector(selectOverviewStatus);
const { status, error, loaded, loading, allConfigs } = useSelector(selectOverviewStatus);

const { lastRefresh } = useSyntheticsRefreshContext();

Expand All @@ -38,5 +38,7 @@ export function useOverviewStatus({ scopeStatusByLocation }: { scopeStatusByLoca
status,
error,
loading,
loaded,
allConfigs: allConfigs ?? [],
};
}
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,10 @@ import * as monitorDetailLocatorModule from '../../../../hooks/use_monitor_detai
import * as monitorEnableHandlerModule from '../../../../hooks/use_monitor_enable_handler';
import * as enablementHook from '../../../../hooks/use_enablement';
import { FETCH_STATUS } from '@kbn/observability-shared-plugin/public';
import { MonitorOverviewItem } from '../types';
import { OverviewStatusMetaData } from '../types';

describe('ActionsPopover', () => {
let testMonitor: MonitorOverviewItem;
let testMonitor: OverviewStatusMetaData;

beforeEach(() => {
jest.spyOn(enablementHook, 'useEnablement').mockReturnValue({
Expand All @@ -32,19 +32,17 @@ describe('ActionsPopover', () => {
});

testMonitor = {
location: {
id: 'us_central',
isServiceManaged: true,
},
locationId: 'us_central',
isEnabled: true,
isStatusAlertEnabled: true,
name: 'Monitor 1',
id: 'somelongstring',
configId: '1lkjelre',
type: 'browser',
tags: [],
schedule: '120',
};
monitorQueryId: '123',
status: 'up',
} as any;
});

afterEach(() => {
Expand All @@ -58,7 +56,7 @@ describe('ActionsPopover', () => {
isPopoverOpen={false}
setIsPopoverOpen={jest.fn()}
monitor={testMonitor}
locationId={testMonitor.location.id}
locationId={testMonitor.locationId}
/>
);
expect(getByLabelText('Open actions menu'));
Expand All @@ -74,7 +72,7 @@ describe('ActionsPopover', () => {
isPopoverOpen={isPopoverOpen}
setIsPopoverOpen={setIsPopoverOpen}
monitor={testMonitor}
locationId={testMonitor.location.id}
locationId={testMonitor.locationId}
/>
);
const popoverButton = getByLabelText('Open actions menu');
Expand All @@ -94,7 +92,7 @@ describe('ActionsPopover', () => {
isPopoverOpen={isPopoverOpen}
setIsPopoverOpen={setIsPopoverOpen}
monitor={testMonitor}
locationId={testMonitor.location.id}
locationId={testMonitor.locationId}
/>
);
const popoverButton = getByLabelText('Open actions menu');
Expand All @@ -115,7 +113,7 @@ describe('ActionsPopover', () => {
isPopoverOpen={true}
setIsPopoverOpen={jest.fn()}
monitor={testMonitor}
locationId={testMonitor.location.id}
locationId={testMonitor.locationId}
/>
);

Expand All @@ -132,7 +130,7 @@ describe('ActionsPopover', () => {
isPopoverOpen={true}
setIsPopoverOpen={jest.fn()}
monitor={testMonitor}
locationId={testMonitor.location.id}
locationId={testMonitor.locationId}
/>
);

Expand All @@ -151,7 +149,7 @@ describe('ActionsPopover', () => {
isPopoverOpen={true}
setIsPopoverOpen={jest.fn()}
monitor={testMonitor}
locationId={testMonitor.location.id}
locationId={testMonitor.locationId}
/>
);
expect(getByTestId('actionsPopoverGoToMonitor')?.getAttribute('href')).toBe(
Expand All @@ -172,7 +170,7 @@ describe('ActionsPopover', () => {
position="relative"
setIsPopoverOpen={jest.fn()}
monitor={testMonitor}
locationId={testMonitor.location.id}
locationId={testMonitor.locationId}
/>
);
const enableButton = getByText('Disable monitor (all locations)');
Expand All @@ -194,7 +192,7 @@ describe('ActionsPopover', () => {
setIsPopoverOpen={jest.fn()}
monitor={{ ...testMonitor, isEnabled: false }}
position="relative"
locationId={testMonitor.location.id}
locationId={testMonitor.locationId}
/>
);
const enableButton = getByText('Enable monitor (all locations)');
Expand Down
Loading

0 comments on commit 5fcc495

Please sign in to comment.