mirror of
https://github.com/elastic/kibana.git
synced 2025-04-24 17:59:23 -04:00
* [@kbn/expect] "fork" expect.js into repo * [eslint] autofix references to expect.js * [tslint] autofix all expect.js imports * now that expect.js is in strict mode, avoid reassigning fn.length
82 lines
3.3 KiB
JavaScript
82 lines
3.3 KiB
JavaScript
/*
|
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
* or more contributor license agreements. Licensed under the Elastic License;
|
|
* you may not use this file except in compliance with the Elastic License.
|
|
*/
|
|
|
|
import expect from '@kbn/expect';
|
|
import { map as mapAsync } from 'bluebird';
|
|
|
|
export function RollupPageProvider({ getService, getPageObjects }) {
|
|
const testSubjects = getService('testSubjects');
|
|
const log = getService('log');
|
|
const PageObjects = getPageObjects(['header', 'common']);
|
|
|
|
|
|
class RollupJobPage {
|
|
async createNewRollUpJob() {
|
|
await testSubjects.click('createRollupJobButton');
|
|
}
|
|
|
|
async verifyStepIsActive(stepNumber) {
|
|
await testSubjects.exists(`createRollupStep${stepNumber}--active`);
|
|
}
|
|
|
|
async addRoleNameandIndexPattern(name, indexPattern) {
|
|
log.debug(`Adding name ${name} to form`);
|
|
await testSubjects.setValue('rollupJobName', name);
|
|
await testSubjects.setValue('rollupIndexPattern', indexPattern);
|
|
}
|
|
|
|
async verifyIndexPatternAccepted() {
|
|
const span = await testSubjects.find('fieldIndexPatternSuccessMessage');
|
|
const message = await span.findByCssSelector('p');
|
|
const text = await message.getVisibleText();
|
|
expect(text).to.be.equal('Success! Index pattern has matching indices.');
|
|
}
|
|
|
|
async setIndexName(name) {
|
|
await testSubjects.setValue('rollupIndexName', name);
|
|
}
|
|
|
|
async moveToNextStep() {
|
|
await testSubjects.click('rollupJobNextButton');
|
|
}
|
|
|
|
async setJobInterval(time) {
|
|
await testSubjects.setValue('rollupJobInterval', time);
|
|
}
|
|
|
|
async saveJob() {
|
|
await testSubjects.click('rollupJobSaveButton');
|
|
await PageObjects.header.waitUntilLoadingHasFinished();
|
|
}
|
|
|
|
async getJobList() {
|
|
const jobs = await testSubjects.findAll('jobTableRow');
|
|
return mapAsync(jobs, async job => {
|
|
const jobNameElement = await job.findByCssSelector('[data-test-subj="jobTableCell-id"]');
|
|
const jobStatusElement = await job.findByCssSelector('[data-test-subj="jobTableCell-status"]');
|
|
const jobIndexPatternElement = await job.findByCssSelector('[data-test-subj="jobTableCell-indexPattern"]');
|
|
const jobRollUpIndexPatternElement = await job.findByCssSelector('[data-test-subj="jobTableCell-rollupIndex"]');
|
|
const jobDelayElement = await job.findByCssSelector('[data-test-subj="jobTableCell-delay"]');
|
|
const jobIntervalElement = await job.findByCssSelector('[data-test-subj="jobTableCell-interval"]');
|
|
const jobGroupElement = await job.findByCssSelector('[data-test-subj="jobTableCell-groups"]');
|
|
const jobMetricsElement = await job.findByCssSelector('[data-test-subj="jobTableCell-metrics"]');
|
|
|
|
return {
|
|
jobName: await jobNameElement.getVisibleText(),
|
|
jobStatus: await jobStatusElement.getVisibleText(),
|
|
jobIndexPattern: await jobIndexPatternElement.getVisibleText(),
|
|
jobRollUpIndexPattern: await jobRollUpIndexPatternElement.getVisibleText(),
|
|
jobDelayElement: await jobDelayElement.getVisibleText(),
|
|
jobInterval: await jobIntervalElement.getVisibleText(),
|
|
jobGroup: await jobGroupElement.getVisibleText(),
|
|
jobMetrics: await jobMetricsElement.getVisibleText()
|
|
};
|
|
});
|
|
}
|
|
|
|
}
|
|
return new RollupJobPage();
|
|
}
|