我开始使用Appium测试我的React Native应用程序。我有一个简单的登录方案,在输入和提交一些用户名和密码后,我期望应用status
为'Logged in'
。我正在iPhone X 12.2模拟器上运行测试。
但是测试失败并显示以下错误:
Expected: "Logged in"
Received: "status"
以某种方式无法正确接收文本值。那么如何获取元素的内部文本?
App.js:
<Text accessibilityLabel="status">{this.state.status}</Text>
appium.test.js:
test('Login success', async() => {
expect(await driver.hasElementByAccessibilityId('username input')).toBe(true)
expect(await driver.hasElementByAccessibilityId('password input')).toBe(true)
expect(await driver.hasElementByAccessibilityId('submit button')).toBe(true)
expect(await driver.hasElementByAccessibilityId('status')).toBe(true)
await driver.elementByAccessibilityId('username input').sendKeys('some_username')
await driver.elementByAccessibilityId('password input').sendKeys('some_password')
await driver.elementByAccessibilityId('submit button').click()
const result = await driver.elementByAccessibilityId('status').text()
console.log(result) // 'status' WHY???
// the test runs fine until here:
expect(result).toBe('Logged in')
})
我能想到的是text()
不是获取元素内部文本的正确函数,但这就是我一直关注的文档或教程中看到的全部内容……>
答案 0 :(得分:2)
我遇到了同样的问题。 似乎RN0.50引入了此问题。
这不是Appium上的错误,而是WDA实施以及它如何返回文本值的问题。 https://github.com/appium/appium/issues/10349对此问题进行了讨论。
您可以使用testID
而不是accessibilityLabel
在IOS上解决它。
let textProps={}
if(Platform.OS==='android')
textProps.accessibilityLabel = "welcomeLabel"
...
...
...
<Text
style={styles.welcome}
{...textProps}
testID="welcomeLabel">
...
...
您仍然可以使用elementByAccessibilityId
功能。