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: [