我需要检查Div标签的文本,并确保它是否显示正确的文本
这是HTML代码:
这是我写的断言内容的步骤定义
Given(/^offer summary section should display "([^"]*)" amount against "([^"]*)"$/, (charge, labelText) => {
const parentElement = cy.get('.c-offer-summary > .c-offer-summary__ledger').children('.c-ledger__section').find('.c-ledger__row-name').contains(labelText).parent();
parentElement.find('.c-ledger__row-amount').invoke('text').should('eq',charge);
});
但是柏树抛出了一个错误:
我不知道我哪里出错!!! :(
任何帮助表示赞赏
我假设你试图测试.c-ledger__row-amount是“DKK 15.00”。试试这个。
cy.get(".c-ledger__row-amount").invoke('text').then((text) => {
expect(text.trim()).equal('DKK 15.00');
});
有时您必须删除尾随空格
这看起来像Replacing " " from javascript dom text node类似的问题。
请尝试此命令链
const parentElement = cy.get('.c-offer-summary > .c-offer-summary__ledger')
.children('.c-ledger__section')
.find('.c-ledger__row-name')
.contains(labelText)
.parent();
parentElement.find('.c-ledger__row-amount')
.invoke('text')
.should('satisfy', (text) => text.replace(/\u00a0/g, ' ') === charge);