带unittest的脚本分析.py

import unittestfrom selenium import webdriverclass BaiduTest(unittest.TestCase):    def setUp(self):        self.driver = webdriver.Firefox()        self.driver.implicitly_wait(30)        self.base_url = "http://www.baidu.com"        """        接下来定义空的verificationErrors数组,脚本运行时的错误信息将被记录到这个数组中。        """        self.verificationErrors = []        """        定义accept_next alert变量,表示是否继续接受下一个警告,初始状态为True。        """        self.accept_next_alert = True        """        setUp用于设置初始化工作,在执行每一个测试用例前先被执行,它与tearDown方法相呼应,        后者在每一个测试用例执行后被执行。这里的初始化工作定义了浏览器启动和基础URL地址。        """    def test_baidu(self):        driver = self.driver        driver.get(self.base_url + "/")        driver.find_element_by_id("kw").clear()        driver.find_element_by_id("kw").send_keys("selenium ide")        driver.find_element_by_id("su").click()    def is_element_present(self,how,what):        try:            self.driver.find_element(by = how,value=what)        except NoSuchElementException as e:            return False        return True    """    is_element_present方法用于查找页面元素是否存在,通过find_element()来接收元素的定位方法(how)    和定位值(what)。如果定位到元素则返回True,否则抛出异常并返回False。    try..except..…为Python 语言的异常处理。    """    def is_alert_present(self):        try:            self.driver.switch_to_alert()        except NoAlertPresentException as e:            return False        return True    """    is_alert_present()方法用于判断当前页面是否存在警告框,    利用WebDriver提供的switch_to_alert()方法来捕捉页面上警告框。如果捕捉到警告框则返回True,    否则将抛出NoAlertPresentException 类型异常,并返回False。    """    """    不管页面是否出现警告框,返回结果都为True。所以,可以调整该方法为driver.switch_to_alertO.text,    用于获取当前页面上的警告提示信息。可以获取到就返回True,获取不到则返回False。    """    def close_alert_and_get_its_text(self):        try:            alert = self.driver.switch_to_alert()            alert_text = alert.text            if self.accept_next_alert:                alert.accept()            else:                alert.dismiss()            return alert_text        finally:            self.accept_next_alert = True    """    close_alert_and_get_its_text()关闭警告并获得警告信息。首先通过switch_to_alert()获得警告,    通过text 获得警告框信息。接着通过if 语句判断accept_next_alert的状态,在setUp()中已经初始化状态为True,    如果为True,则通过accept()接受警告,否则dismiss()忽略此警告。    """    def tearDown(self):        self.driver.quit()        self.assertEqual([],self.verificationErrors)    """    tearDown()方法在每个测试方法执行后调用,这个方法用于测试用例执行后的清理工作,    如退出浏览器、关闭驱动,恢复用例执行状态等。    """    """    在setUp()方法中定义了verificationErors为空数组,这里通过assertEqual()比较其是否为空,    如果为空则说明用例执行的过程中没有出现异常,否则将抛出AssertionError异常。    """if __name__ == ‘__main__‘:    unittest.main()

原文地址:https://www.cnblogs.com/zhang-da/p/12210761.html

时间: 2024-09-27 20:30:23

带unittest的脚本分析.py的相关文章

Selenium 2自动化测试实战33(带unittest的脚本分析)

带unittest的脚本分析 #test.py #coding:utf-8 from selenium import webdriver from selenium.webdriver.common.keys import Keys from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import Select from selenium.common.exceptions import N

Python 应用闭包思路动态生成unittest执行脚本---分析问题,解决问题,记录填坑。

至于为什么要动态生成unittest执行脚本,以及设计思路,代码阅读参考前文,传送门.好了,本文我们就上一篇文章中的问题做一下分析,记录一下填坑之路吧,这个坑真特么深,挣扎了好久才出来. 首先我们先说一下问题在哪,因为使用了闭包,闭包会绑定变量无法清除无法更改,假如我第一次运行testall函数循环两次,第一次是正常的,第二次运行testall函数循环一次,那么生成的报告就会出现问题,会出现第一次运行的结果.即是:后一次循环运行只要比前一次循环少,那么report一定会出现前一次的结果,必先的b

Hadoop的shell脚本分析

你会发现hadoop-daemon.sh用于启动单独的本机节点 而hadoop-daemons.sh 会批量的ssh到别的机器启动 前记: 这些天一直学习hadoop,学习中也遇到了许多的问题,主要是对hadoop的shell脚本和hadoop的源码概念不够清楚,所以我就对hadoop的bin目录下的shell脚本进行了研究,有一些成果想记录下来,也希望大家前来批评指正. 分析原因: 很多hadoop的初学者对hadoop的脚本不是很清楚,不知道为什么可以在命令行中启动hadoop,也不知道为什

Android自带音频均衡器MusicFx分析

Android自带音频均衡器MusicFx分析 种种原因,我要简单分析一个Android中built-in的音频均衡器MusicFx.重点是它的默认值的来历.网上很少有文章讲了这个的除了这篇<com.android.musicFx设置音效流程 -- 从app到AudioFlinger>.注:Android系统版本为4.2.2_r1. 从App到AudioFliger的终点是在android_media_AudioEffect.cpp(之前版本在是audio_media_AudioEffect.

uboot移植(二)——uboot mkconfig脚本分析

uboot移植(二)--uboot  mkconfig 脚本分析 一:mkconfig脚本的作用 mkconfig是通过传入的参数来脚本用于某个开发板配置uboot,主要是通过判断其输入的参数来创建符号链接文件,使它们指向该开发板对应的配置文件来进行配置. (1)配置CPU架构相关的文件:在include目录下创建asm文件,指向include/asm-arm (2)配置SOC类型相关的文件:include目录下创建regs.h文件,指向include/s5pc110.h include/asm

sqlserver导出带数据的脚本

说明: 以前要将一个表中的数据导出为脚本,只有用存储过程.现在在SQL Server 2008中增加了一个新特性,除了导出表的定义外,还支持将表中的数据导出为脚本. 步骤: 右击需要导出数据的数据库,在弹出式菜单中选择"任务"下的"生成脚本"选项 在第二步选择"高级选项"如果不是2008(R2)的选择 "编写数据的脚本"选择为TRUE,这里默认是为FALSE的 ,   是2008(R2)的选择"要编写的脚本的数据的类

shell脚本分析apache日志状态码

一.首先将apache日志按天切割 vi /etc/httpd/conf/httpd.confErrorLog "|rotatelogs /var/log/httpd/%Y%m%derror_log 86400 480″CustomLog "|rotatelogs /var/log/httpd/%Y%m%daccess_log 86400 480″ combined 二.重启apache服 service httpd restart ##################apahce日志

Hadoop公开课:完全分布式脚本分析

脚本分析start-all.sh 1)首先进入/soft/Hadoop/sbin目录 2)nano start-all.sh sbin/start-all.sh主要做的事情: 1) libexec/hadoop-config.sh 2) start-dfs.sh 3) start-yarn.sh 3)cat libexec/hadoop-config.sh hadoop_conf_dir =etc/hadoop 4)cat sbin/start-dfs.sh sbin/start-dfs.sh的

内核移植(四)——Makefile和链接脚本分析

1:Makefile分析 (1) kernel的Makefile写法和规则等和uboot的Makefile是一样的,甚至Makefile中的很多内容都是一样的. (2) kernel的Makefile比uboot的Makefile要复杂,这里我们并不会一行一行的详细分析. (3) Makefile中只有一些值得关注的我会强调一下,其他不强调的地方暂时可以不管. (4) Makefile中刚开始定义了kernel的内核版本号.这个版本号挺重要(在模块化驱动安装时会需要用到),要注意会查,会改. (