简单的自动化测试模型(python+selenium)

         刚接触自动化测试,由于没有编程语言的基础,是搞不懂代码里面的函数、封装、包以及其他概念,只是了解字符串、数组、元组及字典这种最基本的名词,更不懂自动化测试框架了。

         在我这种外门汉的角度来看,代码不就是一页word文件写进去,从头执行到尾吗?其实不然,代码可不止一页word,很多页啊。

        看着虫师的书籍学习自动化测试,边看边敲还是会忘记,想想还是做做笔记比较合宜。这篇笔记来粗略记下学习自动化测试的几种模型,可能再之后回来看会有特别的感受,先这样记着吧。

1、线性测试

线性测试,顾名思义,就是一条路按照一条直线走到底。它的每个脚本都是独立的,都可以拿出来单独运行,来验证一个功能点,上两段小代码举个栗子:

打开百度主页:

# coding:utf-8
from time import sleep  # 从time中引入sleep from selenium import webdriver # 从selenium中引入webdriver  driver = webdriver.Firefox() # 选择打开的浏览器 driver.maximize_window() # 浏览器窗口最大化 driver.implicitly_wait(3) # 隐式等待 driver.get("https://www.baidu.com") # 获取URL,打开页面  driver.quit() # 退出相关浏览器

打开百度主页,并输入查找内容:

# coding:utf-8
from time import sleep  # 从time中引入sleep from selenium import webdriver # 从selenium中引入webdriver  driver = webdriver.Firefox() # 选择打开的浏览器 driver.maximize_window() # 浏览器窗口最大化 driver.implicitly_wait(3) # 隐式等待 driver.get("https://www.baidu.com") # 获取URL,打开页面  search = driver.find_element_by_id("kw") # 通过id定位搜索框 search.send_keys("selenium") # 填入"selenium" sleep(5) # 直接等待  driver.quit() # 退出相关浏览器

 以上两段代码,分别做了实现打开百度首页和打开百度首页后输入查找内容的功能,都可以单独拿出来执行。如果需要修改查找访问页面,那么我需要两段代码都需要修改。当这类独立的脚本数量多了起来,去修改这些内容花费的工作量太大,将会失去了自动化的目的。

2、模块化与类库

login.py

# coding:utf-8
from time import sleep from selenium import webdriver # 从selenium中引入webdriver def login_mantis(): driver = webdriver.Firefox() # 选择打开的浏览器 driver.maximize_window() # 浏览器窗口最大化 driver.implicitly_wait(3) # 隐式等待 driver.get("http://192.168.1.201/mantisbt-1.2.19/login_page.php") # 获取URL,打开页面 sleep(1) # 直接等待 username = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[2]/td[2]/input") # 通过Xpath定位获取输入账号框 username.send_keys("wuhaobo") # 输入账号 sleep(1) password = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[3]/td[2]/input") # 通过Xpath定位获取输入密码框 password.send_keys("123456") # 输入密码 sleep(1) login = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[6]/td/input") # 通过Xpath定位获取登录按钮 login.click() # 点击登录按钮 sleep(3)

上面的代码实现了mantis登录功能。

quit.py

# coding:utf-8
from selenium import webdriver  # 从selenium中引入webdriver def quit_mantis(): driver = webdriver.Firefox() # 选择打开的浏览器 driver.quit() # 退出相关浏览器

上面的代码实现了mantis退出功能。

do_something_in_mantis.py

# coding:utf-8
from time import sleep  # 从time中引入sleep from selenium import webdriver # 从selenium中引入webdriver import login # 引入登录模块 import quit # 引入退出模块  login.login_mantis() # 调用登录模块 print ">>>以下操作为在登录界面后的操作" # 需要做的操作放在登录和退出中间 print ">>>以上操作为在登录界面后的操作" quit.quit_mantis() # 调用退出模块

上面的代码实现了调用登录模块和退出模块。

通过以上代码可以发现,登录模块和退出模块可以让任意操作类脚本调用,省去了该部分代码的重复量,便于维护的同时,也加快了代码的开发速度。

3、数据驱动

直接理解成参数化输入,不同结果输出。

(1)、读取TXT方式

将存好登录的账号密码放置在两个TXT文件中:

 

# coding:utf-8
from time import sleep
from selenium import webdriver # 从selenium中引入webdriver  username_file = open("G:\\joker_study\\username.txt") # 打开账号文本路径 username = username_file.read() # 取出账号  password_file = open("G:\\joker_study\\password.txt") # 打开密码文本路径 password = password_file.read() # 取出密码def login_mantis_by_txt(): driver = webdriver.Firefox() # 选择打开的浏览器 driver.maximize_window() # 浏览器窗口最大化 driver.implicitly_wait(3) # 隐式等待 driver.get("http://192.168.1.201/mantisbt-1.2.19/login_page.php") # 获取URL,打开页面 sleep(1) # 直接等待 username_input = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[2]/td[2]/input") # 获取输入账号框 username_input.send_keys(username) # 输入账号 sleep(1) password_input = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[3]/td[2]/input") # 获取输入密码框 password_input.send_keys(password) # 输入密码 sleep(1) login_button = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[6]/td/input") # 获取登录按钮 login_button.click() # 点击登录按钮 sleep(3) driver.quit() # 退出浏览器

上面的代码实现了从TXT文件中读出账号和密码,再传入函数中,进行登录操作。

(2)、通过函数

userconfig.py

# coding:utf-8
def username_password(username="CJOLER",password="123456"): return username,password

login.py

# coding:utf-8
from time import sleep
from selenium import webdriver # 从selenium中引入webdriver import userconfig # 引入userconfig文件  un, pw = userconfig.username_password() print un, pw def login_mantis_by_txt(): driver = webdriver.Firefox() # 选择打开的浏览器 driver.maximize_window() # 浏览器窗口最大化 driver.implicitly_wait(3) # 隐式等待 driver.get("http://192.168.1.201/mantisbt-1.2.19/login_page.php") # 获取URL,打开页面 sleep(1) # 直接等待 username_input = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[2]/td[2]/input") # 获取输入账号框 username_input.send_keys(un) # 输入账号 sleep(1) password_input = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[3]/td[2]/input") # 获取输入密码框 password_input.send_keys(pw) # 输入密码 sleep(1) login_button = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[6]/td/input") # 获取登录按钮 login_button.click() # 点击登录按钮 sleep(3) driver.quit() # 退出浏览器

上面的代码实现了将账号密码放在一个函数内,再去调用,进行登录操作。

(3)、读取字典

 userconfig.py

# coding:utf-8
def username_password():
    config = {"username": "CJOKER", "password": "123456"} return config

login.py

# coding:utf-8
from time import sleep
from selenium import webdriver # 从selenium中引入webdriver import userconfig # 引入userconfig文件  Data = userconfig.username_password() un = Data["username"] pw = Data["password"] def login_mantis_by_txt(): driver = webdriver.Firefox() # 选择打开的浏览器 driver.maximize_window() # 浏览器窗口最大化 driver.implicitly_wait(3) # 隐式等待 driver.get("http://192.168.1.201/mantisbt-1.2.19/login_page.php") # 获取URL,打开页面 sleep(1) # 直接等待 username_input = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[2]/td[2]/input") # 获取输入账号框 username_input.send_keys(un) # 输入账号 sleep(1) password_input = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[3]/td[2]/input") # 获取输入密码框 password_input.send_keys(pw) # 输入密码 sleep(1) login_button = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[6]/td/input") # 获取登录按钮 login_button.click() # 点击登录按钮 sleep(3) driver.quit() # 退出浏览器

上面的代码实现了将账号密码放在一个字典内,再去调用,进行登录操作。

(4)、csv文件

# coding:utf-8
import os  # 引入os模块
import csv # 引入csv包 from time import sleep # 引入sleep方法 from selenium import webdriver # 从selenium中引入webdriver  list_username = [] list_password = [] data = csv.reader(file('G:\\joker_study\\userconfig.csv', 'rb')) # 获取每列数据 for user in data: print user[0] # 获取第一列中从上往下的数据 list_username.append(user[0]) # 将每次读取的字符串加入到数组中 print user[1] # 获取第二列中从上往下的数据 list_password.append(user[1]) # 将每次读取的字符串加入到数组中 def login_mantis_by_csv(): for i in range(len(list_username)): driver = webdriver.Firefox() # 选择打开的浏览器 driver.maximize_window() # 浏览器窗口最大化 driver.implicitly_wait(3) # 隐式等待 driver.get("http://192.168.1.201/mantisbt-1.2.19/login_page.php") # 获取URL,打开页面 sleep(1) # 直接等待 username_input = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[2]/td[2]/input") # 获取输入账号框 username_input.send_keys(str(list_username[i])) # 输入账号 sleep(1) password_input = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[3]/td[2]/input") # 获取输入密码框 password_input.send_keys(str(list_password)) # 输入密码 sleep(1) login_button = driver.find_element_by_xpath("html/body/div[3]/form/table/tbody/tr[6]/td/input") # 获取登录按钮 login_button.click() # 点击登录按钮 sleep(3) driver.quit() # 退出浏览器

 上 面的代码实现了将账号密码分别存在一个CSV表格中,通过csv.reader将每列都读取出来,user[0]第一列,user[1]第二列,一次类 推。需要注意的是,要讲CSV文件打开的格式和工具格式保持一致:在简体中文环境下,EXCEL打开的CSV文件默认是ANSI编码,如果CSV文件的编 码方式为utf-8、Unicode等编码可能就会出现文件乱码的情况。

4、关键字驱动

 采用EXCEL或者QTP及robot framework等工具大部分都是以关键字驱动来实现自动化测试,这种方式由于只需要关注"我要做什么(命令)?对谁做(对象)?怎么做(值)?",目前还没有去采用这种方式去写作脚本,等学习了robot framework或者用到这种方式的时候,再记录补充下吧。

例如这种EXCEL表格(网上随意复制过来)中所示:

转载于:https://www.cnblogs.com/CJOKER/p/8289510.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值