mirror of
https://github.com/elastic/kibana.git
synced 2025-04-23 17:28:26 -04:00
# Backport This will backport the following commits from `main` to `8.11`: - [[Discover] Fix Discover sidebar nav link global state syncing (#169905)](https://github.com/elastic/kibana/pull/169905) <!--- Backport version: 8.9.7 --> ### Questions ? Please refer to the [Backport tool documentation](https://github.com/sqren/backport) <!--BACKPORT [{"author":{"name":"Davis McPhee","email":"davis.mcphee@elastic.co"},"sourceCommit":{"committedDate":"2023-10-26T14:22:36Z","message":"[Discover] Fix Discover sidebar nav link global state syncing (#169905)\n\n## Summary\r\n\r\nThis PR fixes an issue where global state was not being synced to the\r\nDiscover sidebar nav link when modifying it from other applications,\r\nsuch as Lens.\r\n\r\nFixes #165899.\r\n\r\n### Checklist\r\n\r\n- [ ] Any text added follows [EUI's writing\r\nguidelines](https://elastic.github.io/eui/#/guidelines/writing), uses\r\nsentence case text and includes [i18n\r\nsupport](https://github.com/elastic/kibana/blob/main/packages/kbn-i18n/README.md)\r\n- [ ]\r\n[Documentation](https://www.elastic.co/guide/en/kibana/master/development-documentation.html)\r\nwas added for features that require explanation or tutorials\r\n- [x] [Unit or functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere updated or added to match the most common scenarios\r\n- [ ] Any UI touched in this PR is usable by keyboard only (learn more\r\nabout [keyboard accessibility](https://webaim.org/techniques/keyboard/))\r\n- [ ] Any UI touched in this PR does not create any new axe failures\r\n(run axe in browser:\r\n[FF](https://addons.mozilla.org/en-US/firefox/addon/axe-devtools/),\r\n[Chrome](https://chrome.google.com/webstore/detail/axe-web-accessibility-tes/lhdoppojpmngadmnindnejefpokejbdd?hl=en-US))\r\n- [ ] If a plugin configuration key changed, check if it needs to be\r\nallowlisted in the cloud and added to the [docker\r\nlist](https://github.com/elastic/kibana/blob/main/src/dev/build/tasks/os_packages/docker_generator/resources/base/bin/kibana-docker)\r\n- [ ] This renders correctly on smaller devices using a responsive\r\nlayout. (You can test this [in your\r\nbrowser](https://www.browserstack.com/guide/responsive-testing-on-local-server))\r\n- [x] This was checked for [cross-browser\r\ncompatibility](https://www.elastic.co/support/matrix#matrix_browsers)\r\n\r\n### For maintainers\r\n\r\n- [ ] This was checked for breaking API changes and was [labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"63db41ddae6885a6266fd9d89d0e41193c3d1b39","branchLabelMapping":{"^v8.12.0$":"main","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["release_note:fix","Team:DataDiscovery","backport:prev-minor","v8.12.0"],"number":169905,"url":"https://github.com/elastic/kibana/pull/169905","mergeCommit":{"message":"[Discover] Fix Discover sidebar nav link global state syncing (#169905)\n\n## Summary\r\n\r\nThis PR fixes an issue where global state was not being synced to the\r\nDiscover sidebar nav link when modifying it from other applications,\r\nsuch as Lens.\r\n\r\nFixes #165899.\r\n\r\n### Checklist\r\n\r\n- [ ] Any text added follows [EUI's writing\r\nguidelines](https://elastic.github.io/eui/#/guidelines/writing), uses\r\nsentence case text and includes [i18n\r\nsupport](https://github.com/elastic/kibana/blob/main/packages/kbn-i18n/README.md)\r\n- [ ]\r\n[Documentation](https://www.elastic.co/guide/en/kibana/master/development-documentation.html)\r\nwas added for features that require explanation or tutorials\r\n- [x] [Unit or functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere updated or added to match the most common scenarios\r\n- [ ] Any UI touched in this PR is usable by keyboard only (learn more\r\nabout [keyboard accessibility](https://webaim.org/techniques/keyboard/))\r\n- [ ] Any UI touched in this PR does not create any new axe failures\r\n(run axe in browser:\r\n[FF](https://addons.mozilla.org/en-US/firefox/addon/axe-devtools/),\r\n[Chrome](https://chrome.google.com/webstore/detail/axe-web-accessibility-tes/lhdoppojpmngadmnindnejefpokejbdd?hl=en-US))\r\n- [ ] If a plugin configuration key changed, check if it needs to be\r\nallowlisted in the cloud and added to the [docker\r\nlist](https://github.com/elastic/kibana/blob/main/src/dev/build/tasks/os_packages/docker_generator/resources/base/bin/kibana-docker)\r\n- [ ] This renders correctly on smaller devices using a responsive\r\nlayout. (You can test this [in your\r\nbrowser](https://www.browserstack.com/guide/responsive-testing-on-local-server))\r\n- [x] This was checked for [cross-browser\r\ncompatibility](https://www.elastic.co/support/matrix#matrix_browsers)\r\n\r\n### For maintainers\r\n\r\n- [ ] This was checked for breaking API changes and was [labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"63db41ddae6885a6266fd9d89d0e41193c3d1b39"}},"sourceBranch":"main","suggestedTargetBranches":[],"targetPullRequestStates":[{"branch":"main","label":"v8.12.0","labelRegex":"^v8.12.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/169905","number":169905,"mergeCommit":{"message":"[Discover] Fix Discover sidebar nav link global state syncing (#169905)\n\n## Summary\r\n\r\nThis PR fixes an issue where global state was not being synced to the\r\nDiscover sidebar nav link when modifying it from other applications,\r\nsuch as Lens.\r\n\r\nFixes #165899.\r\n\r\n### Checklist\r\n\r\n- [ ] Any text added follows [EUI's writing\r\nguidelines](https://elastic.github.io/eui/#/guidelines/writing), uses\r\nsentence case text and includes [i18n\r\nsupport](https://github.com/elastic/kibana/blob/main/packages/kbn-i18n/README.md)\r\n- [ ]\r\n[Documentation](https://www.elastic.co/guide/en/kibana/master/development-documentation.html)\r\nwas added for features that require explanation or tutorials\r\n- [x] [Unit or functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere updated or added to match the most common scenarios\r\n- [ ] Any UI touched in this PR is usable by keyboard only (learn more\r\nabout [keyboard accessibility](https://webaim.org/techniques/keyboard/))\r\n- [ ] Any UI touched in this PR does not create any new axe failures\r\n(run axe in browser:\r\n[FF](https://addons.mozilla.org/en-US/firefox/addon/axe-devtools/),\r\n[Chrome](https://chrome.google.com/webstore/detail/axe-web-accessibility-tes/lhdoppojpmngadmnindnejefpokejbdd?hl=en-US))\r\n- [ ] If a plugin configuration key changed, check if it needs to be\r\nallowlisted in the cloud and added to the [docker\r\nlist](https://github.com/elastic/kibana/blob/main/src/dev/build/tasks/os_packages/docker_generator/resources/base/bin/kibana-docker)\r\n- [ ] This renders correctly on smaller devices using a responsive\r\nlayout. (You can test this [in your\r\nbrowser](https://www.browserstack.com/guide/responsive-testing-on-local-server))\r\n- [x] This was checked for [cross-browser\r\ncompatibility](https://www.elastic.co/support/matrix#matrix_browsers)\r\n\r\n### For maintainers\r\n\r\n- [ ] This was checked for breaking API changes and was [labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"63db41ddae6885a6266fd9d89d0e41193c3d1b39"}}]}] BACKPORT--> Co-authored-by: Davis McPhee <davis.mcphee@elastic.co>
This commit is contained in:
parent
dba57f5116
commit
028a9fd940
4 changed files with 127 additions and 39 deletions
|
@ -10,6 +10,7 @@ import type { BehaviorSubject } from 'rxjs';
|
|||
import { filter, map } from 'rxjs/operators';
|
||||
import { createGetterSetter, createKbnUrlTracker } from '@kbn/kibana-utils-plugin/public';
|
||||
import { replaceUrlHashQuery } from '@kbn/kibana-utils-plugin/common';
|
||||
import { isFilterPinned } from '@kbn/es-query';
|
||||
import { getScopedHistory } from '../kibana_services';
|
||||
import { SEARCH_SESSION_ID_QUERY_PARAM } from '../constants';
|
||||
import type { DiscoverSetupPlugins } from '../plugin';
|
||||
|
@ -61,13 +62,10 @@ export function initializeKbnUrlTracking(
|
|||
filter(
|
||||
({ changes }) => !!(changes.globalFilters || changes.time || changes.refreshInterval)
|
||||
),
|
||||
map(async ({ state }) => {
|
||||
const { isFilterPinned } = await import('@kbn/es-query');
|
||||
return {
|
||||
...state,
|
||||
filters: state.filters?.filter(isFilterPinned),
|
||||
};
|
||||
})
|
||||
map(({ state }) => ({
|
||||
...state,
|
||||
filters: state.filters?.filter(isFilterPinned),
|
||||
}))
|
||||
),
|
||||
},
|
||||
],
|
||||
|
|
|
@ -334,37 +334,5 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
|
|||
expect(newMainPanelSize).to.be(mainPanelSize - resizeDistance);
|
||||
});
|
||||
});
|
||||
|
||||
describe('URL state', () => {
|
||||
it('should show a warning and fall back to the default data view when navigating to a URL with an invalid data view ID', async () => {
|
||||
await PageObjects.common.navigateToApp('discover');
|
||||
await PageObjects.timePicker.setDefaultAbsoluteRange();
|
||||
await PageObjects.header.waitUntilLoadingHasFinished();
|
||||
const dataViewId = await PageObjects.discover.getCurrentDataViewId();
|
||||
const originalUrl = await browser.getCurrentUrl();
|
||||
const newUrl = originalUrl.replace(dataViewId, 'invalid-data-view-id');
|
||||
await browser.get(newUrl);
|
||||
await PageObjects.header.waitUntilLoadingHasFinished();
|
||||
await retry.try(async () => {
|
||||
expect(await browser.getCurrentUrl()).to.be(originalUrl);
|
||||
expect(await testSubjects.exists('dscDataViewNotFoundShowDefaultWarning')).to.be(true);
|
||||
});
|
||||
});
|
||||
|
||||
it('should show a warning and fall back to the current data view if the URL is updated to an invalid data view ID', async () => {
|
||||
await PageObjects.common.navigateToApp('discover');
|
||||
await PageObjects.timePicker.setDefaultAbsoluteRange();
|
||||
const originalHash = await browser.execute<[], string>('return window.location.hash');
|
||||
const dataViewId = await PageObjects.discover.getCurrentDataViewId();
|
||||
const newHash = originalHash.replace(dataViewId, 'invalid-data-view-id');
|
||||
await browser.execute(`window.location.hash = "${newHash}"`);
|
||||
await PageObjects.header.waitUntilLoadingHasFinished();
|
||||
await retry.try(async () => {
|
||||
const currentHash = await browser.execute<[], string>('return window.location.hash');
|
||||
expect(currentHash).to.be(originalHash);
|
||||
expect(await testSubjects.exists('dscDataViewNotFoundShowSavedWarning')).to.be(true);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
}
|
||||
|
|
121
test/functional/apps/discover/group1/_url_state.ts
Normal file
121
test/functional/apps/discover/group1/_url_state.ts
Normal file
|
@ -0,0 +1,121 @@
|
|||
/*
|
||||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
||||
* or more contributor license agreements. Licensed under the Elastic License
|
||||
* 2.0 and the Server Side Public License, v 1; you may not use this file except
|
||||
* in compliance with, at your election, the Elastic License 2.0 or the Server
|
||||
* Side Public License, v 1.
|
||||
*/
|
||||
|
||||
import expect from '@kbn/expect';
|
||||
|
||||
import { FtrProviderContext } from '../ftr_provider_context';
|
||||
|
||||
export default function ({ getService, getPageObjects }: FtrProviderContext) {
|
||||
const browser = getService('browser');
|
||||
const log = getService('log');
|
||||
const retry = getService('retry');
|
||||
const esArchiver = getService('esArchiver');
|
||||
const kibanaServer = getService('kibanaServer');
|
||||
const filterBar = getService('filterBar');
|
||||
const testSubjects = getService('testSubjects');
|
||||
const appsMenu = getService('appsMenu');
|
||||
const PageObjects = getPageObjects([
|
||||
'common',
|
||||
'discover',
|
||||
'header',
|
||||
'timePicker',
|
||||
'unifiedFieldList',
|
||||
'visualize',
|
||||
]);
|
||||
|
||||
const defaultSettings = {
|
||||
defaultIndex: 'logstash-*',
|
||||
};
|
||||
|
||||
describe('discover URL state', () => {
|
||||
before(async function () {
|
||||
log.debug('load kibana index with default index pattern');
|
||||
await kibanaServer.importExport.load('test/functional/fixtures/kbn_archiver/discover');
|
||||
// and load a set of makelogs data
|
||||
await esArchiver.loadIfNeeded('test/functional/fixtures/es_archiver/logstash_functional');
|
||||
await kibanaServer.uiSettings.replace(defaultSettings);
|
||||
await PageObjects.common.navigateToApp('discover');
|
||||
await PageObjects.timePicker.setDefaultAbsoluteRange();
|
||||
});
|
||||
|
||||
after(async () => {
|
||||
await kibanaServer.savedObjects.clean({ types: ['search', 'index-pattern'] });
|
||||
});
|
||||
|
||||
it('should show a warning and fall back to the default data view when navigating to a URL with an invalid data view ID', async () => {
|
||||
await PageObjects.common.navigateToApp('discover');
|
||||
await PageObjects.timePicker.setDefaultAbsoluteRange();
|
||||
await PageObjects.header.waitUntilLoadingHasFinished();
|
||||
const dataViewId = await PageObjects.discover.getCurrentDataViewId();
|
||||
const originalUrl = await browser.getCurrentUrl();
|
||||
const newUrl = originalUrl.replace(dataViewId, 'invalid-data-view-id');
|
||||
await browser.get(newUrl);
|
||||
await PageObjects.header.waitUntilLoadingHasFinished();
|
||||
await retry.try(async () => {
|
||||
expect(await browser.getCurrentUrl()).to.be(originalUrl);
|
||||
expect(await testSubjects.exists('dscDataViewNotFoundShowDefaultWarning')).to.be(true);
|
||||
});
|
||||
});
|
||||
|
||||
it('should show a warning and fall back to the current data view if the URL is updated to an invalid data view ID', async () => {
|
||||
await PageObjects.common.navigateToApp('discover');
|
||||
await PageObjects.timePicker.setDefaultAbsoluteRange();
|
||||
const originalHash = await browser.execute<[], string>('return window.location.hash');
|
||||
const dataViewId = await PageObjects.discover.getCurrentDataViewId();
|
||||
const newHash = originalHash.replace(dataViewId, 'invalid-data-view-id');
|
||||
await browser.execute(`window.location.hash = "${newHash}"`);
|
||||
await PageObjects.header.waitUntilLoadingHasFinished();
|
||||
await retry.try(async () => {
|
||||
const currentHash = await browser.execute<[], string>('return window.location.hash');
|
||||
expect(currentHash).to.be(originalHash);
|
||||
expect(await testSubjects.exists('dscDataViewNotFoundShowSavedWarning')).to.be(true);
|
||||
});
|
||||
});
|
||||
|
||||
it('should sync Lens global state to Discover sidebar link and carry over the state when navigating to Discover', async () => {
|
||||
await PageObjects.common.navigateToApp('discover');
|
||||
await PageObjects.common.navigateToApp('lens');
|
||||
await appsMenu.openCollapsibleNav();
|
||||
let discoverLink = await appsMenu.getLink('Discover');
|
||||
expect(discoverLink?.href).to.contain(
|
||||
'/app/discover#/?_g=(filters:!(),refreshInterval:(pause:!t,value:60000),time:(from:now-15m,to:now))' +
|
||||
"&_a=(columns:!(),filters:!(),index:'logstash-*',interval:auto,query:(language:kuery,query:''),sort:!(!('@timestamp',desc)))"
|
||||
);
|
||||
await appsMenu.closeCollapsibleNav();
|
||||
await PageObjects.timePicker.setDefaultAbsoluteRange();
|
||||
await filterBar.addFilter({
|
||||
field: 'extension.raw',
|
||||
operation: 'is one of',
|
||||
value: ['jpg', 'css'],
|
||||
});
|
||||
await filterBar.toggleFilterPinned('extension.raw');
|
||||
await PageObjects.header.waitUntilLoadingHasFinished();
|
||||
await appsMenu.openCollapsibleNav();
|
||||
discoverLink = await appsMenu.getLink('Discover');
|
||||
expect(discoverLink?.href).to.contain(
|
||||
"/app/discover#/?_g=(filters:!(('$state':(store:globalState)," +
|
||||
"meta:(alias:!n,disabled:!f,field:extension.raw,index:'logstash-*'," +
|
||||
'key:extension.raw,negate:!f,params:!(jpg,css),type:phrases,value:!(jpg,css)),' +
|
||||
'query:(bool:(minimum_should_match:1,should:!((match_phrase:(extension.raw:jpg)),' +
|
||||
"(match_phrase:(extension.raw:css))))))),query:(language:kuery,query:'')," +
|
||||
"refreshInterval:(pause:!t,value:60000),time:(from:'2015-09-19T06:31:44.000Z'," +
|
||||
"to:'2015-09-23T18:31:44.000Z'))&_a=(columns:!(),filters:!(),index:'logstash-*'," +
|
||||
"interval:auto,query:(language:kuery,query:''),sort:!(!('@timestamp',desc)))"
|
||||
);
|
||||
await appsMenu.clickLink('Discover');
|
||||
await PageObjects.header.waitUntilLoadingHasFinished();
|
||||
expect(await filterBar.hasFilter('extension.raw', '', undefined, true)).to.be(true);
|
||||
expect(await filterBar.isFilterPinned('extension.raw')).to.be(true);
|
||||
expect(await PageObjects.timePicker.getTimeConfig()).to.eql({
|
||||
start: 'Sep 19, 2015 @ 06:31:44.000',
|
||||
end: 'Sep 23, 2015 @ 18:31:44.000',
|
||||
});
|
||||
expect(await PageObjects.discover.getHitCount()).to.be('11,268');
|
||||
});
|
||||
});
|
||||
}
|
|
@ -37,5 +37,6 @@ export default function ({ getService, loadTestFile }: FtrProviderContext) {
|
|||
loadTestFile(require.resolve('./_inspector'));
|
||||
loadTestFile(require.resolve('./_date_nanos'));
|
||||
loadTestFile(require.resolve('./_date_nanos_mixed'));
|
||||
loadTestFile(require.resolve('./_url_state'));
|
||||
});
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue