国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

?selenium+python做web端自動(dòng)化測試框架與實(shí)例詳解教程

這篇具有很好參考價(jià)值的文章主要介紹了?selenium+python做web端自動(dòng)化測試框架與實(shí)例詳解教程。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

最近受到萬點(diǎn)暴擊,由于公司業(yè)務(wù)出現(xiàn)問題,工作任務(wù)沒那么繁重,有時(shí)間摸索selenium+python自動(dòng)化測試,結(jié)合網(wǎng)上查到的資料自己編寫出適合web自動(dòng)化測試的框架,由于本人也是剛剛開始學(xué)習(xí)python,這套自動(dòng)化框架目前已經(jīng)基本完成了所以總結(jié)下編寫的得失,便于以后回顧溫習(xí),有許多不足的的地方,也遇到了各種奇葩問題,希望大神們多多指教。

首先我們要了解什么是自動(dòng)化測試,簡單的說編寫代碼、腳本,讓軟件自動(dòng)運(yùn)行,發(fā)現(xiàn)缺陷,代替部分的手工測試。了解了自動(dòng)化測試后,我們要清楚一個(gè)框架需要分那些模塊:
?

?selenium+python做web端自動(dòng)化測試框架與實(shí)例詳解教程

?

上圖的框架適合大多數(shù)的自動(dòng)化測試,比如web UI ?、接口自動(dòng)化測試都可以采用,如大佬有好的方法請多多指教,簡單說明下每個(gè)模塊:

  • common:存放一些共通的方法
  • data:存放一些文件信息
  • logs:存放程序中寫入的日志信息
  • picture:存放程序中截圖文件信息
  • report:存放測試報(bào)告
  • test_case:存放編寫具體的測試用例
  • conf.ini、readconf.py:存放編寫的配置信息
    ?

下面就具體介紹每個(gè)模塊的內(nèi)容:conf.ini主要存放一些不會(huì)輕易改變的信息,編寫的代碼如下:

[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中的數(shù)據(jù)信息
# *_*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的方法有一些區(qū)別讀取一些配置文集就介紹完了,下面就說說common包下的公共文件

?selenium+python做web端自動(dòng)化測試框架與實(shí)例詳解教程

?

現(xiàn)在就從上往下結(jié)束吧!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 點(diǎn)擊
    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
    # 獲取標(biāo)簽屬性
    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文件中讀取信息,定義全局一個(gè)字典來存取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("查下的信息為空,傳遞的參數(shù)有誤!數(shù)據(jù)庫名稱:【%s】,表信息【%s】,查詢的id【%s】"
                      %(database_name,table_name,sql_id))

接著介紹最簡單的日志logs.py模塊:

# logging模塊支持我們自定義封裝一個(gè)新日志類
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
        # 創(chuàng)建一個(gè)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)
        # 創(chuàng)建一個(gè)handler,用于輸出到控制臺(tái)
        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模塊最后一個(gè)是test_runner.py這個(gè)方法主要是用來執(zhí)行全部的測試用例

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):
    ''' 執(zhí)行測試用例 '''
    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公共模塊所有的模塊,簡單說下在寫這些公共模塊時(shí),出現(xiàn)了各種問題,特別是讀取xml文件的,唉!對(duì)于一個(gè)python的小白真是心酸?。〗又f下db模塊的內(nèi)容,db模塊主要是讀取sql語句以及返回對(duì)應(yīng)的值!

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):
        '''初始化數(shù)據(jù)庫'''
        self.db = None
        self.cursor = None
    def connect_db(self):
        '''創(chuàng)建連接數(shù)據(jù)庫'''
        try:
            self.db = pymysql.connect(**config_db)
            #創(chuàng)建游標(biāo)位置
            self.cursor = self.db.cursor()
            # print("鏈接數(shù)據(jù)庫成功")
            conf.mylogger.info("鏈接IP為%s的%s數(shù)據(jù)庫成功" %(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("關(guān)閉數(shù)據(jù)庫")
        conf.mylogger.info("關(guān)閉數(shù)據(jù)庫")
        self.db.close()

?剛開始寫db模塊是一直對(duì)字典模塊的信息怎樣傳遞到數(shù)據(jù)鏈接的模塊,進(jìn)過網(wǎng)上查詢好些資料才徹底解決,對(duì)自己來說也是一種進(jìn)步,哈哈,下面說下自己踩的坑,幫助自己以后學(xué)習(xí)**config_db把字典變成關(guān)鍵字參數(shù)傳遞,下面舉例說明下:如果kwargs={'a':1,'b':2,'c':3}那么**kwargs這個(gè)等價(jià)為test(a=1,b=2,c=3)是不是很簡單!哈哈 以上就是框架的主要模塊,其他的模塊每個(gè)項(xiàng)目與每個(gè)系統(tǒng)都不一樣,在這里就是列舉出來了,因?yàn)榫退銓懗鰜泶蠹乙膊荒軓?fù)用,下面就給大家看看小白還有哪些模塊

?selenium+python做web端自動(dòng)化測試框架與實(shí)例詳解教程

?

看下了下data模塊下的xml模塊大家可能用的到,就給大家貼出來吧!因?yàn)閡i測試主要就用到select與delete語句,所以也沒有寫多么復(fù)雜的sql語句

<?xml version="1.0" encoding="utf-8" ?>
<data>
    <database name="database_member">
        <table name="table_member">
            <sql id="select_member">
                select * from user where real_name=%s
            </sql>
            <sql id="select_member_one">
                select mobile from user where mobile=%s
            </sql>
            <sql id="delete_member">
                delete from user where mobile=%s
            </sql>
            <sql id="insert_member">
                insert into user(id) value(%s)
            </sql>
            <sql id="update_member">
                uodate user set real_name = %s where uuid=%s
            </sql>
        </table>
    </database>
</data>

?下面介紹下其他模塊的內(nèi)容:test_data.xlsx文件主要是存放一些用戶信息,以及url信息,這樣修改用戶信息與url信息就不要修改代碼方便以后操作!logs是在代碼運(yùn)行時(shí)候產(chǎn)生的日志信息,picture是存放圖片信息,report存放輸入的報(bào)告信息, test_case是編寫用戶的模塊需要所有的用例名稱都要以test開頭來命名哦,這是因?yàn)閡nittest在進(jìn)行測試時(shí)會(huì)自動(dòng)匹配test_case文件夾下面所有test開頭的.py文件

?selenium+python做web端自動(dòng)化測試框架與實(shí)例詳解教程文章來源地址http://www.zghlxwxcb.cn/news/detail-495822.html

到了這里,關(guān)于?selenium+python做web端自動(dòng)化測試框架與實(shí)例詳解教程的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • Python+Selenium.webdriver實(shí)現(xiàn)WEB端UI自動(dòng)化測試(實(shí)例腳本)

    Python+Selenium.webdriver實(shí)現(xiàn)WEB端UI自動(dòng)化測試(實(shí)例腳本)

    ????????本篇記錄基于Python+Selenium.webdriver實(shí)現(xiàn)WEB端UI自動(dòng)化測試,其中測試用例使用excel維護(hù)。為了在實(shí)際項(xiàng)目種的擴(kuò)展應(yīng)用,建議學(xué)習(xí)webdriver的元素定位方法,歡迎在評(píng)論區(qū)溝通討論。 該示例選取的是登錄頁不需要輸入驗(yàn)證碼校驗(yàn)的基礎(chǔ)頁面(考慮到現(xiàn)在大部分項(xiàng)目都是

    2023年04月08日
    瀏覽(34)
  • Selenium基于Python web自動(dòng)化測試框架 -- PO

    Selenium基于Python web自動(dòng)化測試框架 -- PO

    ??? 交流討論: 歡迎加入我們一起學(xué)習(xí)! ?? 資源分享 : 耗時(shí)200+小時(shí)精選的「軟件測試」資料包 ??? 教程推薦: 火遍全網(wǎng)的《軟件測試》教程?? ?? 歡迎點(diǎn)贊 ?? 收藏 ?留言 ?? 如有錯(cuò)誤敬請指正! 關(guān)于selenium測試框架首先想到的就是PO模型,簡單說下PO模型 PO模型的

    2024年02月22日
    瀏覽(26)
  • selenium+python做web端自動(dòng)化測試框架實(shí)戰(zhàn)

    selenium+python做web端自動(dòng)化測試框架實(shí)戰(zhàn)

    最近受到萬點(diǎn)暴擊,由于公司業(yè)務(wù)出現(xiàn)問題,工作任務(wù)沒那么繁重,有時(shí)間摸索selenium+python自動(dòng)化測試,結(jié)合網(wǎng)上查到的資料自己編寫出適合web自動(dòng)化測試的框架,由于本人也是剛剛開始學(xué)習(xí)python,這套自動(dòng)化框架目前已經(jīng)基本完成了所以總結(jié)下編寫的得失,便于以后回顧溫

    2024年02月14日
    瀏覽(26)
  • 基于Selenium+Python的web自動(dòng)化測試框架詳解

    目錄 一、什么是Selenium? 二、自動(dòng)化測試框架 三、自動(dòng)化框架的設(shè)計(jì)和實(shí)現(xiàn) 四、需要改進(jìn)的模塊 五、總結(jié) Selenium是一個(gè)基于瀏覽器的自動(dòng)化測試工具,它提供了一種跨平臺(tái)、跨瀏覽器的端到端的web自動(dòng)化解決方案。Selenium主要包括三部分:Selenium IDE、Selenium WebDriver 和Selen

    2024年02月09日
    瀏覽(28)
  • 基于Selenium+Python的web自動(dòng)化測試框架_pythonselenium框架

    基于Selenium+Python的web自動(dòng)化測試框架_pythonselenium框架

    主要負(fù)責(zé)執(zhí)行用例后的生成報(bào)告,一般以HTML格式居多,信息主要是用例執(zhí)行情況。另外還可以配置發(fā)送郵件功能。 4、log模塊 主要用來記錄用例執(zhí)行情況,以便于高效的調(diào)查用例失敗信息以及追蹤用例執(zhí)行情況。 三、自動(dòng)化框架的設(shè)計(jì)和實(shí)現(xiàn) 1、需求分析 首先我們的測試對(duì)

    2024年04月17日
    瀏覽(32)
  • Python + Selenium,分分鐘搭建 Web 自動(dòng)化測試框架!

    Python + Selenium,分分鐘搭建 Web 自動(dòng)化測試框架!

    在程序員的世界中,一切重復(fù)性的工作,都應(yīng)該通過程序自動(dòng)執(zhí)行。 「自動(dòng)化測試」就是一個(gè)最好的例子。 隨著互聯(lián)網(wǎng)應(yīng)用開發(fā)周期越來越短,迭代速度越來越快,只會(huì)點(diǎn)點(diǎn)點(diǎn),不懂開發(fā)的手工測試,已經(jīng)無法滿足如今的業(yè)務(wù)要求,只能被企業(yè)逐步裁員淘汰。 「自動(dòng)化測試

    2024年02月02日
    瀏覽(29)
  • web自動(dòng)化測試框架落地實(shí)施全過程-測試環(huán)境搭建 (Selenium+Python)

    web自動(dòng)化測試框架落地實(shí)施全過程-測試環(huán)境搭建 (Selenium+Python)

    Web自動(dòng)化測試是指使用自動(dòng)化工具模擬用戶在Web瀏覽器中執(zhí)行的操作,通過編寫腳本來自動(dòng)化執(zhí)行測試用例,以驗(yàn)證Web應(yīng)用程序的功能、性能和兼容性等方面的質(zhì)量。其主要目的是降低測試成本和時(shí)間,并提高測試效率和準(zhǔn)確性。 Web自動(dòng)化測試通常包括以下步驟: 確定測試

    2024年02月09日
    瀏覽(20)
  • Python+Selenium+Pytest+Allure自動(dòng)化測試框架實(shí)戰(zhàn)實(shí)例(示例為我司網(wǎng)盤產(chǎn)品)

    Python+Selenium+Pytest+Allure自動(dòng)化測試框架實(shí)戰(zhàn)實(shí)例(示例為我司網(wǎng)盤產(chǎn)品)

    應(yīng)公司要求,組織員工培訓(xùn)自動(dòng)化測試,所以也趁此機(jī)會(huì)把我所學(xué)習(xí)的自動(dòng)化框架整理一下,雖說不是很完美,但也有所收獲。 序號(hào) 庫、插件、工具 版本號(hào) 1 Python 3.11 2 Pycharm 22.2.3 3 pytest 7.2.0 4 pywin32 305 5 selenium3 4.6.0 6 openpyxl 3.0.10 7 Chromedriver 與當(dāng)前瀏覽器版本對(duì)應(yīng)即可 8 al

    2023年04月16日
    瀏覽(437)
  • Selenium Web自動(dòng)化測試框架實(shí)踐

    Selenium Web自動(dòng)化測試框架實(shí)踐

    目錄 ? ? ? ?前言: 項(xiàng)目背景 功能實(shí)現(xiàn) 項(xiàng)目架構(gòu) 瀏覽器driver定義 用例運(yùn)行前后的環(huán)境準(zhǔn)備工作 工具方法模塊 Pageobject頁面對(duì)象封裝 執(zhí)行測試用例 ? ? ? ?前言: ? ? ? ? ?Selenium是一個(gè)基于Web的自動(dòng)化測試框架,可以通過模擬用戶在瀏覽器上的操作,來自動(dòng)化地測試Web應(yīng)

    2024年02月10日
    瀏覽(27)
  • WEB自動(dòng)化測試(selenium工具)框架、面試題

    WEB自動(dòng)化測試(selenium工具)框架、面試題

    ? ? ? ? ? ? 讓程序員代替人為去驗(yàn)證web項(xiàng)目功能的過程 ? ???1)需求變動(dòng)不頻繁 測試腳本的穩(wěn)定性決定了自動(dòng)化測試的維護(hù)成本。如果軟件需求變動(dòng)過于頻繁,測試人員需要根據(jù)變動(dòng)的需求來更新測試用例以及相關(guān)的測試腳本,而腳本的維護(hù)本身就是一個(gè)代碼開發(fā)的過程,

    2024年02月03日
    瀏覽(32)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包