From 132b1f75aedd73b18479ff10cf3ab8e59819c1fd Mon Sep 17 00:00:00 2001 From: spalger Date: Fri, 10 Aug 2018 13:29:21 -0700 Subject: [PATCH] [pageObjects/dashboard] check that save is complete before resolving --- .../apps/dashboard/_dashboard_time.js | 9 +++------ .../functional/page_objects/dashboard_page.js | 19 +++++++++++++++++-- 2 files changed, 20 insertions(+), 8 deletions(-) diff --git a/test/functional/apps/dashboard/_dashboard_time.js b/test/functional/apps/dashboard/_dashboard_time.js index 4ecef2007bc94..285da16bfb443 100644 --- a/test/functional/apps/dashboard/_dashboard_time.js +++ b/test/functional/apps/dashboard/_dashboard_time.js @@ -42,8 +42,7 @@ export default function ({ getPageObjects, getService }) { it('is saved', async () => { await PageObjects.dashboard.clickNewDashboard(); await PageObjects.dashboard.addVisualizations([PageObjects.dashboard.getTestVisualizationNames()[0]]); - const isDashboardSaved = await PageObjects.dashboard.saveDashboard(dashboardName, { storeTimeWithDashboard: false }); - expect(isDashboardSaved).to.eql(true); + await PageObjects.dashboard.saveDashboard(dashboardName, { storeTimeWithDashboard: false }); }); it('Does not set the time picker on open', async () => { @@ -62,8 +61,7 @@ export default function ({ getPageObjects, getService }) { it('is saved with quick time', async function () { await PageObjects.dashboard.clickEdit(); await PageObjects.header.setQuickTime('Today'); - const isDashboardSaved = await PageObjects.dashboard.saveDashboard(dashboardName, { storeTimeWithDashboard: true }); - expect(isDashboardSaved).to.eql(true); + await PageObjects.dashboard.saveDashboard(dashboardName, { storeTimeWithDashboard: true }); }); it('sets quick time on open', async function () { @@ -78,8 +76,7 @@ export default function ({ getPageObjects, getService }) { it('is saved with absolute time', async function () { await PageObjects.dashboard.clickEdit(); await PageObjects.header.setAbsoluteRange(fromTime, toTime); - const isDashboardSaved = await PageObjects.dashboard.saveDashboard(dashboardName, { storeTimeWithDashboard: true }); - expect(isDashboardSaved).to.eql(true); + await PageObjects.dashboard.saveDashboard(dashboardName, { storeTimeWithDashboard: true }); }); it('sets absolute time on open', async function () { diff --git a/test/functional/page_objects/dashboard_page.js b/test/functional/page_objects/dashboard_page.js index 73b53043cb3b7..14ecd13d2c48c 100644 --- a/test/functional/page_objects/dashboard_page.js +++ b/test/functional/page_objects/dashboard_page.js @@ -288,6 +288,8 @@ export function DashboardPageProvider({ getService, getPageObjects }) { } /** + * Save the current dashboard with the specified name and options and + * verify that the save was successful * * @param dashName {String} * @param saveOptions {{storeTimeWithDashboard: boolean, saveAsNew: boolean, needsConfirm: false}} @@ -301,8 +303,21 @@ export function DashboardPageProvider({ getService, getPageObjects }) { await PageObjects.header.waitUntilLoadingHasFinished(); - // Confirm that the Dashboard has been saved. - return await testSubjects.exists('saveDashboardSuccess'); + // Confirm that the Dashboard has actually been saved + if (!await testSubjects.exists('saveDashboardSuccess')) { + throw new Error('Expected to find "saveDashboardSuccess" toast after saving dashboard'); + } + + await this.waitForSaveModalToClose(); + } + + async waitForSaveModalToClose() { + log.debug('Waiting for dashboard save modal to close'); + await retry.try(async () => { + if (await testSubjects.exists('dashboardSaveModal')) { + throw new Error('dashboard save still open'); + } + }); } async deleteDashboard(dashboardName, dashboardId) {