HTML5   发布时间:2022-04-27  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了ios – 使用EarlGrey按导航栏上的后退按钮大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图编写一个使用后退按钮的测试时遇到了一些麻烦,希望有人能指出我正确的方向.

我的观点很标准我有一个UINavigation控制器作为我的根视图控制器,我正在推动它到一个点,然后需要回去.

我试图让匹配器找到导航栏中的后退按钮,但没有取得任何成功.
我试图使用标签,id和值,在后退按钮项上设置辅助功能标识符并没有产生匹配,即使它适用于我的其他界面元素.

[self.navigationItem.BACkBarButtonItem setAccessibilityIdentifier:@"BACk"];

在我的测试中,我有以下内容

// Press the BACk button

id<GREymatcher> BACkMatcher =
    grey_allOf(grey_accessibilityID(@"BACk"),grey_sufficientlyVisible(),nil);

[[EarlGrey SELEctElementWithMatcher:BACkMatcher] performAction:grey_tap()];

我使用断点和PO深入研究,发现后退按钮的accessibilityLabel确实设置为@“BACk”,但它也与下面的代码不匹配.

// Press the BACk button

id<GREymatcher> BACkMatcher =
    grey_allOf(grey_accessibilityID(@"BACk"),nil);

[[EarlGrey SELEctElementWithMatcher:BACkMatcher] performAction:grey_tap()];

解决方法

问题是你需要一个更具体的匹配器来从UINavigationController获取BACk按钮.如果查看测试失败时转储的ui层次结构,您会注意到多个元素具有可访问性标签BACk.因此,您需要使用grey_accessibilityTrait匹配器来缩小搜索范围,如下所示:

id<GREymatcher> matcherForBACkButton =
    grey_allOf(grey_accessibilityLabel(@"BACk"),grey_accessibilityTrait(UIAccessibilityTraitButton),nil);

[[EarlGrey SELEctElementWithMatcher:matcherForBACkButton]
    performAction:grey_tap()];

大佬总结

以上是大佬教程为你收集整理的ios – 使用EarlGrey按导航栏上的后退按钮全部内容,希望文章能够帮你解决ios – 使用EarlGrey按导航栏上的后退按钮所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。