Appium element.text()返回元素accessibilityLabel而不是text

时间:2019-04-14 15:22:54

标签: react-native testing appium

我开始使用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()不是获取元素内部文本的正确函数,但这就是我一直关注的文档或教程中看到的全部内容……

1 个答案:

答案 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功能。