查看原文
其他

创建你的第一个webdriver python代码

苦叶子 开源优测 2022-11-13

前言

今天我们开始我们的第一个python webdriver自动化测试脚本。并就测试脚本进行一一解释说明。

webdriver python代码

本示例代码演示了使用Ie浏览器访问百度进行搜索测试。

HTMLTestRunner 从这里下载:

 

下载后和当前测试脚本放在同一目录。

# 将以下代码保存到first_webdriver.py中

#-*- coding:utf-8 -*-

__author__ = u'苦叶子'

from selenium import webdriver
import
unittest
import
HTMLTestRunner  import sysfrom time import sleep reload(sys) sys.setdefaultencoding("utf-8")

class BaiduTest(unittest.TestCase):
   """百度首页搜索测试用例"""    def setUp(self):        self.driver = webdriver.Ie()        self.driver.implicitly_wait(30)        self.base_url = u"http://www.baidu.com"            def test_baidu_search(self):        driver = self.driver        print u"开始[case_0001]百度搜索"        driver.get(self.base_url)                # 验证标题        self.assertEqual(driver.title, u"百度一下,你就知道")        driver.find_element_by_id("kw").clear()        driver.find_element_by_id("kw").send_keys(u"开源优测")        driver.find_element_by_id("su").click()        sleep(3)                # 验证搜索结果标题        self.assertEqual(driver.title, u"开源优测_百度搜索")      
     def tearDown(self):        self.driver.quit()      
 
if __name__ == '__main__':    testunit = unittest.TestSuite()    testunit.addTest(BaiduTest('test_baidu_search'))        # 定义报告输出路径    htmlPath = u"testReport.html"    fp = file(htmlPath, "wb")        runner = HTMLTestRunner.HTMLTestRunner(stream=fp,           title=u"百度测试",           description=u"测试用例结果")        runner.run(testunit)        fp.close()

代码解释

总体上代码分为四大块

  1. 文件保存编码及作者定义

#-*- coding:utf-8 -*-
__author__ = u'苦叶子'
  1. 导入相关基础模块

# 从selenium中导入webdriver模块
from selenium import webdriver

# 导入unittest模块,作为用例基类
import unittest

# 导入html报告生成模块,用于html格式报告生成
import HTMLTestRunner  

# 导入sys模块
import sys

# 导入sleep模块,用于强制等待
from time import sleep
  1. 设置当前python运行环境为utf8

# 设置当前python运行在utf-8编码下,这样你的中文就不会乱码了

reload(sys) sys.setdefaultencoding("utf-8")
  1. 定义和实现测试用例

# 从unittest.TestCase继承

class BaiduTest(unittest.TestCase):    """百度首页搜索测试用例"""        # 用例级初始化函数,自动执行    def setUp(self):        # 初始化基于IE浏览器的webdriver实例        self.driver = webdriver.Ie()                # 给当前webdriver设置全局隐性等待时间,最大30s        self.driver.implicitly_wait(30)                # 设置首页url        self.base_url = u"http://www.baidu.com"            def test_baidu_search(self):        # 简单赋值,这样在本测试中后续就不用每次都写self.driver,        # 少写几个字符, 都是为了偷懒啊😄        driver = self.driver                # 在控制台打印输出        print u"开始[case_0001]百度搜索"                # 启动浏览器,并访问首页        driver.get(self.base_url)                # 验证标题        self.assertEqual(driver.title, u"百度一下,你就知道")                # 清理搜索输入框中的数据        driver.find_element_by_id("kw").clear()                # 在搜索输入框中输入 开源优测        driver.find_element_by_id("kw").send_keys(u"开源优测")                # 单击 百度一下  按钮        driver.find_element_by_id("su").click()                # 强制等3s        sleep(3)                # 验证搜索结果标题        self.assertEqual(driver.title, u"开源优测_百度搜索")    
   # 用例级清理函数,自动执行        def tearDown(self):        # 退出webdriver,同时关闭当前webdrier session下所有浏览器窗口        self.driver.quit()
  1. 测试脚本主运行入口

# python main函数
if
__name__ == '__main__':    
   # 初始化一个用例套件集
   testunit = unittest.TestSuite()        # 往用例套件集新增一个测试    testunit.addTest(BaiduTest('test_baidu_search'))            # 定义报告输出路径,这里是当前目录    htmlPath = u"testReport.html"        # 打开测试报告文件    fp = file(htmlPath, "wb")        # 构建一个HTMLTestReport执行器    runner = HTMLTestRunner.HTMLTestRunner(stream=fp,           title=u"百度测试",           description=u"测试用例结果")        # 运行测试集    runner.run(testunit)        # 关闭打开的测试报告文件    fp.close()

运行代码

使用以下命令运行上述代码

python first_webdriver.py

可以看到:

  1. 将启动浏览器访问百度首页

  2. 在百度首页搜索框中输入了 开源优测 单击了 百度一下 按钮 显示出搜索结果

  3. 闭关了浏览器

  4. 在当前目录下 生成了testReport.html的测试报告文件

总结

最后总结下,要注意的几个关键点:

  1. 确保要启动的浏览器的驱动已经下载好,具体在哪下载请参见上一章

  2. 确保下载了HTMLTestRunner模块

  3. 最好自己把代码一行行敲入一遍,不要直接拷贝运行


更多精彩

Python Selenium Webdriver安装手册

webdriver介绍&与Selenium RC的比较

python selenium2示例 - 生成 HTMLTestRunner 测试报告

python selenium2 架构说明

python selenium2示例 - Page Object Model

python selenium2示例 - 利用excel实现参数化

python selenium2 开发环境搭建

python selenium2源码分析概要

Hello,伙伴们长按二维码关注我们吧!

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存