Skip to content

Commit

Permalink
[7.5] [ML] Functional tests - fix typing issue (#52167) (#52585)
Browse files Browse the repository at this point in the history
* [ML] Functional tests - fix typing issue (#52167)

* Use char by char typing in all text fields

* Add dely before first typed charakter when typing char by char

* Remove delay before typing again

* Use clearCharByChar option for input fields

* Revert "Use clearCharByChar option for input fields"

This reverts commit e412d7b.

* Revert "Use char by char typing in all text fields"

This reverts commit 2fbccc5.

* Disable jobCreatorUpdate for tests

* Revert "Disable jobCreatorUpdate for tests"

This reverts commit e178fd8.

* Check typing char by char for job wizard inputs

* Remove .only from anomaly detection suite

* Move setValueWithChecks from testSubjects to a ML service

# Conflicts:
#	x-pack/test/functional/services/machine_learning/index.ts
#	x-pack/test/functional/services/machine_learning/job_wizard_advanced.ts
#	x-pack/test/functional/services/machine_learning/job_wizard_common.ts
#	x-pack/test/functional/services/ml.ts

* fix bad merge
  • Loading branch information
Spencer authored Dec 10, 2019
1 parent 62dbb69 commit 3b83995
Show file tree
Hide file tree
Showing 5 changed files with 101 additions and 15 deletions.
73 changes: 73 additions & 0 deletions x-pack/test/functional/services/machine_learning/common.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
/*
* 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 { FtrProviderContext } from '../../ftr_provider_context';

interface SetValueOptions {
clearWithKeyboard?: boolean;
typeCharByChar?: boolean;
}

export function MachineLearningCommonProvider({ getService }: FtrProviderContext) {
const log = getService('log');
const retry = getService('retry');
const testSubjects = getService('testSubjects');
const find = getService('find');

return {
async setValueWithChecks(
selector: string,
text: string,
options: SetValueOptions = {}
): Promise<void> {
return await retry.try(async () => {
const { clearWithKeyboard = false, typeCharByChar = false } = options;
log.debug(`TestSubjects.setValueWithChecks(${selector}, ${text})`);
await testSubjects.click(selector);
// in case the input element is actually a child of the testSubject, we
// call clearValue() and type() on the element that is focused after
// clicking on the testSubject
const input = await find.activeElement();

await retry.tryForTime(5000, async () => {
let currentValue = await input.getAttribute('value');
if (currentValue !== '') {
if (clearWithKeyboard === true) {
await input.clearValueWithKeyboard();
} else {
await input.clearValue();
}
currentValue = await input.getAttribute('value');
}

if (currentValue === '') {
return true;
} else {
throw new Error(`Expected input to be empty, but got value '${currentValue}'`);
}
});

for (const chr of text) {
await retry.tryForTime(5000, async () => {
const oldValue = await input.getAttribute('value');
await input.type(chr, { charByChar: typeCharByChar });

await retry.tryForTime(1000, async () => {
const newValue = await input.getAttribute('value');
if (newValue === `${oldValue}${chr}`) {
return true;
} else {
throw new Error(
`After typing character '${chr}', the new value in the input should be '${oldValue}${chr}' (got ${newValue})`
);
}
});
});
}
});
},
};
}
1 change: 1 addition & 0 deletions x-pack/test/functional/services/machine_learning/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@

export { MachineLearningAnomalyExplorerProvider } from './anomaly_explorer';
export { MachineLearningAPIProvider } from './api';
export { MachineLearningCommonProvider } from './common';
export { MachineLearningDataFrameAnalyticsProvider } from './data_frame_analytics';
export { MachineLearningDataVisualizerProvider } from './data_visualizer';
export { MachineLearningJobManagementProvider } from './job_management';
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,15 @@
* you may not use this file except in compliance with the Elastic License.
*/
import expect from '@kbn/expect';
import { ProvidedType } from '@kbn/test/types/ftr';

import { FtrProviderContext } from '../../ftr_provider_context';
import { MachineLearningCommonProvider } from './common';

export function MachineLearningJobWizardAdvancedProvider({
getService,
getPageObjects,
}: FtrProviderContext) {
export function MachineLearningJobWizardAdvancedProvider(
{ getService }: FtrProviderContext,
mlCommon: ProvidedType<typeof MachineLearningCommonProvider>
) {
const comboBox = getService('comboBox');
const testSubjects = getService('testSubjects');
const retry = getService('retry');
Expand Down Expand Up @@ -47,7 +49,7 @@ export function MachineLearningJobWizardAdvancedProvider({
},

async setQueryDelay(queryDelay: string) {
await testSubjects.setValue('mlJobWizardInputQueryDelay', queryDelay, {
await mlCommon.setValueWithChecks('mlJobWizardInputQueryDelay', queryDelay, {
clearWithKeyboard: true,
typeCharByChar: true,
});
Expand All @@ -64,7 +66,7 @@ export function MachineLearningJobWizardAdvancedProvider({
},

async setFrequency(frequency: string) {
await testSubjects.setValue('mlJobWizardInputFrequency', frequency, {
await mlCommon.setValueWithChecks('mlJobWizardInputFrequency', frequency, {
clearWithKeyboard: true,
typeCharByChar: true,
});
Expand All @@ -81,7 +83,7 @@ export function MachineLearningJobWizardAdvancedProvider({
},

async setScrollSize(scrollSize: string) {
await testSubjects.setValue('mlJobWizardInputScrollSize', scrollSize, {
await mlCommon.setValueWithChecks('mlJobWizardInputScrollSize', scrollSize, {
clearWithKeyboard: true,
typeCharByChar: true,
});
Expand Down Expand Up @@ -260,7 +262,7 @@ export function MachineLearningJobWizardAdvancedProvider({
},

async setDetectorDescription(description: string) {
await testSubjects.setValue('mlAdvancedDetectorDescriptionInput', description, {
await mlCommon.setValueWithChecks('mlAdvancedDetectorDescriptionInput', description, {
clearWithKeyboard: true,
});
await this.assertDetectorDescriptionValue(description);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,15 @@
* you may not use this file except in compliance with the Elastic License.
*/
import expect from '@kbn/expect';
import { ProvidedType } from '@kbn/test/types/ftr';

import { FtrProviderContext } from '../../ftr_provider_context';
import { MachineLearningCommonProvider } from './common';

export function MachineLearningJobWizardCommonProvider({ getService }: FtrProviderContext) {
export function MachineLearningJobWizardCommonProvider(
{ getService }: FtrProviderContext,
mlCommon: ProvidedType<typeof MachineLearningCommonProvider>
) {
const comboBox = getService('comboBox');
const retry = getService('retry');
const testSubjects = getService('testSubjects');
Expand Down Expand Up @@ -108,7 +113,7 @@ export function MachineLearningJobWizardCommonProvider({ getService }: FtrProvid
},

async setBucketSpan(bucketSpan: string) {
await testSubjects.setValue('mlJobWizardInputBucketSpan', bucketSpan, {
await mlCommon.setValueWithChecks('mlJobWizardInputBucketSpan', bucketSpan, {
clearWithKeyboard: true,
typeCharByChar: true,
});
Expand All @@ -125,7 +130,9 @@ export function MachineLearningJobWizardCommonProvider({ getService }: FtrProvid
},

async setJobId(jobId: string) {
await testSubjects.setValue('mlJobWizardInputJobId', jobId, { clearWithKeyboard: true });
await mlCommon.setValueWithChecks('mlJobWizardInputJobId', jobId, {
clearWithKeyboard: true,
});
await this.assertJobIdValue(jobId);
},

Expand All @@ -141,7 +148,7 @@ export function MachineLearningJobWizardCommonProvider({ getService }: FtrProvid
},

async setJobDescription(jobDescription: string) {
await testSubjects.setValue('mlJobWizardInputJobDescription', jobDescription, {
await mlCommon.setValueWithChecks('mlJobWizardInputJobDescription', jobDescription, {
clearWithKeyboard: true,
});
await this.assertJobDescriptionValue(jobDescription);
Expand Down Expand Up @@ -283,7 +290,7 @@ export function MachineLearningJobWizardCommonProvider({ getService }: FtrProvid
await this.ensureAdvancedSectionOpen();
subj = advancedSectionSelector(subj);
}
await testSubjects.setValue(subj, modelMemoryLimit, { clearWithKeyboard: true });
await mlCommon.setValueWithChecks(subj, modelMemoryLimit, { clearWithKeyboard: true });
await this.assertModelMemoryLimitValue(modelMemoryLimit, {
withAdvancedSection: sectionOptions.withAdvancedSection,
});
Expand Down
7 changes: 5 additions & 2 deletions x-pack/test/functional/services/ml.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import { FtrProviderContext } from '../ftr_provider_context';
import {
MachineLearningAnomalyExplorerProvider,
MachineLearningAPIProvider,
MachineLearningCommonProvider,
MachineLearningDataFrameAnalyticsProvider,
MachineLearningDataVisualizerProvider,
MachineLearningJobManagementProvider,
Expand All @@ -25,6 +26,8 @@ import {
} from './machine_learning';

export function MachineLearningProvider(context: FtrProviderContext) {
const common = MachineLearningCommonProvider(context);

const anomalyExplorer = MachineLearningAnomalyExplorerProvider(context);
const api = MachineLearningAPIProvider(context);
const dataFrameAnalytics = MachineLearningDataFrameAnalyticsProvider(context);
Expand All @@ -33,8 +36,8 @@ export function MachineLearningProvider(context: FtrProviderContext) {
const jobSourceSelection = MachineLearningJobSourceSelectionProvider(context);
const jobTable = MachineLearningJobTableProvider(context);
const jobTypeSelection = MachineLearningJobTypeSelectionProvider(context);
const jobWizardAdvanced = MachineLearningJobWizardAdvancedProvider(context);
const jobWizardCommon = MachineLearningJobWizardCommonProvider(context);
const jobWizardAdvanced = MachineLearningJobWizardAdvancedProvider(context, common);
const jobWizardCommon = MachineLearningJobWizardCommonProvider(context, common);
const jobWizardMultiMetric = MachineLearningJobWizardMultiMetricProvider(context);
const jobWizardPopulation = MachineLearningJobWizardPopulationProvider(context);
const navigation = MachineLearningNavigationProvider(context);
Expand Down

0 comments on commit 3b83995

Please sign in to comment.