Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Search] Remove long-running query pop-up #75385

Merged
merged 115 commits into from
Sep 13, 2020
Merged
Changes from 1 commit
Commits
Show all changes
115 commits
Select commit Hold shift + click to select a range
9ce2275
[Search] Remove long-running query pop-up
lukasolson Aug 19, 2020
b647c34
Merge branch 'master' into search-remove-popup
lukasolson Aug 20, 2020
c1217b0
Don't timeout if requestTimeout isn't configured
lukasolson Aug 20, 2020
3299406
Merge branch 'master' into search-remove-popup
lukasolson Aug 20, 2020
b9aa07d
Remove unused kibanaUtils
lukasolson Aug 20, 2020
c2c0237
Remove unused kibanaReact
lukasolson Aug 21, 2020
7927af6
Re-add reference to kibanaUtils
lukasolson Aug 21, 2020
0f69bac
Remove unused translations and update documentation
lukasolson Aug 21, 2020
c29ab1b
Add new x-pack advanced setting searchTimeout and use it in the Enhan…
Aug 23, 2020
4f603ce
docs
Aug 23, 2020
13ea90e
Merge branch 'master' into search-remove-popup
lukasolson Aug 24, 2020
2df19ac
Merge branch 'master' of github.com:elastic/kibana into search/search…
Aug 25, 2020
25aae3a
Re-add toast when queries time out
lukasolson Aug 25, 2020
849ef85
Fix types
lukasolson Aug 25, 2020
de8107d
Update error message with capabilities
lukasolson Aug 25, 2020
d54b09a
Update docs
lukasolson Aug 25, 2020
20ea649
Update docs
lukasolson Aug 25, 2020
356281a
Move search server routes into a directory.
lukeelmers Aug 20, 2020
84ad62f
Add internal/_msearch route.
lukeelmers Aug 26, 2020
9a8de03
Remove legacy search API, rewrite default search strategy to use inte…
lukeelmers Aug 26, 2020
371a4df
Remove legacy es_client code.
lukeelmers Aug 26, 2020
2475467
Handle msearch options on server.
lukeelmers Aug 26, 2020
775586a
Remove elasticsearch-browser dependency.
lukeelmers Aug 26, 2020
d7df81e
Update generated docs.
lukeelmers Aug 26, 2020
e02a9dc
Merge branch 'master' of github.com:elastic/kibana into search/search…
Aug 26, 2020
2cb19ec
Merge remote-tracking branch 'lukeelmers/fix/remove-es-client' into s…
Aug 26, 2020
c07d923
Rely on server timeout in OSS (?)
Aug 26, 2020
1086b9c
Merge branch 'master' into search/search-timeout-setting
elasticmachine Aug 26, 2020
184a3e6
Merge branch 'master' of github.com:elastic/kibana into search/search…
Aug 26, 2020
8c75c64
Rename function
Aug 26, 2020
5b1af34
Merge branch 'master' of github.com:elastic/kibana into search/search…
Aug 26, 2020
17fd210
Merge branch 'search/search-timeout-setting' of github.com:lizozom/ki…
Aug 26, 2020
39605fe
Merge branch 'master' of github.com:elastic/kibana into search/search…
Aug 26, 2020
742f3ba
Add features to dependencies
lukasolson Aug 26, 2020
4056f40
Undefined check
lukasolson Aug 26, 2020
791a92f
Merge branch 'master' into fix/remove-es-client
elasticmachine Aug 26, 2020
82915ab
Merge branch 'master' into search/search-timeout-setting
elasticmachine Aug 27, 2020
059706e
doc
Aug 27, 2020
260d23c
Code review fixes
Aug 27, 2020
9540e4c
code review
Aug 27, 2020
6de4205
doc
Aug 27, 2020
5049b35
loading count
Aug 27, 2020
002c13c
simplify code review and fix jest tets
Aug 27, 2020
3c07a71
Merge branch 'master' of github.com:elastic/kibana into pr/75943
Aug 27, 2020
1dded0a
type check
Aug 27, 2020
75c1eb6
Merge branch 'master' of github.com:elastic/kibana into search/search…
Aug 27, 2020
a6a128f
Merge remote-tracking branch 'lukeelmers/fix/remove-es-client' into s…
Aug 27, 2020
05e9bdf
Remove esShard from client
Aug 27, 2020
8dd8f95
Merge branch 'master' into fix/remove-es-client
elasticmachine Aug 31, 2020
1dab018
Merge remote-tracking branch 'lukeelmers/fix/remove-es-client' into s…
Aug 31, 2020
dc19863
cleanup request parameters from FE
Aug 31, 2020
0499b21
doc
Aug 31, 2020
05c51b8
doc
Aug 31, 2020
39fc3fe
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 1, 2020
735ac5c
Align request parameters on server,
Sep 1, 2020
0edd897
docs
Sep 1, 2020
34a008f
add management docs
Sep 1, 2020
f9fab22
docs
Sep 1, 2020
eaa9c77
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 1, 2020
a601601
Remove import
Sep 1, 2020
cb1951e
Break circular dep + fix msearch test
Sep 1, 2020
78ea8a1
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 1, 2020
4921152
Remove deleted type
Sep 1, 2020
0b954df
Fix jest
Sep 1, 2020
5e2417d
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 2, 2020
3f8b19a
Bring toSnakeCase back
Sep 2, 2020
b000274
docs
Sep 2, 2020
504814d
fix jest
Sep 2, 2020
e520695
Merge branch 'search-timeout-setting' into search-remove-popup
lukasolson Sep 3, 2020
5e0959a
Add new x-pack advanced setting searchTimeout and use it in the Enhan…
Aug 23, 2020
a682fb7
docs
Aug 23, 2020
f2c4c16
Rely on server timeout in OSS (?)
Aug 26, 2020
2497e00
Rename function
Aug 26, 2020
a65596f
doc
Aug 27, 2020
1e9e9a0
Remove esShard from client
Aug 27, 2020
6d718c5
cleanup request parameters from FE
Aug 31, 2020
060ce08
doc
Aug 31, 2020
0310fb1
doc
Aug 31, 2020
1b4770a
Align request parameters on server,
Sep 1, 2020
70b5809
docs
Sep 1, 2020
f8aba5d
add management docs
Sep 1, 2020
f4d0064
docs
Sep 1, 2020
9c5c0ec
Remove import
Sep 1, 2020
befdf10
Break circular dep + fix msearch test
Sep 1, 2020
098a9ad
Remove deleted type
Sep 1, 2020
dac9d7a
Fix jest
Sep 1, 2020
f9273d6
Bring toSnakeCase back
Sep 2, 2020
3dc393e
docs
Sep 2, 2020
59f5cc1
fix jest
Sep 2, 2020
2841d57
Fix merge
Sep 3, 2020
313bbd7
Fix types
lukasolson Sep 5, 2020
ae3f8b6
Merge branch 'search/search-timeout-setting' into search-remove-popup
lukasolson Sep 5, 2020
2dea1e3
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 6, 2020
68c2604
Merge branch 'search/search-timeout-setting' into pr/75385
Sep 6, 2020
6111ac7
Allow timeout to be undefined
Sep 6, 2020
b1b466c
Fix jest test
Sep 6, 2020
5a7c9e0
Upldate docs
Sep 6, 2020
882c4fd
Fix msearch jest
Sep 6, 2020
6e91b8f
Merge branch 'search/search-timeout-setting' into pr/75385
Sep 6, 2020
95f0e9b
Merge correction
Sep 6, 2020
b9306c0
Merge branch 'master' into search/search-timeout-setting
elasticmachine Sep 7, 2020
bec86a5
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 7, 2020
887b3ea
docs
Sep 7, 2020
b9c7dfc
Merge branch 'search/search-timeout-setting' of github.com:lizozom/ki…
Sep 8, 2020
4bdbcc6
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 8, 2020
f6d4b5b
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 8, 2020
4405680
Fix rollup search merge
Sep 8, 2020
61d1f76
Merge branch 'master' of github.com:elastic/kibana into search/search…
Sep 8, 2020
790f2b0
Merge branch 'search/search-timeout-setting' into pr/75385
Sep 8, 2020
069390b
Merge branch 'master' of github.com:elastic/kibana into pr/75385
Sep 9, 2020
25d5e37
Fix merge
Sep 9, 2020
bc6eaae
Merge branch 'master' into search-remove-popup
elasticmachine Sep 9, 2020
c6508b0
Use i18n
lukasolson Sep 10, 2020
4ed7d31
Merge remote-tracking branch 'origin/search-remove-popup' into search…
lukasolson Sep 10, 2020
66dac98
Merge branch 'master' into search-remove-popup
lukasolson Sep 13, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Remove legacy search API, rewrite default search strategy to use inte…
…rnal route.
  • Loading branch information
lukeelmers committed Aug 26, 2020
commit 9a8de032ed328f8e583fe2babc9269d395fc8bb6
11 changes: 1 addition & 10 deletions src/plugins/data/public/plugin.ts
Original file line number Diff line number Diff line change
@@ -19,13 +19,7 @@

import './index.scss';

import {
PluginInitializerContext,
CoreSetup,
CoreStart,
Plugin,
PackageInfo,
} from 'src/core/public';
import { PluginInitializerContext, CoreSetup, CoreStart, Plugin } from 'src/core/public';
import { ConfigSchema } from '../config';
import { Storage, IStorageWrapper, createStartServicesGetter } from '../../kibana_utils/public';
import {
@@ -100,15 +94,13 @@ export class DataPublicPlugin
private readonly fieldFormatsService: FieldFormatsService;
private readonly queryService: QueryService;
private readonly storage: IStorageWrapper;
private readonly packageInfo: PackageInfo;

constructor(initializerContext: PluginInitializerContext<ConfigSchema>) {
this.searchService = new SearchService();
this.queryService = new QueryService();
this.fieldFormatsService = new FieldFormatsService();
this.autocomplete = new AutocompleteService(initializerContext);
this.storage = new Storage(window.localStorage);
this.packageInfo = initializerContext.env.packageInfo;
}

public setup(
@@ -145,7 +137,6 @@ export class DataPublicPlugin

const searchService = this.searchService.setup(core, {
usageCollection,
packageInfo: this.packageInfo,
expressions,
});

4 changes: 2 additions & 2 deletions src/plugins/data/public/search/fetch/types.ts
Original file line number Diff line number Diff line change
@@ -17,8 +17,8 @@
* under the License.
*/

import { HttpStart } from 'src/core/public';
import { GetConfigFn } from '../../../common';
import { ISearchStartLegacy } from '../types';

/**
* @internal
@@ -35,9 +35,9 @@ export interface FetchOptions {
}

export interface FetchHandlers {
legacySearchService: ISearchStartLegacy;
config: { get: GetConfigFn };
esShardTimeout: number;
http: HttpStart;
}

export interface SearchError {
8 changes: 7 additions & 1 deletion src/plugins/data/public/search/legacy/call_client.test.ts
Original file line number Diff line number Diff line change
@@ -17,6 +17,7 @@
* under the License.
*/

import { coreMock } from '../../../../../core/public/mocks';
import { callClient } from './call_client';
import { SearchStrategySearchParams } from './types';
import { defaultSearchStrategy } from './default_search_strategy';
@@ -54,7 +55,12 @@ describe('callClient', () => {

test('Passes the additional arguments it is given to the search strategy', () => {
const searchRequests = [{ _searchStrategyId: 0 }];
const args = { legacySearchService: {}, config: {}, esShardTimeout: 0 } as FetchHandlers;
const args = {
http: coreMock.createStart().http,
legacySearchService: {},
config: { get: jest.fn() },
esShardTimeout: 0,
} as FetchHandlers;

callClient(searchRequests, [], args);

Original file line number Diff line number Diff line change
@@ -17,9 +17,9 @@
* under the License.
*/

import { IUiSettingsClient } from 'kibana/public';
import { HttpStart, IUiSettingsClient } from 'src/core/public';
import { coreMock } from '../../../../../core/public/mocks';
import { defaultSearchStrategy } from './default_search_strategy';
import { searchServiceMock } from '../mocks';
import { SearchStrategySearchParams } from './types';
import { UI_SETTINGS } from '../../../common';

@@ -31,30 +31,19 @@ function getConfigStub(config: any = {}) {
} as IUiSettingsClient;
}

const msearchMockResponse: any = Promise.resolve([]);
msearchMockResponse.abort = jest.fn();
const msearchMock = jest.fn().mockReturnValue(msearchMockResponse);

const searchMockResponse: any = Promise.resolve([]);
searchMockResponse.abort = jest.fn();
const searchMock = jest.fn().mockReturnValue(searchMockResponse);
const msearchMock = jest.fn().mockResolvedValue({ body: { responses: [] } });

describe('defaultSearchStrategy', function () {
describe('search', function () {
let searchArgs: MockedKeys<Omit<SearchStrategySearchParams, 'config'>>;
let es: any;
let http: jest.Mocked<HttpStart>;

beforeEach(() => {
msearchMockResponse.abort.mockClear();
msearchMock.mockClear();

searchMockResponse.abort.mockClear();
searchMock.mockClear();

const searchService = searchServiceMock.createStartContract();
searchService.aggs.calculateAutoTimeExpression = jest.fn().mockReturnValue('1d');
searchService.__LEGACY.esClient.search = searchMock;
searchService.__LEGACY.esClient.msearch = msearchMock;
http = coreMock.createStart().http;
http.post.mockResolvedValue(msearchMock);

searchArgs = {
searchRequests: [
@@ -63,16 +52,16 @@ describe('defaultSearchStrategy', function () {
},
],
esShardTimeout: 0,
legacySearchService: searchService.__LEGACY,
http,
};

es = searchArgs.legacySearchService.esClient;
es = http.post;
});

test('does not send max_concurrent_shard_requests by default', async () => {
const config = getConfigStub({ [UI_SETTINGS.COURIER_BATCH_SEARCHES]: true });
await search({ ...searchArgs, config });
expect(es.msearch.mock.calls[0][0].max_concurrent_shard_requests).toBe(undefined);
expect(es.mock.calls[0][1].query.max_concurrent_shard_requests).toBe(undefined);
});

test('allows configuration of max_concurrent_shard_requests', async () => {
@@ -81,13 +70,13 @@ describe('defaultSearchStrategy', function () {
[UI_SETTINGS.COURIER_MAX_CONCURRENT_SHARD_REQUESTS]: 42,
});
await search({ ...searchArgs, config });
expect(es.msearch.mock.calls[0][0].max_concurrent_shard_requests).toBe(42);
expect(es.mock.calls[0][1].query.max_concurrent_shard_requests).toBe(42);
});

test('should set rest_total_hits_as_int to true on a request', async () => {
const config = getConfigStub({ [UI_SETTINGS.COURIER_BATCH_SEARCHES]: true });
await search({ ...searchArgs, config });
expect(es.msearch.mock.calls[0][0]).toHaveProperty('rest_total_hits_as_int', true);
expect(es.mock.calls[0][1].query).toHaveProperty('rest_total_hits_as_int', true);
});

test('should set ignore_throttled=false when including frozen indices', async () => {
@@ -96,15 +85,7 @@ describe('defaultSearchStrategy', function () {
[UI_SETTINGS.SEARCH_INCLUDE_FROZEN]: true,
});
await search({ ...searchArgs, config });
expect(es.msearch.mock.calls[0][0]).toHaveProperty('ignore_throttled', false);
});

test('should properly call abort with msearch', () => {
const config = getConfigStub({
[UI_SETTINGS.COURIER_BATCH_SEARCHES]: true,
});
search({ ...searchArgs, config }).abort();
expect(msearchMockResponse.abort).toHaveBeenCalled();
expect(es.mock.calls[0][1].query).toHaveProperty('ignore_throttled', false);
});
});
});
67 changes: 44 additions & 23 deletions src/plugins/data/public/search/legacy/default_search_strategy.ts
Original file line number Diff line number Diff line change
@@ -17,6 +17,8 @@
* under the License.
*/

import { BehaviorSubject } from 'rxjs';

import { getPreference, getTimeout } from '../fetch';
import { getMSearchParams } from './get_msearch_params';
import { SearchStrategyProvider, SearchStrategySearchParams } from './types';
@@ -30,34 +32,53 @@ export const defaultSearchStrategy: SearchStrategyProvider = {
},
};

function msearch({
searchRequests,
legacySearchService,
config,
esShardTimeout,
}: SearchStrategySearchParams) {
const es = legacySearchService.esClient;
const inlineRequests = searchRequests.map(({ index, body, search_type: searchType }) => {
const inlineHeader = {
index: index.title || index,
search_type: searchType,
ignore_unavailable: true,
preference: getPreference(config.get),
};
const inlineBody = {
...body,
timeout: getTimeout(esShardTimeout),
function msearch({ searchRequests, config, http, esShardTimeout }: SearchStrategySearchParams) {
const requests = searchRequests.map(({ index, body, search_type: searchType }) => {
return {
header: {
index: index.title || index,
ignore_unavailable: true,
preference: getPreference(config.get),
search_type: searchType,
},
body: {
...body,
timeout: getTimeout(esShardTimeout),
},
};
return `${JSON.stringify(inlineHeader)}\n${JSON.stringify(inlineBody)}`;
});

const searching = es.msearch({
...getMSearchParams(config.get),
body: `${inlineRequests.join('\n')}\n`,
const abortController = new AbortController();
let resolved = false;

const loadingCount$ = new BehaviorSubject(0);
http.addLoadingCountSource(loadingCount$);

// Start LoadingIndicator
loadingCount$.next(loadingCount$.getValue() + 1);

const cleanup = () => {
if (!resolved) {
resolved = true;
// Decrement loading counter & cleanup BehaviorSubject
loadingCount$.next(loadingCount$.getValue() - 1);
loadingCount$.complete();
}
};

const searching = http.post('/internal/_msearch', {
query: getMSearchParams(config.get),
body: JSON.stringify({ searches: requests }),
signal: abortController.signal,
});

searching.finally(() => cleanup());

return {
searching: searching.then(({ responses }: any) => responses),
abort: searching.abort,
abort: () => {
abortController.abort();
cleanup();
},
searching: searching.then(({ body }) => body?.responses),
};
}
6 changes: 0 additions & 6 deletions src/plugins/data/public/search/mocks.ts
Original file line number Diff line number Diff line change
@@ -35,12 +35,6 @@ function createStartContract(): jest.Mocked<ISearchStart> {
aggs: searchAggsStartMock(),
search: jest.fn(),
searchSource: searchSourceMock,
__LEGACY: {
esClient: {
search: jest.fn(),
msearch: jest.fn(),
},
},
};
}

26 changes: 5 additions & 21 deletions src/plugins/data/public/search/search_service.ts
Original file line number Diff line number Diff line change
@@ -17,11 +17,10 @@
* under the License.
*/

import { Plugin, CoreSetup, CoreStart, PackageInfo } from 'src/core/public';
import { Plugin, CoreSetup, CoreStart } from 'src/core/public';
import { ISearchSetup, ISearchStart, SearchEnhancements } from './types';

import { createSearchSource, SearchSource, SearchSourceDependencies } from './search_source';
import { getEsClient, LegacyApiCaller } from './legacy';
import { AggsService, AggsStartDependencies } from './aggs';
import { IndexPatternsContract } from '../index_patterns/index_patterns';
import { ISearchInterceptor, SearchInterceptor } from './search_interceptor';
@@ -33,9 +32,8 @@ import { ExpressionsSetup } from '../../../expressions/public';

/** @internal */
export interface SearchServiceSetupDependencies {
packageInfo: PackageInfo;
usageCollection?: UsageCollectionSetup;
expressions: ExpressionsSetup;
usageCollection?: UsageCollectionSetup;
}

/** @internal */
@@ -45,28 +43,18 @@ export interface SearchServiceStartDependencies {
}

export class SearchService implements Plugin<ISearchSetup, ISearchStart> {
private esClient?: LegacyApiCaller;
private readonly aggsService = new AggsService();
private searchInterceptor!: ISearchInterceptor;
private usageCollector?: SearchUsageCollector;

public setup(
{ http, getStartServices, injectedMetadata, notifications, uiSettings }: CoreSetup,
{ expressions, packageInfo, usageCollection }: SearchServiceSetupDependencies
{ expressions, usageCollection }: SearchServiceSetupDependencies
): ISearchSetup {
const esApiVersion = injectedMetadata.getInjectedVar('esApiVersion') as string;
const esRequestTimeout = injectedMetadata.getInjectedVar('esRequestTimeout') as number;
const packageVersion = packageInfo.version;

this.usageCollector = createUsageCollector(getStartServices, usageCollection);

this.esClient = getEsClient({
esRequestTimeout,
esApiVersion,
http,
packageVersion,
});

/**
* A global object that intercepts all searches and provides convenience methods for cancelling
* all pending search requests, as well as getting the number of pending search requests.
@@ -107,15 +95,12 @@ export class SearchService implements Plugin<ISearchSetup, ISearchStart> {
return this.searchInterceptor.search(request, options);
}) as ISearchGeneric;

const legacySearch = {
esClient: this.esClient!,
};

const searchSourceDependencies: SearchSourceDependencies = {
getConfig: uiSettings.get.bind(uiSettings),
// TODO: we don't need this, apply on the server
esShardTimeout: injectedMetadata.getInjectedVar('esShardTimeout') as number,
search,
legacySearch,
http,
};

return {
@@ -127,7 +112,6 @@ export class SearchService implements Plugin<ISearchSetup, ISearchStart> {
return new SearchSource({}, searchSourceDependencies);
},
},
__LEGACY: legacySearch,
};
}

Original file line number Diff line number Diff line change
@@ -22,7 +22,7 @@ import { SearchSourceDependencies } from './search_source';
import { IIndexPattern } from '../../../common/index_patterns';
import { IndexPatternsContract } from '../../index_patterns/index_patterns';
import { Filter } from '../../../common/es_query/filters';
import { dataPluginMock } from '../../mocks';
import { coreMock } from '../../../../../core/public/mocks';

describe('createSearchSource', () => {
const indexPatternMock: IIndexPattern = {} as IIndexPattern;
@@ -31,13 +31,11 @@ describe('createSearchSource', () => {
let createSearchSource: ReturnType<typeof createSearchSourceFactory>;

beforeEach(() => {
const data = dataPluginMock.createStartContract();

dependencies = {
getConfig: jest.fn(),
search: jest.fn(),
legacySearch: data.search.__LEGACY,
esShardTimeout: 30000,
http: coreMock.createStart().http,
};

indexPatternContractMock = ({
Loading