Python分类测试代码实例汇总
时间:2022-07-27
本文章向大家介绍Python分类测试代码实例汇总,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
1.自动化测试里面的测试用例设计的一些方法
解耦、可以独立运行、需要灵活切换
设计思路: 脚本功能分析(分步骤)和模块化分层(拆分为多模块)
project
login_order.py #登录下单测试用例 category.py #菜单分类测试用例 all_test.py #主入口
login_order.py
# -*- coding: UTF-8 -*-
import unittest
import time
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.action_chains import ActionChains
class LoginOrderTestCase(unittest.TestCase):
def setUp(self):
print("测试开始")
self.driver = webdriver.Firefox()
self.driver.implicitly_wait(20)
self.base_url = "https://xdclass.net"
self.driver.get(self.base_url)
def tearDown(self):
print("单个测试用例结束")
pass
#单个测试用例结束
def test_login_order(self):
u"登录测试用例"
driver = self.driver
#登录框
login_ele = driver.find_element_by_css_selector("#login")
ActionChains(driver).click(login_ele).perform()
sleep(2)
#查找输入框,输入账号,输入框要提前清理里面的数据
driver.find_element_by_id("phone").clear()
driver.find_element_by_id("phone").send_keys("13113777338")
#查找密码输入框,输入密码
driver.find_element_by_id("pwd").clear()
driver.find_element_by_id("pwd").send_keys("123456789")
#拿到登录按钮
login_btn_ele = driver.find_element_by_css_selector("button.login")
#触发点击事件,登录
login_btn_ele.click()
#判断登陆是否成功,逻辑-》鼠标移到上面,判断弹窗字符
#获取鼠标上移的元素
user_info_ele = driver.find_element_by_css_selector(".user_head_portrait")
sleep(1)
#hover触发
ActionChains(driver).move_to_element(user_info_ele).perform()
sleep(1)
#获取用户名称元素
user_name_ele = driver.find_element_by_css_selector(".img_name span:nth-child(2)")
print("===测试结果==")
print(user_name_ele.text)
name = user_name_ele.text
#self.assertEqual(name, u"二当家小D",msg="登录失败")
video_ele = driver.find_element_by_css_selector("div.hotcourses:nth-child(3) div:nth-child(2) div:nth-child(1) ul:nth-child(1) li:nth-child(1) a:nth-child(1) div:nth-child(1) img:nth-child(1)")
video_ele.click()
sleep(2)
buy_btn_ele = driver.find_element_by_css_selector(".learn_btn a:nth-child(1)")
buy_btn_ele.click()
print("进入下单页面")
if __name__ == '__main__':
unittest.main()
category.py
# -*- coding: UTF-8 -*-
import unittest
import time
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.action_chains import ActionChains
class CategoryTestCase(unittest.TestCase):
def setUp(self):
print("测试开始")
self.driver = webdriver.Firefox()
self.driver.implicitly_wait(20)
self.base_url = "https://xdclass.net"
self.driver.get(self.base_url)
def tearDown(self):
print("测试结束")
#单个测试用例结束
self.driver.quit()
def test_menu(self):
u"弹出菜单测试用例"
driver = self.driver
#跳转网页
sleep(1)
#定位到鼠标移动到上面的元素
menu_ele = driver.find_element_by_css_selector("#banner_left_ul a:nth-child(1) li:nth-child(1) span:nth-child(1)")
#对定位到的元素执行鼠标移动到上面的操作
ActionChains(driver).move_to_element(menu_ele).perform()
sleep(2)
#选中子菜单
sub_meun_ele = driver.find_element_by_css_selector("#des li:nth-child(1) div:nth-child(1) div:nth-child(1) div:nth-child(2) a:nth-child(1)")
sub_meun_ele.click()
sleep(2)
if __name__ == '__main__':
unittest.main()
all_test.py
# -*- coding: UTF-8 -*-
import unittest
import HTMLTestRunner
import login_order ,category
import time
#创建测试集合
def create_suite():
print("测试开始")
suite = unittest.TestSuite()
suite.addTest(unittest.makeSuite(login_order.LoginOrderTestCase))
suite.addTest(unittest.makeSuite(category.CategoryTestCase))
return suite
if __name__ == '__main__':
suite = create_suite()
#文件名中加了当前时间,为了每次生成不同的测试报告
file_prefix = time.strftime("%Y-%m-%d %H_%M_%S", time.localtime())
#创建测试报告,此时这个文件还是空文件 wb 以二进制格式打开一个文件,只用于写入,如果文件存在则覆盖,不存在则创建
fp = open("./"+file_prefix+"_result.html","wb")
# stream定义一个测试报告写入的文件,title就是标题,description就是描述
runner = HTMLTestRunner.HTMLTestRunner(stream=fp, title=u"小D课堂 测试报告",description=u"测试用例执行情况",verbosity=2)
runner.run(suite)
fp.close()
- 采用HTML5之"data-"机制自由提供数据
- Spring和SpringMVC父子的容器之道---[上篇]
- 快速完成(图片旋转,查看原图)
- Jsp中格式化时间戳的常用标签
- 反射+自定义注解---实现Excel数据列属性和JavaBean属性的自动映射
- 后台模板管理系统___左侧菜单数据的异步加载
- Shiro眼皮下玩ajax,玩出302 Found
- 对于JSONObject,我只是临时抱佛脚
- 总结切面编程AOP的注解式开发和XML式开发
- SpringMVC注解@RequestMapping之produces属性导致的406错误
- SpringBoot集成MyBatis的分页插件PageHelper(回头草)
- SpringBoot整合Mybatis之进门篇
- Tomcat和Java Virtual Machine的性能调优总结
- 一次浴火重生的MySQL优化(EXPLAIN命令详解)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法