selenium+python做web端自动化测试框架与实例详解教程_python web 自动化框架系统

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

        os.mkdir(os.path.dirname(os.getcwd()) + '/picture/')
    photo = self.driver.get_screenshot_as_file(project_dir +  '/picture/'
                                               + str(id) + str('_') + time.strftime("%Y-%m-%d-%H-%M-%S") + '.png')
    return photo
def __del__(self):
    time.sleep(2)
    self.driver.close()
    self.driver.quit()

  下面介绍下,config文件主要用于读取文件中的信息:



import os,xlrd
from common.logs import MyLog
from xml.etree import ElementTree as ElementTree
mylogger = MyLog.get_log()
project_dir = os.path.dirname(os.getcwd())

def user_Add():
‘’‘excel文件中读取用户登录信息’‘’
with xlrd.open_workbook(project_dir+‘/data/test_data.xlsx’) as files:
table_user = files.sheet_by_name(‘userdata’)
try:
username = str(int(table_user.cell(1,0).value))
except:
username = str(table_user.cell(1,0).value)
try:
passwd = str(int(table_user.cell(1,1).value))
except:
passwd = str(table_user.cell(1,1).value)
try:
check = str(int(table_user.cell(1, 2).value))
except Exception:
check = str(table_user.cell(1, 2).value)
table_url = files.sheet_by_name(‘base_url’)
base_url = str(table_url.cell(1,0).value)
return (username,passwd,base_url,check)

#从xml文件中读取信息,定义全局一个字典来存取xml读出的信息
database={}
def set_read_xml():
sql_path = os.path.join(project_dir,‘data’,‘SQL.xml’)
data =ElementTree.parse(sql_path)
for db in data.findall(‘database’):
name = db.get(‘name’)
table = {}
for tb in db.getchildren():
table_name = tb.get(“name”)
sql = {}
for data in tb.getchildren():
sql_id = data.get(“id”)
sql[sql_id] = data.text
table[table_name] = sql
database[name] = table
mylogger.info(“读取的xml文件的信息%s” %database)
def get_sql_sen(database_name,table_name,sql_id):
set_read_xml()
db = database.get(database_name).get(table_name)
if db.get(sql_id):
sql = db.get(sql_id).strip()
mylogger.info(“返回sql语句信息%s” % sql)
return sql
else:
mylogger.info(“查下的信息为空,传递的参数有误!数据库名称:【%s】,表信息【%s】,查询的id【%s】”
%(database_name,table_name,sql_id))


 接着介绍最简单的日志logs.py模块:



logging模块支持我们自定义封装一个新日志类

import logging,time
import os.path
class Logger(object):
def init(self, logger,cases=“./”):
self.logger = logging.getLogger(logger)
self.logger.setLevel(logging.DEBUG)
self.cases = cases
# 创建一个handler,用于写入日志文件
for filename in os.listdir(os.path.dirname(os.getcwd())):
if filename == “logs”:
break
else:
os.mkdir(os.path.dirname(os.getcwd())+‘/logs’)
rq = time.strftime(‘%Y%m%d%H%M’, time.localtime(time.time()))
log_path = os.path.dirname(os.getcwd()) + ‘/logs/’
log_name = log_path + rq + ‘.log’ # 文件名
# 将日志写入磁盘
fh = logging.FileHandler(log_name)
fh.setLevel(logging.INFO)
# 创建一个handler,用于输出到控制台
ch = logging.StreamHandler()
ch.setLevel(logging.INFO)
# 定义handler的输出格式
formatter = logging.Formatter(‘%(asctime)s - %(name)s - %(levelname)s - %(message)s’)
fh.setFormatter(formatter)
ch.setFormatter(formatter)
# 给logger添加handler
self.logger.addHandler(fh)
self.logger.addHandler(ch)
def getlog(self):
return self.logger


 common模块最后一个是test\_runner.py这个方法主要是用来执行全部的测试用例



import time,HTMLTestRunner
import unittest
from common.config import *
project_dir = os.path.abspath(os.path.join(os.path.dirname(file),os.pardir))
class TestRunner(object):
‘’’ 执行测试用例 ‘’’
def init(self, cases=“…/”,title=“Auto Test Report”,description=“Test case execution”):
self.cases = cases
self.title = title
self.des = description
def run(self):
for filename in os.listdir(project_dir):
if filename == “report”:
break
else:
os.mkdir(project_dir+‘/report’)
# fp = open(project_dir+“/report/” + “report.html”, ‘wb’)
now = time.strftime(“%Y-%m-%d_%H_%M_%S”)
# fp = open(project_dir+“/report/”+“result.html”, ‘wb’)
fp = open(project_dir+“/report/”+ now +“result.html”, ‘wb’)
tests = unittest.defaultTestLoader.discover(self.cases,pattern=‘test*.py’,top_level_dir=None)
runner = HTMLTestRunner.HTMLTestRunner(stream=fp, title=self.title, description=self.des)
runner.run(tests)
fp.close()


以上就是common公共模块所有的模块,简单说下在写这些公共模块时,出现了各种问题,特别是读取xml文件的,唉!对于一个python的小白真是心酸啊!接着说下db模块的内容,db模块主要是读取sql语句以及返回对应的值!



import pymysql
import readconf
import common.config as conf
readconf_conf = readconf.Read_conf()

host = readconf_conf.get_db(“host”)
username = readconf_conf.get_db(“username”)
password = readconf_conf.get_db(“password”)
port = readconf_conf.get_db(“port”)
database = readconf_conf.get_db(“database”)
config_db = {
‘host’: str(host),
‘user’: username,
‘password’: password,
‘port’: int(port),
‘db’: database
}
class Mysql_DB():
def init(self):
‘’‘初始化数据库’‘’
self.db = None
self.cursor = None
def connect_db(self):
‘’‘创建连接数据库’‘’
try:
self.db = pymysql.connect(**config_db)
#创建游标位置
self.cursor = self.db.cursor()
# print(“链接数据库成功”)
conf.mylogger.info(“链接IP为%s的%s数据库成功” %(host,database))
except ConnectionError as ex:
conf.mylogger.error(ex)

def get_sql_result(self,sql,params,state):
    self.connect_db()
    try:
        self.cursor.execute(sql, params)
        self.db.commit()
        # return self.cursor
    except ConnectionError as ex:
        self.db.rollback()
    if state==0:
        return self.cursor.fetchone()
    else:
        return self.cursor.fetchall()
def close_db(self):
    print("关闭数据库")
    conf.mylogger.info("关闭数据库")
    self.db.close()

 刚开始写db模块是一直对字典模块的信息怎样传递到数据链接的模块,进过网上查询好些资料才彻底解决,对自己来说也是一种进步,哈哈,下面说下自己踩的坑,帮助自己以后学习\*\*config\_db把字典变成关键字参数传递,下面举例说明下:如果kwargs={'a':1,'b':2,'c':3}那么\*\*kwargs这个等价为test(a=1,b=2,c=3)是不是很简单!哈哈 以上就是框架的主要模块,其他的模块每个项目与每个系统都不一样,在这里就是列举出来了,因为就算写出来大家也不能复用,下面就给大家看看小白还有哪些模块


![](https://img-blog.csdnimg.cn/img_convert/a952e90190b4a3571cb0691cc401b6cf.png)


看下了下data模块下的xml模块大家可能用的到,就给大家贴出来吧!因为ui测试主要就用到select与delete语句,所以也没有写多么复杂的sql语句



<?xml version="1.0" encoding="utf-8" ?> select * from user where real_name=%s select mobile from user where mobile=%s delete from user where mobile=%s insert into user(id) value(%s) uodate user set real_name = %s where uuid=%s

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值