Selenium+Python做web端自动化测试框架与实例详解教程,一线互联网架构师360°全方面性能调优

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新软件测试全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

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

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

如果你需要这些资料,可以添加V获取:vip1024b (备注软件测试)
img

正文

[DATABASE]
host = 127.0.0.1
username = root
password = root
port = 3306
database = cai_test

[HTTP]

接口的url

baseurl = http://xx.xxxx.xx
port = 8080
timeout = 1.0
readconf.py文件主要用于读取conf.ini中的数据信息

*coding:utf-8 *

author = “Test Lu”
import os,codecs
import configparser
prodir = os.path.dirname(os.path.abspath(file))
conf_prodir = os.path.join(prodir,‘conf.ini’)
class Read_conf():
def init(self):
with open(conf_prodir) as fd:
data = fd.read()
#清空文件信息
if data[:3] ==codecs.BOM_UTF8:
data = data[3:]
file = codecs.open(conf_prodir,‘w’)
file.write(data)
file.close()
self.cf = configparser.ConfigParser()
self.cf.read(conf_prodir)
def get_http(self,name):
value = self.cf.get(“HTTP”,name)
return value

def get_db(self,name):
return self.cf.get(“DATABASE”,name)

这里需要注意,python3.0以上版本与python2.7版本import configparser的方法有一些区别
读取一些配置文集就介绍完了,下面就说说common包下的公共文件

现在就从上往下结束吧!common主要是封装的一些定位元素的方法:

*coding:utf-8 *

author = “Test Lu”
from selenium import webdriver
import time,os
import common.config

from common.logs import MyLog

project_dir = os.path.dirname(os.path.dirname(os.path.abspath(file)))
class Comm(object):
def init(self,driver):
self.driver = driver

self.driver = webdriver.Firefox()

self.driver = webdriver.Chrome()
self.driver.maximize_window()
def open_url(self,url):
self.driver.get(url)
self.driver.implicitly_wait(30)

selenium 定位方法

def locate_element(self,loatetype,value):
if (loatetype == ‘id’):
el = self.driver.find_element_by_id(value)
if (loatetype == ‘name’):
el = self.driver.find_element_by_name(value)
if (loatetype == ‘class_name’):
el = self.driver.find_element_by_class_name(value)
if (loatetype == ‘tag_name’):
el = self.driver.find_elements_by_tag_name(value)
if (loatetype == ‘link’):
el = self.driver.find_element_by_link_text(value)
if (loatetype == ‘css’):
el = self.driver.find_element_by_css_selector(value)
if (loatetype == ‘partial_link’):
el = self.driver.find_element_by_partial_link_text(value)
if (loatetype == ‘xpath’):
el = self.driver.find_element_by_xpath(value)
return el if el else None

selenium 点击

def click(self,loatetype,value):
self.locate_element(loatetype,value).click()
#selenium 输入
def input_data(self,loatetype,value,data):
self.locate_element(loatetype,value).send_keys(data)
#获取定位到的指定元素
def get_text(self, loatetype, value):
return self.locate_element(loatetype, value).text

获取标签属性

def get_attr(self, loatetype, value, attr):
return self.locate_element(loatetype, value).get_attribute(attr)

页面截图

def sc_shot(self,id):
for filename in os.listdir(os.path.dirname(os.getcwd())) :
if filename == ‘picture’:
break
else:
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

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

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
img

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

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

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
[外链图片转存中…(img-4JeXFUBg-1713158776231)]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值