一,安装出现的问题
1,webdriver has no attribute “find_element_by_id”
原因:下载selenium没有指定版本,导致版本过高,当前语法不支持
解决办法:cmd执行:1)pip uninstall selenium
2)pip install Selenium==3.12.0
2,gecodriver needs to be in PATH
原因:驱动存放路径没有添加系统环境变量
解决办法:
1)找到驱动存放路径,复制路径
2)将复制的路径添加到系统环境变量中(PATH里)
3,安装了selenium报错has no attribute Chrome或者Firefox
原因:pycharm没有加上selenium包
解决办法:步骤五重新再执行一遍,点击确定就会出现当前python环境下安装的最新的包
二,测试中的问题
1,driver = webdriver.chrome() TypeError: ‘module‘ object is not callable
解决办法
方法一:
chrome的首字母应该为大写,如下:
driver=webdriver.Chrome()
修改代码后程序即可正常运行
from selenium import webdriver
driver = webdriver.Chrome()
方法二:
你也可以将路径传递给你的Chromedriver,将executable_path设置为你的chromedriver所在的位置(指向chromedriver.exe的路径,或者,对于非Windows用户,它被称为chromedriver):
driver = webdriver.Chrome(executable_path='C:/path/to/chromedriver.exe')
方法三:
driver = webdriver.Chrome()是因为没有chromedriver.exe这个文件
(1)下载一个chromedriver.exe 下载的链接为:
http://chromedriver.chromium.org/downloads
(2)然后根据自己的系统去下载不同的chromedriver.exe文件,windows只有32的但是都可以用
(3)解压后挡在这个目录的Scripts下面
2,ImprotError:No module named 'cv2’
利用以下命令:
pip install opencv-python
3,定位不到元素
原因:
- 元素定位方式编写错误
- 点击速度过快,页面没有加载出来就需要点击页面上的元
- frame/iframe表单嵌套
- 页面跳转到新的标签页,未切换handle窗口
- 使用了动态属性进行定位元素
解决办法:
(1).Frame/Iframe原因定位不到元素:
这个是最常见的原因,首先要理解下frame的实质,frame中实际上是嵌入了另一个页面,而webdriver每次只能在一个页面识别,因此需要先定位到相应的frame,对那个页面里的元素进行定位。
解决方案:
如果iframe有name或id的话,直接使用switch_to_frame(“name值”)或switch_to_frame(“id值”)。如下:
driver=webdriver.Firefox()
driver.get(r’http://www.126.com/’)
driver.switch_to_frame(‘x-URS-iframe’) #需先跳转到iframe框架
username=driver.find_element_by_name(‘email’)
username.clear()
如果iframe没有name或id的话,则可以通过下面的方式定位:
- 先定位到iframe
elementi= driver.find_element_by_class_name(‘APP-editor-iframe’)- 再将定位对象传给switch_to_frame()方法
driver.switch_to_frame(elementi)
(2)还未加载出元素就开始定位元素
- 强制等待sleep(3)
不管元素,是否在页面出现都等 3 秒,再去操作它,是强制性。但是这种情况往往一般都只用在脚本的调试,真正的自动化测试用例中一般不会使用。 - 隐式等待implicitly_wait(3)
是设置的全局等待,等待时间是对页面中的所有元素设置加载时间,如果超出了设置时间的则抛出异常。缺点:隐式等待的三秒钟就是在等待这个页面的所有 js 和图片加载出来,就算需要操作的按钮出来了,还要去等 页面js、img 加载完成 - 显示等待WebDriverWait(3)
是针对于某个特定的元素设置的等待时间,在设置时间内,默认每隔一段时间检测一次当前页面某个元素是否存在,如果在规定的时间内找到了元素,则直接执行,即找到元素就执行相关操作,如果超过设置时间检测不到则抛出异常。默认检测频率为0.5s,默认抛出异常为:NoSuchElementException
4,自动化测试的异常
解决办法:
- 1.try:要执行的代码块
except 异常名称:
print(“异常提示”) - 2.try:要执行的代码块
except (异常名称)as 别名:
print(“异常提示”) - 3.try:要执行的代码块
except (异常名称)as 别名:
print(“异常提示”)
finally:
最终必须要执行的代码块 - 4.raise直接抛出异常
三,优化
1,Selenium中如何保证操作元素的成功率或者稳定性?
•减少操作步骤,例如需要多次操作进入测试页面,直接通过网址来打开,减少不必要的操作
•合理的使用等待操作:time.sleep()、driver.implicitly_wait()、WebDriverWait()
•使用多种方式进行id/name/class/xpath/css selector不同方式进行定位
•为了减少用例之间相互影响,所以设计用例时,尽量降低用例的耦合度
•多用try捕捉处理异常
•针对一些不稳定的动态控件经过JS实现操作
• 框架中使用用例失败重试,提升测试用例成功率
2,如何提高selenium脚本的执行速度?
•减少操作步骤,例如需要多次操作进入测试页面,直接通过网址来打开,减少不必要的操作
•中断页面加载,如果页面加载的内容过多,我们可以查看一下加载慢的原因,如果加载的内容不影响我们测试,就设置超时时间,中断页面加载
•服务器允许的情况下,尽量设置多线程运行,提高执行速度,前提用例之间没有耦合度
•使用更高配置的电脑和选择更快的网络环境
•不要加太多的sleep,尽量使用显式等待
3,定期检查测试
自动化测试的有效性需要通过维护去保持,定期重新审查就是一种测试脚本的维护手段,是非常有必要的。而频率则需要结合团队对测试脚本维护的力度来看,复审的主要的方法与开发完成之后的初次审查是一样的,只是关注点会稍有不同。检查测试有助于过滤掉不再相关的不必要和过时的数据。这有助于降低成本和维护工作
4,生成丰富的相关测试数据
高质量的数据对于良好的测试是必不可少的。因此,重要的是要确保数据是正确的、准确的及最新的,需涵盖系统内几乎所有的场景和功能。这里可以采用通用数据生成器ZenData来生成所需的大规模数据,支持多种语言,数据格式可自定义,一键生成百万条数据,毫无压力。