Skip to content

Commit

Permalink
[Dashboard] Retain Tags on Quicksave (elastic#111015)
Browse files Browse the repository at this point in the history
* fixed missing tags api when loading saved dashboard. Added tests
  • Loading branch information
ThomThomson authored and chrisronline committed Sep 8, 2021
1 parent af45242 commit 856c8d3
Show file tree
Hide file tree
Showing 4 changed files with 104 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ export const useDashboardAppState = ({
savedDashboards,
kbnUrlStateStorage,
initializerContext,
savedObjectsTagging,
isEmbeddedExternally,
dashboardCapabilities,
dispatchDashboardStateChange,
Expand Down
20 changes: 13 additions & 7 deletions test/functional/page_objects/dashboard_page.ts
Original file line number Diff line number Diff line change
Expand Up @@ -284,9 +284,11 @@ export class DashboardPageObject extends FtrService {
}

public async clickQuickSave() {
await this.expectQuickSaveButtonEnabled();
this.log.debug('clickQuickSave');
await this.testSubjects.click('dashboardQuickSaveMenuItem');
await this.retry.try(async () => {
await this.expectQuickSaveButtonEnabled();
this.log.debug('clickQuickSave');
await this.testSubjects.click('dashboardQuickSaveMenuItem');
});
}

public async clickNewDashboard(continueEditing = false) {
Expand Down Expand Up @@ -392,10 +394,11 @@ export class DashboardPageObject extends FtrService {
*/
public async saveDashboard(
dashboardName: string,
saveOptions: SaveDashboardOptions = { waitDialogIsClosed: true, exitFromEditMode: true }
saveOptions: SaveDashboardOptions = { waitDialogIsClosed: true, exitFromEditMode: true },
clickMenuItem = true
) {
await this.retry.try(async () => {
await this.enterDashboardTitleAndClickSave(dashboardName, saveOptions);
await this.enterDashboardTitleAndClickSave(dashboardName, saveOptions, clickMenuItem);

if (saveOptions.needsConfirm) {
await this.ensureDuplicateTitleCallout();
Expand Down Expand Up @@ -435,9 +438,12 @@ export class DashboardPageObject extends FtrService {
*/
public async enterDashboardTitleAndClickSave(
dashboardTitle: string,
saveOptions: SaveDashboardOptions = { waitDialogIsClosed: true }
saveOptions: SaveDashboardOptions = { waitDialogIsClosed: true },
clickMenuItem = true
) {
await this.testSubjects.click('dashboardSaveMenuItem');
if (clickMenuItem) {
await this.testSubjects.click('dashboardSaveMenuItem');
}
const modalDialog = await this.testSubjects.find('savedObjectSaveModal');

this.log.debug('entering new title');
Expand Down
89 changes: 89 additions & 0 deletions x-pack/test/functional/apps/dashboard/dashboard_tagging.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
/*
* 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; you may not use this file except in compliance with the Elastic License
* 2.0.
*/

import expect from '@kbn/expect';
import { FtrProviderContext } from '../../ftr_provider_context';

export default function ({ getService, getPageObjects }: FtrProviderContext) {
const listingTable = getService('listingTable');
const testSubjects = getService('testSubjects');
const esArchiver = getService('esArchiver');
const find = getService('find');
const PageObjects = getPageObjects([
'common',
'tagManagement',
'header',
'dashboard',
'visualize',
'lens',
]);

const dashboardTag = 'extremely-cool-dashboard';
const dashboardTitle = 'Coolest Blank Dashboard';

describe('dashboard tagging', () => {
const verifyTagFromListingPage = async () => {
await PageObjects.dashboard.gotoDashboardLandingPage();
await listingTable.waitUntilTableIsLoaded();

// open the filter dropdown
const filterButton = await find.byCssSelector('.euiFilterGroup .euiFilterButton');
await filterButton.click();
await testSubjects.click(
`tag-searchbar-option-${PageObjects.tagManagement.testSubjFriendly(dashboardTag)}`
);
// click elsewhere to close the filter dropdown
const searchFilter = await find.byCssSelector('.euiPageBody .euiFieldSearch');
await searchFilter.click();
// wait until the table refreshes
await listingTable.waitUntilTableIsLoaded();
const itemNames = await listingTable.getAllItemsNames();
expect(itemNames).to.contain(dashboardTitle);
};

const createTagFromDashboard = async () => {
await testSubjects.click('dashboardSaveMenuItem');
await testSubjects.click('savedObjectTagSelector');
await testSubjects.click(`tagSelectorOption-action__create`);

expect(await PageObjects.tagManagement.tagModal.isOpened()).to.be(true);

await PageObjects.tagManagement.tagModal.fillForm(
{
name: dashboardTag,
color: '#fc03db',
description: '',
},
{
submit: true,
}
);
expect(await PageObjects.tagManagement.tagModal.isOpened()).to.be(false);
};

before(async () => {
await esArchiver.loadIfNeeded('x-pack/test/functional/es_archives/logstash_functional');
await esArchiver.loadIfNeeded('x-pack/test/functional/es_archives/lens/basic');
await PageObjects.common.navigateToApp('dashboard');
await PageObjects.dashboard.preserveCrossAppState();
await PageObjects.dashboard.clickNewDashboard();
});

it('adds a new tag to a new Dashboard', async () => {
await createTagFromDashboard();
PageObjects.dashboard.saveDashboard(dashboardTitle, {}, false);
await verifyTagFromListingPage();
});

it('retains its saved object tags after quicksave', async () => {
await PageObjects.dashboard.gotoDashboardEditMode(dashboardTitle);
await PageObjects.dashboard.useMargins(false); // turn margins off to cause quicksave to be enabled
await PageObjects.dashboard.clickQuickSave();
await verifyTagFromListingPage();
});
});
}
1 change: 1 addition & 0 deletions x-pack/test/functional/apps/dashboard/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ export default function ({ loadTestFile }: FtrProviderContext) {
loadTestFile(require.resolve('./drilldowns'));
loadTestFile(require.resolve('./sync_colors'));
loadTestFile(require.resolve('./_async_dashboard'));
loadTestFile(require.resolve('./dashboard_tagging'));
loadTestFile(require.resolve('./dashboard_lens_by_value'));
loadTestFile(require.resolve('./dashboard_maps_by_value'));

Expand Down

0 comments on commit 856c8d3

Please sign in to comment.