Selenium 自动化框架

目录

Selenium 自动化框架

设计初衷

有什么用

如何使用?

Selenium自动化测试技巧

Selenium自动化

跨浏览器测试中的Selenium

利用正确的定位器

数据驱动的测试

不要依赖特定的驱动程序

选择器顺序

使用PageObjects设计模式

提倡wait避免sleep

关闭Firebug起始页

 


 

Selenium 自动化框架

设计初衷

这个框架一开始就是为了自动化而产生的,因为之前公司有浏览器自动化的需求。一开始的框架其实是非常简陋的,然后因为业务已经稳定了,所以不敢做太大变更。在离职后好好的总结了一下,重新将框架重构。

 

有什么用

高度封装 Selenium 的操作,只要配置 json 就能够实现想要的功能。提供后台动态修改配置,为所要网站更改页面元素快速解决。从此不用再走修改框架源码,上传 git 然后拉取到线上服务器这些繁琐流程。为你省下更多时间喝咖啡。

 

架构 前端 vue 后端 flask 自动化 titans

目录结构

+---abstracts // 抽象类
+---bin // 二进制文件
+---components // 组件
+---configs // 配置文件
+---core // 核心逻辑
+---hooks // 钩子
+---logs // 日志
+---manages // 全局管理类
+---storages // 存储保存位置
|   \---cookies
+---utils // 通用工具
复制代码

组件

│  click.py                 点击操作类                    
│  content.py               html标签内容获取类                    
│  cookie.py                cookie操作类                        
│  for.py                   for循环流程类                    
│  if.py                    if流程类                    
│  iframe.py                iframe操作类            
│  input.py                 输入操作类                    
│  javascript.py            javascript代码执行类                  
│  judge.py                 条件判断类                      
│  request.py               请求类                          
│  sleep.py                 睡眠延时类                        
│  wait.py                  等待事件类                       
│  while.py                 while循环类        
│  window.py                window标签页切换类
复制代码

整体流程

(海量免费学习资料,软件测试交流:1140267353,还会有同行一起技术交流)

 

如何使用?

这里以自动化百度搜索为例子,首先我们需要如下的配置

[
  {
    "component": "request",
    "args": {
      "url": "https://www.baidu.com"
    },
    "type": "browser"
  },
  {
    "component": "input",
    "args": {
      "xpath": "//input[@id='kw']",
      "text": "Python"
    },
    "type": "text"
  },
  {
    "component": "click",
    "args": {
      "xpath": "//input[@id='su']"
    }
  },
  {
    "component": "sleep",
    "args": {
      "time": 3600
    }
  }
]
复制代码

配置中使用 {} 作为一个组件的调用,[] 作为一个作用域来使用。 {} 有三个基本参数:

args 配置参数

type 组件使用具体方法

component 所使用的组件名称

[] 主要是作用域,用于 if, for, while 循环这些有自己作用域的组件,然后在里面调用 {} 就可以 实现流程控制了

具体效果如下:

 

Selenium自动化测试技巧

与以前瀑布式开发模式不同,现在软件测试人员具有使用自动化工具执行测试用例套件的优势,而以前,测试人员习惯于通过测试脚本执行来完成测试。

但自动化测试的目的不是完全摆脱手动测试,而是最大程度地减少手动运行的测试。自动化测试使您可以快速测试多语言站点,还可以提高测试执行速度。

自动化测试的过程很简单

Selenium自动化

由于开源工具和应用程序的成本效益,效率,可重复性,准确性和易用性,它们变得越来越重要。Selenium是开放源代码工具之一,它在应用程序测试方面提供了开放源代码工具的所有优点。

Selenium是用于测试的一套Selenium工具。它包含Selenium IDESelenium RCSelenium WebdriverSelenium Grid。它用于自动化Web交互和回归测试,并具有记录和回放功能。此外还可以将记录的脚本导出为其他语言,包括JavaC#PythonRubyJavascriptPHP(海量免费学习资料,软件测试交流:1140267353,还会有同行一起技术交流)

跨浏览器测试中的Selenium

顾名思义,跨浏览器测试是一种用于在不同的Web浏览器和设备上测试Web应用程序以确保其在每个设备和浏览器上都能无缝运行的方法。

Selenium帮助在Safari,Google Chrome,Mozilla Firefox和IE中自动化测试案例。Selenium也可以同时在不同浏览器上的同一台计算机上执行测试用例。它还支持多种语言和操作系统。

让我们看一下Selenium的最佳实践,以在自动化测试过程中充分利用。

利用正确的定位器

Selenium框架的底部是与浏览器进行交互,从而可以使用文档**对象模型(DOM)**检查,输入和浏览多个对象。这是通过一组操作发生的,并使用了多个定位器,包括CSS选择器,nameXpathID标记名链接文本classname

例如,当您不想在开发人员和测试人员不了解的情况下更改代码时,请使用ClassID定位器。另一方面,当其他团队进行测试时,可以使用链接文本来动态处理情况。最后,可以采用XPath可用于定位。

数据驱动的测试

如果要为不同的输入使用相同的测试和相同的代码,则可以依赖Selenium。它将允许开发人员和质量检查团队进行修改,这意味着您可以将其用于系统功能测试以及浏览器兼容性测试。

Selenium还允许客户从其框架中受益。客户可以利用专有的测试加速器并启动测试自动化。这将减少自动化周期时间。有很多个函数库,可让客户端启动自动化过程。

不要依赖特定的驱动程序

永远不要依赖于一种特定的驱动程序实现。了解驱动程序在不同的浏览器中不是瞬时的。也就是说,不一定会有IE驱动程序、FireFox驱动程序等。

例如,在连续Linux构建过程中执行集成测试时,将收到RemoteDriver。您可以使用LabelledParameterizedJUnit具有,@RunWith 而TestNG为 @Parameters)在Selenium中快速创建小型框架。

ScreenShotWatchManJUnit @RuleTestNG TestListenerAdapter)。换句话说,使用参数注释来处理多种浏览器类型并准备好同时执行是不错的选择。

选择器顺序

选择选择器的顺序很重要,因为选择器(例如XPathCSS)是基于位置的。与IDname链接文本相比,它们比较慢。nameID是特别直接和直接的方式选择器。CSS通常是IDName的组合。相比之下,XPath应该是最后的解决方案。

健壮的解决方案如下所示: XPath <CSS <Links Text <Name <ID。这意味着以ID开头,并使XPath为最后一个选择器。在3个没有数据的表中,XPath识别第二个表的速度最慢,并且可能不会返回正确的表。因此,最后选择了XPath,它们很脆弱。CSS始终与名称和ID结合在一起。

使用PageObjects设计模式

PageObject已作为测试自动化中的最佳设计模式而获得普及。它提升了测试的可维护维护性,还减少了代码重复量。此外,它是一个面向对象的类,它充当被测应用程序页面的接口。为简化起见,PageObject是一种面向对象的设计模式,并且将网页定义为类。页面上的不同元素将成为变量。用户交互被用具体的方法实现。

  • 网页=类别

  • 页面上的各种元素=变量

  • 用户互动=方法

  • PageObject的优点

  • 通过较小的UI调整,它有助于建立一个健壮的框架。测试代码和页面代码是分开的。

  • 它们可靠且易于维护。

  • 该脚本是可读的。该代码是可重用的。

  • 几乎完全消除重复。

提倡wait避免sleep

利用wait代替sleep。了解显式和隐式等待,还有Thread.sleep()逻辑。然后,为什么wait等待而不是sleep

  • wait
  •  

显式–等待某种情况发生,而无需继续编写代码。

隐式–指示WebDriver轮询DOM,直到完成对元素的搜索为止。默认情况下,时间设置为0。

  • sleep

Thread.sleep()无论工作页是否准备就绪,都会在括号内指定的秒数内等待。

关闭Firebug起始页

在启动firefox驱动程序时,可能已包含firebug。有时这可能导致无法工作正常。如果在启动浏览器时同时打开一个新的firebug选项卡使您感到烦恼,请按照以下提供的提示之一关闭firebug起始页。

  • showFirstRunPage标志中将False设置,如下。
FirefoxProfile profile = new FirefoxProfile();
profile.setPreference("extensions.firebug.showFirstRunPage", false);
复制代码

 

最后小枫整理不易,欢迎大家点赞关注收藏!!!

扫码进群领取免费自动化学习资料,面试宝典等等,群内还有大牛交流,欢迎你的到来。

猜你喜欢

转载自blog.csdn.net/weixin_49346599/article/details/107713839