website/docs/ocr-testing/ocr-set-value.md
Send a sequence of key strokes to an element. It will:
The command will search for the provided text and try to find a match based on Fuzzy Logic from Fuse.js. This means that if you might provide a selector with a typo, or the found text might not be a 100% match it will still try to give you back an element. See the logs below.
await brower.ocrSetValue({
text: "docs",
value: "specfileretries",
});
[0-0] 2024-05-26T04:17:51.355Z INFO webdriver: COMMAND ocrSetValue(<object>)
......................
[0-0] 2024-05-26T04:17:52.356Z INFO @wdio/ocr-service:ocrGetElementPositionByText: We searched for the word "docs" and found one match "docs" with score "100%"
textstringThe text you want to search for to click on.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
});
valuestringValue to be added.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
});
submitValuebooleanfalseIf the value also needs to be submitted into the input field. This means an "ENTER" will be send at the end of the string.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
submitValue: true,
});
clickDurationnumber500 millisecondsThis is the duration of the click. If you want you can also create a "long click" by increasing the time.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
clickDuration: 3000, // This is 3 seconds
});
contrastnumber0.25The higher the contrast, the darker the image and vice versa. This can help to find text in an image. It accepts values between -1 and 1.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
contrast: 0.5,
});
haystacknumberWebdriverIO.Element | ChainablePromiseElement | RectangleThis is the search area in the screen where the OCR needs to look for text. This can be an element or a rectangle containing x, y, width and height
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
haystack: $("elementSelector"),
});
// OR
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
haystack: await $("elementSelector"),
});
// OR
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
haystack: {
x: 10,
y: 50,
width: 300,
height: 75,
},
});
languagestringengThe language that Tesseract will recognize. More info can be found here and the supported languages can be found here.
import { SUPPORTED_OCR_LANGUAGES } from "@wdio/ocr-service";
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
// Use Dutch as a language
language: SUPPORTED_OCR_LANGUAGES.DUTCH,
});
relativePositionobjectYou can click on the screen relative to the matching element. This can be done based on relative pixels above, right, below or left from the matching element
:::note
The following combinations are allowed
above + left or above + rightbelow + left or below + rightThe following combinations are NOT allowed
above plus belowleft plus right:::
relativePosition.abovenumberClick x pixels above the matching element.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
relativePosition: {
above: 100,
},
});
relativePosition.rightnumberClick x pixels right from the matching element.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
relativePosition: {
right: 100,
},
});
relativePosition.belownumberClick x pixels below the matching element.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
relativePosition: {
below: 100,
},
});
relativePosition.leftnumberClick x pixels left from the matching element.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
relativePosition: {
left: 100,
},
});
fuzzyFindOptionsYou can alter the fuzzy logic to find text with the following options. This might help find a better match
fuzzyFindOptions.distancenumberDetermines how close the match must be to the fuzzy location (specified by location). An exact letter match which is distance characters away from the fuzzy location would score as a complete mismatch. A distance of 0 requires the match to be at the exact location specified. A distance of 1000 would require a perfect match to be within 800 characters of the location to be found using a threshold of 0.8.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
fuzzyFindOptions: {
distance: 20,
},
});
fuzzyFindOptions.locationnumberDetermines approximately where in the text is the pattern expected to be found.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
fuzzyFindOptions: {
location: 20,
},
});
fuzzyFindOptions.thresholdnumberAt what point does the matching algorithm give up. A threshold of 0 requires a perfect match (of both letters and location), a threshold of 1.0 would match anything.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
fuzzyFindOptions: {
threshold: 0.8,
},
});
fuzzyFindOptions.isCaseSensitivebooleanWhether the search should be case sensitive.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
fuzzyFindOptions: {
isCaseSensitive: true,
},
});
fuzzyFindOptions.minMatchCharLengthnumberOnly the matches whose length exceeds this value will be returned. (For instance, if you want to ignore single character matches in the result, set it to 2)
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
fuzzyFindOptions: {
minMatchCharLength: 5,
},
});
fuzzyFindOptions.findAllMatchesnumberWhen true, the matching function will continue to the end of a search pattern even if a perfect match has already been located in the string.
await browser.ocrSetValue({
text: "WebdriverIO",
value: "The Value",
fuzzyFindOptions: {
findAllMatches: 100,
},
});