个人博客系统项目自动化测试

目录

一、项目简介

二、项目功能

三、测试计划

1.功能测试

(1)测试用例

(2)实际执行测试的部分操作步骤/截图

博客登录页面

博客首页(列表页)

博客详情页

博客编辑页(发布页)

2、代码编写对博客系统进行自动化测试

四、测试工具

、自

目录

一、项目简介

二、项目功能

三、测试计划

1.功能测试

(1)测试用例

(2)实际执行测试的部分操作步骤/截图

博客登录页面

博客首页(列表页)

博客详情页

博客编辑页(发布页)

2、代码编写对博客系统进行自动化测试

(1)三个软件包的介绍

(2)公共类utils

(3)登录页面测试BlogLoginTest

(4)列表页测试BlogListTest

(5)编辑页测试BlogEditTest

(6)详情页测试BlogDetailTest

(7)测试套件runSuite

四、测试工具

五、自动化测试相关代码链接

六、测试小结

    


一、项目简介

       1. 个人博客系统采用前后端分离的方法来实现,同时使用了数据库来存储相关的数据,同时将其部署到云服务器上。前端主要有四个页面构成:登录页、列表页、详情页以及编辑页,以上模拟实现了最简单的个人博客系统。其结合后端实现了以下的主要功能:登录、编辑博客、注销、删除博客、以及强制登录等功能。
      2.但是该项目没有设计用户注册功能,只能提前在数据库中存储用户信息后经过校验登录;并且用户头像不能自己设定,在进行前端页面的书写过程中已经将头像的图片写为静态了;而用户信息中的文章数以及分类数也没有在后端中具体实现,直接在前端页面中写为了静态的。
      3.该个人博客系统可以实现个人用户简单的博客记录,时间、标题、内容以及发布者等都可以进行详细地查看。

二、项目功能

        该个人博客系统主要实现了以下几个功能:登录、注销、写博客以及删除博客等功能。

        登录功能:用户名以及密码已经在后端写入了数据库,没有实现账户注册功能,即:用户名以及密码是已经存在的。登录成功后就会跳转到列表页面。在右上角存在主页和写博客两个按钮,但是在未登录情况下按下均只会跳转到登录页面。
        列表页面:可以在列表页查看有限数量的博客简介,其包括博客标题、发布时间以及内容概要。在左侧可以看到登录的用户以及文章数、分类数等的模块。在右上角有主页、写博客和注销三个功能:主页即列表页,写博客即博客编辑页,注销即注销用户,回到登录页面。
        详情页面:在列表页面点击“查看全文”按钮就会跳转到详情页,此时就可以看到该篇博客的完整内容。在右上角同样有主页、写博客、删除和注销四个功能:删除即删除该篇博客,删除之后就会跳转到列表页面,该篇博客就被成功删除。
       写博客:在登录之后的任意界面点击“写博客”之后就会进入博客编辑页面,此时就可以进行博客的编写,点击“发布文章”后就可以成功发布文章,此时就会跳转到列表页。

三、测试计划

1.功能测试
(1)测试用例
(2)实际执行测试的部分操作步骤/截图
  • 博客登录页面

        输入正确的账号密码成功登录

  • 博客首页(列表页)

        成功登录并跳转到博客列表页

  • 博客详情页

       对博客列表页中的一篇进行点击“查看全文”跳转到博客详情页

  • 博客编辑页(发布页)

        点击“写博客”跳转到博客编辑页面

2、代码编写对博客系统进行自动化测试
(1)三个软件包的介绍

 在pycharm中新建项目BlogAutotest,同时在项目下面建立三个软件包,分别是common,tests,images。

其中common生成文件中需要用到的公共配置内容,创建启动以及现场截图就是会频繁进行复用,需要单独放一个类,方便进行代码复用,所以单独创建一个类进行存储。

tests有5个文件,四个页面每个页面一个测试类,然后根据脑图进行测试用例的编写,还有一个测试套件runtests,测试套件的运行,使用的是以测试类作为执行顺序的方式,使用测试套件便于运行以及修改。

images是保存自动化截图的软件包,根据每天的日期分类,当天的自动化截图保存到当天的文件夹下。在进行页面定位元素或者截图时,注意添加隐式等待,为了确保页面正确加载显示。           

以下是所建立的是common公共包和tests测试包以及images:

(2)公共类utils
  • 创建驱动、保存现场截图
  • 注意:在保存现场截图的时候命名是按时间来进行文件夹的划分,然后图片的名称要体现出测试类的类名,方便进行问题的追溯。
  • 注意文件名的动态获取,注意时间格式的设置。
(3)登录页面测试BlogLoginTest
  •  创建驱动,并打开页面
  •  测试页面是否正常打开
  •  测试正常登录:多参数测试
  • 测试异常登录:用户名/密码错误/两者都为空的情况
  • 注意测试的顺序,否则可能会因为执行顺序不对导致测试失败
  • 注意清空内容后才能再次输入用户名以及密码
(4)列表页测试BlogListTest
  • 测试博客列表页是否可以正常打开
  • 测试列表页的“查看全文”按钮是否可以正常跳转
  • 测试未登录的直接链接是否会跳转到登录页面,顺便测试了“注销”按钮
  • 同样注意执行顺序
(5)编辑页测试BlogEditTest
  • 测试编辑页是否可以正确打开
  • 测试博客是否可以正常发布:元素齐全 or 部分元素
  • 测试“写博客”按钮是否可以正常使用
  • 执行顺序
(6)详情页测试BlogDetailTest
  • 测试详情页的正确打开
  • 测试能否从详情页打开博客编辑页面
  • 执行顺序
(7)测试套件runSuite
  • 测试套件的运行,使用的是以测试类作为执行顺序的方式。

四、测试工具

      使用selenium进行web自动化测试。selenium 是一个强大的工具,用于自动化 web 应用程序的测试。它支持多种浏览器,并可以通过不同的编程语言来编写自动化脚本,如 Java、Python、C# 等。Selenium 需要 WebDriver 来与浏览器进行交互。不同的浏览器需要不同的 WebDriver。

五、自动化测试相关代码链接

个人博客系统自动化测试相关代码链接

六、测试小结

  • 一定要关注测试用例的执行顺序问题
  • 对于页面的检查一定要到位,如检查元素是否存在确保页面的正确性
  • 注意多参数测试的页面导航问题
  • 因为列表页等的测试是需要在登录成功后才能抵达的,所以在进行登录页面测试的最后一步应该是登录成功的状态,这样子是为了确保列表页等能够正确进入测试。【并不是绝对,但是需要进行关注】
  • 驱动关闭的位置要注意,只有最后一个用例结束之后才进行关闭。
  • 为了把所有的用例的执行结果保存下来,方便后续查错或查看,也就是保存现场,此时就需要直接在公共类中进行该方法的定义。
  • 注意屏幕截图保存的方式:动态时间戳并进行时间格式化,然后期望按照某种维度(天、周)以文件夹的方式进行保存。
  • 在使用chrome浏览器进行自动化测试时,要保整 ChromeDriver 与你hrome 浏览器版本兼容。
  • 如果在测试中遇到超时问题,请检查网络连接或尝试增加 WebDriverWait 的等待时间。
  • 对于不同的 Web 元素定位策略(如 ID、NAME、CLASS_NAME、CSS_SELECTOR、XPATH 等),请根据 Web 页面的实际情况选择合适的策略。

              

     

                

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值