【自动化测试实战篇】Web自动化测试实战:从用例编写到报告生成

🔥艾莉丝努力练剑:个人主页

专栏传送门:《C语言》《数据结构与算法》C/C++干货分享&学习过程记录Linux操作系统编程详解笔试/面试常见算法:从基础到进阶测试开发要点全知道

⭐️为天地立心,为生民立命,为往圣继绝学,为万世开太平


🎬艾莉丝的简介:


🎬艾莉丝的测试开发博客简介:

****************************



前情提示

本文就以博客系统为例,基于web项目进行一下完整的实战吧!


目录

前情提示

[1 ~> 自动化实施步骤](#1 ~> 自动化实施步骤)

[1.1 编写web测试用例](#1.1 编写web测试用例)

[1.2 自动化测试脚本开发](#1.2 自动化测试脚本开发)

[common / Utils.py](#common / Utils.py)

[cases / BlogLogin.py](#cases / BlogLogin.py)

[cases / BlogList.py](#cases / BlogList.py)

[cases / BlogDetail.py](#cases / BlogDetail.py)

[cases / RunCases.py](#cases / RunCases.py)

[1.3 将自动化测试补充至测试报告](#1.3 将自动化测试补充至测试报告)

结尾


1 ~> 自动化实施步骤

1.1 编写web测试用例

这里画测试用例的软件,博主推荐用Xmind------

简单给大家展示一下博客系统UI自动化测试用例的测试用例编写------

1.2 自动化测试脚本开发

common / Utils.py

python 复制代码
#创建驱动对象
import datetime
import os.path
import sys

from selenium import webdriver
from selenium.webdriver.chrome.service import Service
from webdriver_manager.chrome import ChromeDriverManager

class Driver:
    driver = ""
    def __init__(self):
        options = webdriver.ChromeOptions()
        # options.page_load_strategy = 'eager'
        self.driver =
webdriver.Chrome(service=Service(ChromeDriverManager().install()),options=options)

    def getScreenShot(self):
        dirname = datetime.datetime.now().strftime('%Y-%m-%d')
        if not os.path.exists("../images/" + dirname):
            os.mkdir("../images/" + dirname)
        filename = sys._getframe().f_back.f_code.co_name + "-" +
datetime.datetime.now().strftime(
            '%Y-%m-%d-%H%M%S') + ".png"
        self.driver.save_screenshot(f'../images/{dirname}/' + filename)
BlogDriver = Driver()

cases / BlogLogin.py

python 复制代码
import time

from selenium.webdriver.common.by import By

from common.Utils import BlogDriver

class BlogLogin:
    url = ""
    driver = ""

def __init__(self):
    self.url = "http://192.168.47.135:8653/blog_system/blog_login.html"
    self.driver = BlogDriver.driver
    self.driver.get(self.url)
def loginSucTest(self):
time.sleep(2)
    self.driver.find_element(By.CSS_SELECTOR, "#username").clear()
    self.driver.find_element(By.CSS_SELECTOR, "#password").clear()
    self.driver.find_element(By.CSS_SELECTOR,
"#username").send_keys("admin")
    self.driver.find_element(By.CSS_SELECTOR, "#password").send_keys("123")
    self.driver.find_element(By.CSS_SELECTOR, "#submit").click()
# 对登录结果进⾏检测, 如果跳转到了博客列表⻚才算是登录成功了
    self.driver.find_element(By.CSS_SELECTOR, "body > div.container >
div.left > div > img")
    BlogDriver.getScreenShot()
    self.driver.back()

def loginFailTest(self):
    self.driver.find_element(By.CSS_SELECTOR, "#username").clear()
    self.driver.find_element(By.CSS_SELECTOR, "#password").clear()
    self.driver.find_element(By.CSS_SELECTOR,
"#username").send_keys("admin")
    self.driver.find_element(By.CSS_SELECTOR, "#password").send_keys("111")
    self.driver.find_element(By.CSS_SELECTOR, "#submit").click()
    # 等登录失败的结果进⾏检测, 不能仅仅通过body来校验结果,因为登录成功的结果⻚也有body元素
    expect = "⽤⼾名或密码错误!"
    actual = self.driver.find_element(By.CSS_SELECTOR, "body").text
    print(actual)
    BlogDriver.getScreenShot()
    assert expect == actual
    self.driver.back()

cases / BlogList.py

python 复制代码
from selenium.webdriver.common.by import By

from common.Utils import BlogDriver
class BlogList:
    url = ""
    driver = ""
    def __init__(self):
        self.driver = BlogDriver.driver
        self.url = "http://192.168.47.135:8653/blog_system/blog_list.html"
        self.driver.get(self.url)

    # 前提:登陆状态下才能进⼊到列表⻚
    def ListTest(self):
        self.driver.find_element(By.CSS_SELECTOR, "body > div.container >
div.left > div > img")
        self.driver.find_element(By.CSS_SELECTOR, "body > div.container >
div.right > div:nth-child(1) > a")

    articles = self.driver.find_elements(By.CSS_SELECTOR, "body >
div.container > div.right > div")
    assert len(articles) > 10

    #点击⽂章
    self.driver.find_element(By.CSS_SELECTOR,"body > div.container >
div.right > div:nth-child(1) > a").click()

    title = self.driver.title
    assert title == "博客详情⻚"
    BlogDriver.getScreenShot()

cases / BlogDetail.py

python 复制代码
from selenium.webdriver.common.by import By

from common.Utils import BlogDriver
class BlogDetail:
    url = " "
    driver = ""

    def __init__(self):
        self.url = "http://192.168.47.135:8653/blog_system/blog_detail.html?
blogId=15"
        self.driver = BlogDriver.driver
        title = self.driver.title
        #列表⻚已经跳过来了,⽆需再指定url跳转
        if not title=="博客列表⻚":
            self.driver.get(self.url)
    def DetailCheck(self):
        #body > div.container > div.right > div:nth-child(1) > a
        BlogDriver.getScreenShot()
        self.driver.find_element(By.CSS_SELECTOR,"body > div.container >
div.right > div > h3")
        self.driver.find_element(By.CSS_SELECTOR,"body > div.container >
        div.right > div > div.date")
self.driver.find_element(By.CSS_SELECTOR,"#content")

cases / RunCases.py

python 复制代码
from common.Utils import BlogDriver
from tests import BlogLogin
from tests import BlogList
from tests import BlogDetail
if __name__ == "__main__":
    BlogLogin.BlogLogin().loginSucTest()
    BlogList.BlogList().ListTest()
    BlogDetail.BlogDetail().DetailCheck()
    BlogDriver.driver.quit()

1.3 将自动化测试补充至测试报告

测试报告模板:


结尾

本文的内容到这里就全部结束了,感谢您的阅读!

往期回顾:

【自动化测试函数 (下)】Web自动化攻坚:应对加载等待、浏览器导航与无头模式的自动化脚本艺术

结语: 本期我们学习了测试开发/测试内容中的自动化测试常用函数篇,希望对学习测试开发/测试相关内容的uu有所帮助,不要忘记给博主"一键四连"哦!

🗡博主在这里放了一只小狗,大家看完了摸摸小狗放松一下吧!🗡

૮₍ ˶ ˊ ᴥ ˋ˶₎ა

相关推荐
Katecat996632 小时前
基于YOLO11-HAFB-1的五种羊品种分类识别系统详解
人工智能·数据挖掘
旧日之血_Hayter2 小时前
Java线程池实战:高效并发编程技巧
人工智能
落霞的思绪2 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Hacker_Z&Q2 小时前
CSS 笔记2 (属性)
前端·css·笔记
hit56实验室2 小时前
【易经系列】《屯卦》六二:屯如邅如,乘马班如,匪寇,婚媾。女子贞不字,十年乃字。
人工智能
Anastasiozzzz2 小时前
LeetCode Hot100 295. 数据流的中位数 MedianFinder
java·服务器·前端
丝斯20113 小时前
AI学习笔记整理(67)——大模型的Benchmark(基准测试)
人工智能·笔记·学习
咚咚王者3 小时前
人工智能之核心技术 深度学习 第七章 扩散模型(Diffusion Models)
人工智能·深度学习
github.com/starRTC3 小时前
Claude Code中英文系列教程25:非交互式运行 Claude Code
人工智能·ai编程
逄逄不是胖胖3 小时前
《动手学深度学习》-60translate实现
人工智能·python·深度学习