首页 > 编程语言 > 详细

web自动化中踩过的低级错误坑(python+selenium)

时间:2020-04-03 23:51:08      阅读:139      评论:0      收藏:0      [点我收藏+]

1.定位了元素没有做下一步操作,比如,点击、输入等功能,而报错,报错信息如下:

 技术分享图片

2.上传图片时,定位元素,应该定位input标签,点击页面input标签肉眼没有看到定位到任何元素,以为无法成功,实际上只要有input标签被定位到是都可以上传图片的!

3.定义页面基础类时,初始化webdiver,传参数的时候没有对参数driver赋默认None值,即一个默认参数,导致页面报错如下:

传人默认参数,在调用self.main=Main()时,就可以不传入参数了

技术分享图片

class BasePage():
    _base_url = ""

    def __init__(self, driver: WebDriver = None):#就是因为这里没有传None!!??????
        self._driver = None
        if self._driver is None:
            ops_chrome = webdriver.ChromeOptions()
            ops_chrome.debugger_address = "127.0.0.1:9222"
            self._driver = webdriver.Chrome(options=ops_chrome)
        else:
            self._driver = driver
        if self._base_url != "":#这里的意思是如果_base_url不为空的话,就执行跳转到某个页面,这个页面的url其实是子类重写了父类的类属性
            self._driver.get(self._base_url)
        self._driver.implicitly_wait(5)

4. 有时候报错有可能不是没有定位到元素,而是时间太快,页面没有加载出来,这个时候可以加一个等待时间再试一下

5.封装定位元素的方法,应该将by和locate都传进去,使用起来更加灵活!

    def find(self, by, locate):
        return self._driver.find_element(by, locate)

6.在po设计模式中,所有的页面都要继承页面基类(BasePage)

web自动化中踩过的低级错误坑(python+selenium)

原文:https://www.cnblogs.com/zhaikunkun/p/12629621.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!