From 086c6e64f8704fc13a1d2a64530961d2b1f3e1c7 Mon Sep 17 00:00:00 2001 From: Julia Bardi Date: Tue, 23 Jan 2024 16:29:51 +0100 Subject: [PATCH 1/3] allow clearing version combo --- .../components/agent_upgrade_modal/index.tsx | 39 ++++++++++++++----- 1 file changed, 30 insertions(+), 9 deletions(-) diff --git a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.tsx b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.tsx index 57a23cbe412f8..035c4643fff7b 100644 --- a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.tsx +++ b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.tsx @@ -101,6 +101,8 @@ export const AgentUpgradeAgentModal: React.FunctionComponent(''); const QUERY_STUCK_UPDATING = `status:updating AND upgrade_started_at:* AND NOT upgraded_at:* AND upgrade_started_at < now-${AGENT_UPDATING_TIMEOUT_HOURS}h`; + const EMPTY_VALUE = useMemo(() => ({ label: '', value: '' }), []); + const [isInvalid, setIsInvalid] = useState(false); useEffect(() => { const getStuckUpdatingAgentCount = async (agentsOrQuery: Agent[] | string) => { @@ -179,10 +181,10 @@ export const AgentUpgradeAgentModal: React.FunctionComponent> = MAINTENANCE_VALUES.map( @@ -292,6 +294,7 @@ export const AgentUpgradeAgentModal: React.FunctionComponent ) : isSingleAgent ? ( + selectedVersion[0].value && !isAgentUpgradeableToVersion(agents[0], selectedVersion[0].value) ? (

@@ -433,8 +439,10 @@ export const AgentUpgradeAgentModal: React.FunctionComponent )}

@@ -443,6 +451,15 @@ export const AgentUpgradeAgentModal: React.FunctionComponent + ) : undefined + } > {noVersions ? ( >) => { if (!selected.length) { - return; + setSelectedVersion([EMPTY_VALUE]); + setIsInvalid(true); + } else { + setSelectedVersion(selected); + setIsInvalid(false); } - setSelectedVersion(selected); }} onCreateOption={ config?.internal?.onlyAllowAgentUpgradeToKnownVersions ? undefined : onCreateOption } customOptionText="Use custom agent version {searchValue} (not recommended)" + isInvalid={isInvalid} /> )} From 46d701d71f4de20f6ad2c6db6e5d1dfe10b9d253 Mon Sep 17 00:00:00 2001 From: Julia Bardi Date: Tue, 23 Jan 2024 17:01:17 +0100 Subject: [PATCH 2/3] added test, fix bulk action disabled button --- .../agent_upgrade_modal/index.test.tsx | 16 ++++++++++++++++ .../components/agent_upgrade_modal/index.tsx | 1 + 2 files changed, 17 insertions(+) diff --git a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.test.tsx b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.test.tsx index 3073420f4dc58..59529ad90b54a 100644 --- a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.test.tsx +++ b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.test.tsx @@ -109,6 +109,22 @@ describe('AgentUpgradeAgentModal', () => { }); }); + it('should make combo invalid on clearing version', async () => { + const { utils } = renderAgentUpgradeAgentModal({ + agents: [{ id: 'agent1', local_metadata: { host: 'abc' } }] as any, + agentCount: 1, + }); + + await waitFor(() => { + fireEvent.click(utils.getByTestId('comboBoxClearButton')); + const container = utils.getByTestId('agentUpgradeModal.VersionCombobox'); + const input = within(container).getByRole('combobox'); + expect(input?.value).toEqual(''); + expect(utils.getByText('Version is required')).toBeInTheDocument(); + expect(utils.getByTestId('confirmModalConfirmButton')).toBeDisabled(); + }); + }); + it('should display the custom version text input if no versions', async () => { const { utils } = renderAgentUpgradeAgentModal({ agents: [ diff --git a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.tsx b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.tsx index 035c4643fff7b..e333efb152ea3 100644 --- a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.tsx +++ b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.tsx @@ -346,6 +346,7 @@ export const AgentUpgradeAgentModal: React.FunctionComponent Date: Tue, 23 Jan 2024 17:04:25 +0100 Subject: [PATCH 3/3] added test --- .../agent_upgrade_modal/index.test.tsx | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.test.tsx b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.test.tsx index 59529ad90b54a..919a500477f0c 100644 --- a/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.test.tsx +++ b/x-pack/plugins/fleet/public/applications/fleet/sections/agents/components/agent_upgrade_modal/index.test.tsx @@ -125,6 +125,22 @@ describe('AgentUpgradeAgentModal', () => { }); }); + it('should make combo invalid on clearing version - bulk action', async () => { + const { utils } = renderAgentUpgradeAgentModal({ + agents: '*', + agentCount: 1, + }); + + await waitFor(() => { + fireEvent.click(utils.getByTestId('comboBoxClearButton')); + const container = utils.getByTestId('agentUpgradeModal.VersionCombobox'); + const input = within(container).getByRole('combobox'); + expect(input?.value).toEqual(''); + expect(utils.getByText('Version is required')).toBeInTheDocument(); + expect(utils.getByTestId('confirmModalConfirmButton')).toBeDisabled(); + }); + }); + it('should display the custom version text input if no versions', async () => { const { utils } = renderAgentUpgradeAgentModal({ agents: [