Skip to content

Commit

Permalink
[EDR Workflows][Osquery] Missing timeout value when running query fro…
Browse files Browse the repository at this point in the history
…m query history (#174088)

#174082

Fixed bug with `timeout` field not being properly passed from Query
History list to query form.
Added test coverage.
 

https://github.com/elastic/kibana/assets/29123534/48862490-d308-47c6-bdc1-d2c10ec8533d
  • Loading branch information
szwarckonrad authored Jan 22, 2024
1 parent a161ec3 commit 0aadaa9
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 3 deletions.
5 changes: 5 additions & 0 deletions x-pack/plugins/osquery/cypress/e2e/all/live_query_run.cy.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,13 @@ import { navigateTo } from '../../tasks/navigation';
import {
checkActionItemsInResults,
checkResults,
fillInQueryTimeout,
inputQuery,
selectAllAgents,
submitQuery,
typeInECSFieldInput,
typeInOsqueryFieldInput,
verifyQueryTimeout,
} from '../../tasks/live_query';
import { LIVE_QUERY_EDITOR, RESULTS_TABLE, RESULTS_TABLE_BUTTON } from '../../screens/live_query';
import { getAdvancedButton } from '../../screens/integrations';
Expand Down Expand Up @@ -93,13 +95,16 @@ describe('ALL - Live Query run custom and saved', { tags: ['@ess', '@serverless'
selectAllAgents();
cy.getBySel(SAVED_QUERY_DROPDOWN_SELECT).type(`${savedQueryName}{downArrow}{enter}`);
inputQuery('{selectall}{backspace}select * from users;');
getAdvancedButton().click();
fillInQueryTimeout('601');
cy.wait(1000);
submitQuery();
checkResults();
navigateTo('/app/osquery');
cy.get('[aria-label="Run query"]').first().should('be.visible').click();

cy.getBySel(LIVE_QUERY_EDITOR).contains('select * from users;');
verifyQueryTimeout('601');
});

it('should open query details by clicking the details icon', () => {
Expand Down
8 changes: 8 additions & 0 deletions x-pack/plugins/osquery/cypress/tasks/live_query.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
* 2.0.
*/

import { getAdvancedButton } from '../screens/integrations';
import { LIVE_QUERY_EDITOR, OSQUERY_FLYOUT_BODY_EDITOR } from '../screens/live_query';
import { ServerlessRoleName } from '../support/roles';
import { waitForAlertsToPopulate } from '../../../../test/security_solution_cypress/cypress/tasks/create_new_rule';
Expand Down Expand Up @@ -46,6 +47,13 @@ export const fillInQueryTimeout = (timeout: string) => {
});
};

export const verifyQueryTimeout = (timeout: string) => {
getAdvancedButton().click();
cy.getBySel('advanced-accordion-content').within(() => {
cy.getBySel('timeout-input').should('have.value', timeout);
});
};

// sometimes the results get stuck in the tests, this is a workaround
export const checkResults = () => {
cy.getBySel('osqueryResultsTable').then(($table) => {
Expand Down
8 changes: 8 additions & 0 deletions x-pack/plugins/osquery/cypress/tasks/saved_queries.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
* 2.0.
*/

import { getAdvancedButton } from '../screens/integrations';
import { RESULTS_TABLE_BUTTON, RESULTS_TABLE_COLUMNS_BUTTON } from '../screens/live_query';
import { closeToastIfVisible, generateRandomStringName } from './integrations';
import {
Expand All @@ -14,11 +15,14 @@ import {
inputQuery,
selectAllAgents,
submitQuery,
fillInQueryTimeout,
verifyQueryTimeout,
} from './live_query';
import { navigateTo } from './navigation';

export const getSavedQueriesComplexTest = () =>
describe('Saved queries Complex Test', () => {
const timeout = '601';
const suffix = generateRandomStringName(1)[0];
const savedQueryId = `Saved-Query-Id-${suffix}`;
const savedQueryDescription = `Test saved query description ${suffix}`;
Expand All @@ -32,6 +36,8 @@ export const getSavedQueriesComplexTest = () =>
cy.contains('New live query').click();
selectAllAgents();
inputQuery(BIG_QUERY);
getAdvancedButton().click();
fillInQueryTimeout(timeout);
submitQuery();
checkResults();
// enter fullscreen
Expand Down Expand Up @@ -92,6 +98,7 @@ export const getSavedQueriesComplexTest = () =>
cy.contains(savedQueryId);
cy.get(`[aria-label="Run ${savedQueryId}"]`).click();
selectAllAgents();
verifyQueryTimeout(timeout);
submitQuery();

// edit saved query
Expand All @@ -104,6 +111,7 @@ export const getSavedQueriesComplexTest = () =>
// Run in test configuration
cy.contains('Test configuration').click();
selectAllAgents();
verifyQueryTimeout(timeout);
submitQuery();
checkResults();

Expand Down
6 changes: 4 additions & 2 deletions x-pack/plugins/osquery/public/actions/actions_table.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
* 2.0.
*/

import { isArray, isEmpty, pickBy, map } from 'lodash';
import { isArray, isEmpty, pickBy, map, isNumber } from 'lodash';
import { i18n } from '@kbn/i18n';
import {
EuiBasicTable,
Expand All @@ -20,6 +20,7 @@ import {
import React, { useState, useCallback, useMemo } from 'react';
import { useHistory } from 'react-router-dom';

import { QUERY_TIMEOUT } from '../../common/constants';
import { removeMultilines } from '../../common/utils/build_query/remove_multilines';
import { useAllLiveQueries } from './use_all_live_queries';
import type { SearchHit } from '../../common/search_strategy';
Expand Down Expand Up @@ -136,14 +137,15 @@ const ActionsTableComponent = () => {
query: item._source.queries[0].query,
ecs_mapping: item._source.queries[0].ecs_mapping,
savedQueryId: item._source.queries[0].saved_query_id,
timeout: item._source.queries[0].timeout ?? QUERY_TIMEOUT.DEFAULT,
agentSelection: {
agents: item._source.agent_ids,
allAgentsSelected: item._source.agent_all,
platformsSelected: item._source.agent_platforms,
policiesSelected: item._source.agent_policy_ids,
},
},
(value) => !isEmpty(value)
(value) => !isEmpty(value) || isNumber(value)
),
});
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import React, { useMemo } from 'react';
import { FormattedMessage } from '@kbn/i18n-react';

import { useFormContext } from 'react-hook-form';
import { QUERY_TIMEOUT } from '../../../common/constants';
import { LiveQuery } from '../../live_queries';

const euiFlyoutHeaderCss = {
Expand All @@ -28,7 +29,7 @@ const PlaygroundFlyoutComponent: React.FC<PlaygroundFlyoutProps> = ({ enabled, o
// @ts-expect-error update types
const { serializer, watch } = useFormContext();
const watchedValues = watch();
const { query, ecs_mapping: ecsMapping, id } = watchedValues;
const { query, ecs_mapping: ecsMapping, id, timeout } = watchedValues;
/* recalculate the form data when ecs_mapping changes */
// eslint-disable-next-line react-hooks/exhaustive-deps
const serializedFormData = useMemo(() => serializer(watchedValues), [ecsMapping]);
Expand All @@ -52,6 +53,7 @@ const PlaygroundFlyoutComponent: React.FC<PlaygroundFlyoutProps> = ({ enabled, o
query={query}
ecs_mapping={serializedFormData.ecs_mapping}
savedQueryId={id}
timeout={timeout || QUERY_TIMEOUT.DEFAULT}
queryField={false}
ecsMappingField={false}
/>
Expand Down

0 comments on commit 0aadaa9

Please sign in to comment.