I have an element defined as
this.clientRowName = element(by.id('CLIENT_NAME')); //page object file
I want to read the text in this element which is "ABC" but doing: var client = page.clientRowName.getText();
returns an object instead of a string. Is there any other way that I can get the text for the element
getText()If the element has any text in it, then getText( ) function is used to get that text from the element. element(by.id('username')). getText(); sendKeys() If you want to send text to the input field, we use sendKeys( ) function.
getText() This method returns a string representing the value of the current element. You must use the other XML get methods to navigate through an XML document. This method is a synonym for getNodeValue();.
getText()
returns a promise, you need to resolve it:
page.clientRowName.getText().then(function (text) {
console.log(text);
});
Or, if you just want to assert the text, let expect()
resolve the promise for you:
expect(page.clientRowName.getText()).toEqual("ABC");
Promises and the Control Flow documentation page should clear things up.
Another solution may be to use async/await
.
class Page {
constructor() {
this.clientRowName = $('#CLIENT_NAME');
}
}
/****************/
it('should console.log client name', async () => {
const client = await Page.clientRowName.getText();
console.log(client);
});
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With