Selenium没有看到AngularJS页面元素

前端之家收集整理的这篇文章主要介绍了Selenium没有看到AngularJS页面元素前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在编写Selenium测试以检查我的应用程序时遇到问题.我想测试的是当用户输入正确的登录名/密码时,会显示正确的页面并且用户登录.

主要问题是我的登录表单是作为AngularJS指令生成的(我有两个不同的登录页面,这个指令在两个地方都被重用),而Selenium似乎无法看到这个指令生成标记中的元素.
最重要的是,在我用指令生成的常规标记替换之前,测试正在传递此页面.

所以看起来Selenium似乎无法看到由指令生成的html元素.

有什么建议我如何克服这个问题?除了当然还原这个变化引入指令:)

页面源将在Angular编译之前显示模板.您应该能够使用Chrome的开发者控制台查看已编译的模板:尝试右键单击元素并选择“检查元素”将其打开.

driver.getPageSource()将失败的原因相同(它获取未编译的模板),但driver.findElement()应该可以正常工作.

<input id="username" type="text" ng-model="foo"/>

应该找到使用

driver.findElement(By.id("username"));

猜你在找的Angularjs相关文章