4584a8b570
* Updating everything except the license headers themselves * Applying ESLint rules * Manually replacing the stragglers
55 lines
2.4 KiB
TypeScript
55 lines
2.4 KiB
TypeScript
/*
|
|
* 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 { FtrProviderContext } from '../ftr_provider_context';
|
|
|
|
const RENDER_COMPLETE_SELECTOR = '[data-render-complete="true"]';
|
|
const RENDER_COMPLETE_PENDING_SELECTOR = '[data-render-complete="false"]';
|
|
const DATA_LOADING_SELECTOR = '[data-loading]';
|
|
|
|
export function RenderableProvider({ getService }: FtrProviderContext) {
|
|
const log = getService('log');
|
|
const retry = getService('retry');
|
|
const find = getService('find');
|
|
|
|
class Renderable {
|
|
/**
|
|
* This method waits for a certain number of objects to finish rendering and loading, which is indicated
|
|
* by a couple tags. The RENDER_COMPLETE_SELECTOR indicates that it's done initially loading up. Some
|
|
* visualizations also add a DATA_LOADING_SELECTOR when the internal data is loading. This test will not
|
|
* return if any of those tags are found.
|
|
* @param count {Number} Number of RENDER_COMPLETE_SELECTORs to wait for.
|
|
*/
|
|
public async waitForRender(count: number = 1): Promise<void> {
|
|
log.debug(`Renderable.waitForRender for ${count} elements`);
|
|
await retry.try(async () => {
|
|
const completedElements = await find.allByCssSelector(RENDER_COMPLETE_SELECTOR);
|
|
if (completedElements.length < count) {
|
|
const pendingElements = await find.allByCssSelector(RENDER_COMPLETE_PENDING_SELECTOR);
|
|
const pendingElementNames = [];
|
|
for (const pendingElement of pendingElements) {
|
|
const title = await pendingElement.getAttribute('data-title');
|
|
pendingElementNames.push(title);
|
|
}
|
|
throw new Error(`${
|
|
completedElements.length
|
|
} elements completed rendering, still waiting on a total of ${count}
|
|
specifically:\n${pendingElementNames.join('\n')}`);
|
|
}
|
|
|
|
const stillLoadingElements = await find.allByCssSelector(DATA_LOADING_SELECTOR, 1000);
|
|
if (stillLoadingElements.length > 0) {
|
|
throw new Error(`${stillLoadingElements.length} elements still loading contents`);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
return new Renderable();
|
|
}
|