【软件测试】个人博客系统测试

简介: 【软件测试】个人博客系统测试

一、项目背景

1.1 技术背景


  1. 我的博客系统主要是通过前端HTML+后端SpringBoot实现了一个博客的基本的功能。
  2. 前端主要用到了HTML+CSS,通过Jquery的方式向后端请求数据。
  3. 后端主要用到了SpringBoot的框架,整合了MyBatis,通过MyBatis从数据库中查询数据响应给前端。
  4. 项目中,用户在注册保存密码的时候,后端会进行md5加盐算法进行加密处理,保证了密码的安全性。
  5. 相应数据的时候,封装了一个统一的返回格式,便于前后端的交互及数据的获取。
  6. 用户登录后,为了保持用户在线的持久化,在用户登录成功时,会将用户的身份信息存储在session中,这样在每次访问一个页面的时候,会对当前用户的身份信息进行校验,每次访问时前端会传来一个seeionId,后端通过这个sessionId拿到用户的信息,然后校验,通过后响应给前端数据,否则,提示用户登录。

1.2 功能背景


  1. 注册:新用户进行注册,后端会进行校验,如果注册的用户已存在,会提示用户已存在,如果两次密码不一致,会提示用户重新输入;如果注册成功,会跳转到登录页面。
  2. 登录:用户输入用户名和密码,登录成功,跳转到个人博客列表页,显示当前用户已发布的博客信息。
  3. 发布博客:点击发布博客,会跳转到博客添加页,输入博客内容,发布博客,然后跳转到博客列表页,展示刚刚发布的博客。
  4. 博客详情页:点击博客详情,跳转到博客详情页,展示了博客的标题、内容、发布时间、阅读量、作者信息(作者用户名、作者发布文章数)。
  5. 总博客列表页:显示所有用户发布的博客,会以分页的形式展示,我设置的默认是每页显示两条,会有总页数,当前所在页。
  6. 修改博客:在个人博客列表中,可以点击修改某一篇文章,进入博客修改页重新进行编辑,然后发布修改。
  7. 删除博客:在个人博客列表中,可以点击删除某一篇文章。
  8. 游客登录:如果用户未登录,作为游客可以访问博客列表页(主页),可以查看所有用户发布的博客内容及博客详情,但是不能发布文章。
  9. 注销:点击注销,会退出当前账号。

二、 测试用例编写

根据博客系统的功能,兼容,界面,易用,性能,安全等方面设计了如下测试用例



三、自动化测试

3.1 什么是自动化测试

自动化测试简单来说就是使用自动测试工具和自动测试脚本来完成指定的测试任务,测试启动过程不需要人为参与,但自动化测试之前的准备需要人工手动配置好。它是一种将重复性的、繁琐的测试任务交给计算机自身来执行,它可以大幅度提高测试效率、减少测试人员的成本、提高测试覆盖率和准确性。

3.2 通过使用selenium进行自动化测试的编写(Java实现)

  1. 添加依赖到pom.xml文件:
<!--selenium控制浏览器-->
<dependency>
  <groupId>org.seleniumhq.selenium</groupId>
  <artifactId>selenium-java</artifactId>
  <version>4.7.2</version>
</dependency>
<dependency>
  <groupId>commons-io</groupId>
  <artifactId>commons-io</artifactId>
  <version>2.11.0</version>
</dependency>
<!--测试-->
<dependency>
  <groupId>org.junit.jupiter</groupId>
  <artifactId>junit-jupiter-params</artifactId>
  <version>5.10.1</version>
</dependency>
  1. 封装初始化浏览器驱动:
/**
 * 初始化浏览器驱动
 */
@BeforeAll  //在所有测试方法执行之前执行
static void setUp() {
    //允许所有请求
    chromeOptions.addArguments("--remote-allow-origins=*");
    //取消 chrome正受到自动测试软件的控制的信息栏
    ChromeOptions options = new ChromeOptions();
    options.setExperimentalOption("excludeSwitches", new String[]{"enable-automation"});
    //创建浏览器驱动
    webDriver = new ChromeDriver(chromeOptions);
}
  1. 关闭浏览器
/**
 * 关闭浏览器
 */
@AfterAll // 在所有测试方法执行完之后执行
static void tearDown() {
    webDriver.quit();
}

3.3 编写测试用例,执行自动化测试

前提说明: 我的博客是在本地运行的,如果要测试线上的某个系统,可以把获取页面的url换成相应的网址即可。

3.3.1 输入用户名:test,密码:123,登录成功

  • 获取元素:


  • 测试代码:
/**
 * 输入用户名:test,密码:123,登录成功
 */
@Order(1)//设置执行顺序,但我用着好像不管用
@ParameterizedTest
@CsvFileSource(resources = "loginSuccess.csv")
void loginTest(String username,String password,String blogListUrl) {
    // 1. 打开博客登录页面
    webDriver.get("http://localhost:58081/login.html");
    //智能等待,如果在这次等待期间错误,则会抛出异常
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 2. 输入用户名test
    webDriver.findElement(By.cssSelector("#username")).sendKeys(username);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 3. 输入密码123
    webDriver.findElement(By.cssSelector("#password")).sendKeys(password);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 4. 点击提交按钮
    webDriver.findElement(By.cssSelector("#submit")).click();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    //可能会有弹窗
    webDriver.switchTo().alert().accept();
    // 5. 跳转到列表页
    //  5.1 获取当前页url
    String currentUrl = webDriver.getCurrentUrl();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    //  5.2 与预期url("http://localhost:58081/myblog_list.html")对比,一致则测试通过
    Assertions.assertEquals(blogListUrl, currentUrl);
    // 6. 列表页展示用户名是test
    //  6.1 用户名是test,测试通过,否则不通过
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    String currentUerName = webDriver.findElement(By.cssSelector("#username")).getText();
    Assertions.assertEquals(currentUerName,username);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
}

3.3.2 登录成功后,没有文章,点击写博客,发布博客


  • 点击写文章:


  • 校验url:


  • 测试代码:
@Test
void publishTest() {
    // 1.打开文章列表页
    webDriver.get("http://localhost:58081/myblog_list.html");
    // 2. 没有发布博客,点击添加
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    webDriver.findElement(By.cssSelector("body > div.nav > a:nth-child(5)")).click();
    // 3. 添加标题 test1
    webDriver.findElement(By.cssSelector("#title")).sendKeys("test1");
    // 5. 点击发布文章
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    webDriver.findElement(By.cssSelector("body > div.blog-edit-container > div.title > button")).click();
    // 6. 跳转到博客列表页  “http://localhost:58081/myblog_list.html”
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    String currentUrl = webDriver.getCurrentUrl();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    Assertions.assertEquals("http://localhost:58081/myblog_list.html",currentUrl);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 7. 判断若第一条博客标题为test1,则测试通过
    String newTitle = webDriver.findElement(By.cssSelector("#artListDiv > div > div.title")).getText();
    Assertions.assertEquals("test1",newTitle);
}

3.3.3 发布文章后,文章列表页文章数不为0

  • 获取元素:

  • 测试代码:
@Test
void blogCountTest() {
    //判断当前页文章数量
    int size = webDriver.findElements(By.cssSelector("#artListDiv")).size();
    // 不为0则测试通过
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    Assertions.assertNotEquals(0,size);
}

3.3.4 校验博客

  • 获取元素


  • 测试代码
@Test
 void checkBlogTest() {
     // 1.打开文章列表页
     webDriver.get("http://localhost:58081/myblog_list.html");
     //博客标题
     String title = webDriver.findElement(By.cssSelector("#artListDiv > div:nth-child(1) > div.title")).getText();
     //博客发布时间
     String time = webDriver.findElement(By.cssSelector("#artListDiv > div:nth-child(1) > div.date")).getText();
     Assertions.assertEquals("test1",title);
     //如果是2024年发布的,则测试通过
     if (time.contains("2024")) {
         System.out.println("测试通过");
     } else
         System.out.println("测试未通过");
 }

3.3.5 在文章列表页,发布者可以进行文章修改操作








  • 测试代码
@Test
void updateBlogTest() throws InterruptedException {
    // 1.打开文章列表页
    webDriver.get("http://localhost:58081/myblog_list.html");
    // 2.判断当前登录用户是否是test
    //  根据列表页个人信息进行判断
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    String currentUerName = webDriver.findElement(By.cssSelector("#username")).getText();
    Assertions.assertEquals("test",currentUerName);
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    //  3.执行到这里,说明当前登录用户是test,可以进行修改操作
    //    点击修改,开始修改文章
    webDriver.findElement(By.cssSelector("#artListDiv > div:nth-child(1) > a:nth-child(5)")).click();
    // 4.跳转到修改文章页面  http://localhost:58081/blog_edit.html?blogId=
    // 获取修改页面url
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    String editPageUrl = webDriver.getCurrentUrl();
    if (editPageUrl.contains("http://localhost:58081/blog_edit.html?blogId=")) {
        System.out.println("测试通过!");
    } else {
        System.out.println("测试不通过!");
    }
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    // 5. 修改文章内容
    // 通过JS将标题进行修改
    ((JavascriptExecutor)webDriver).executeScript("document.getElementById(\"title\").value = \"自动化测试\"");
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    // 6. 点击修改文章
    webDriver.findElement(By.cssSelector("body > div.blog-edit-container > div.title > button")).click();
    // 7. 跳转到博客列表页  “http://localhost:58081/myblog_list.html”
    // 会有弹窗
    // 这里强制睡3s,要不然这个弹窗会检测不出来
    sleep(3000);
    webDriver.switchTo().alert().accept();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    String currentUrl = webDriver.getCurrentUrl();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    Assertions.assertEquals("http://localhost:58081/myblog_list.html",currentUrl);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 8. 判断若第一条博客标题为自动化测试,则测试通过
    String newTitle = webDriver.findElement(By.cssSelector("#artListDiv > div > div.title")).getText();
    Assertions.assertEquals("自动化测试",newTitle);
}

3.3.6 在文章列表页,发布者可以进行文章删除操作

  • 操作步骤


@Test
void deleteBlogTest() throws InterruptedException {
    // 1.打开文章列表页
    webDriver.get("http://localhost:58081/myblog_list.html");
    // 2.判断当前登录用户是否是test
    //  根据列表页个人信息进行判断
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    String currentUerName = webDriver.findElement(By.cssSelector("#username")).getText();
    Assertions.assertEquals("test",currentUerName);
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    //  3.执行到这里,说明当前登录用户是test,可以进行删除操作
    //    点击修改,开始删除文章
    webDriver.findElement(By.cssSelector("#artListDiv > div:nth-child(1) > a:nth-child(6)")).click();
    webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
    //可能有弹窗
    sleep(3000);
    webDriver.switchTo().alert().accept();
    // 4. 校验页面 http://localhost:58081/myblog_list.html
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    String currentUrl = webDriver.getCurrentUrl();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    Assertions.assertEquals("http://localhost:58081/myblog_list.html",currentUrl);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 5. 判断若第一条博客标题不是自动化测试,则测试通过
    String newTitle = webDriver.findElement(By.cssSelector("#artListDiv > div > div.title")).getText();
    Assertions.assertNotEquals("自动化测试",newTitle);
}

3.3.7 注销账号,退出登录

  • 操作步骤


  • 测试代码
@Test
void logOffTest() throws InterruptedException {
    // 1. 点击注销按钮,退出博客
    webDriver.findElement(By.cssSelector("body > div.nav > a:nth-child(6)")).click();
    //可能有弹窗,直接通过,跳转到登录页面
    sleep(3000);
    webDriver.switchTo().alert().accept();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 2. 判断当前页面是否是登录页面
    String currentUrl = webDriver.getCurrentUrl();
    Assertions.assertEquals("http://localhost:58081/login.html",currentUrl);
}

3.3.8 输入用户名:testt,密码:123,登录失败

  • 操作步骤

  • 测试代码
@ParameterizedTest
@CsvFileSource(resources = "loginFail1.csv")
void loginFail1(String username,String password,String blogListUrl) {
    // 1. 打开博客登录页面
    webDriver.get("http://localhost:58081/login.html");
    //智能等待
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 2. 输入用户名testt
    webDriver.findElement(By.cssSelector("#username")).sendKeys(username);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 3. 输入密码123
    webDriver.findElement(By.cssSelector("#password")).sendKeys(password);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 4. 点击提交按钮
    webDriver.findElement(By.cssSelector("#submit")).click();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    //可能会有弹窗
    webDriver.switchTo().alert().accept();
    // 5. 不进行跳转
    //  5.1 获取当前页url
    String currentUrl = webDriver.getCurrentUrl();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    //  5.2 与预期url("http://localhost:58081/login.html")对比,一致则测试通过
    Assertions.assertEquals(blogListUrl, currentUrl);
}

3.3.9 输入用户名:test,密码:1234,登录失败

  • 操作步骤

  • 测试代码
@ParameterizedTest
@CsvFileSource(resources = "loginFail2.csv")
void loginFail2(String username,String password,String blogListUrl) {
    // 1. 打开博客登录页面
    webDriver.get("http://localhost:58081/login.html");
    //智能等待
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 2. 输入用户名test
    webDriver.findElement(By.cssSelector("#username")).sendKeys(username);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 3. 输入密码1234
    webDriver.findElement(By.cssSelector("#password")).sendKeys(password);
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    // 4. 点击提交按钮
    webDriver.findElement(By.cssSelector("#submit")).click();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    //可能会有弹窗
    webDriver.switchTo().alert().accept();
    // 5. 不进行跳转
    //  5.1 获取当前页url
    String currentUrl = webDriver.getCurrentUrl();
    webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
    //  5.2 与预期url("http://localhost:58081/login.html")对比,一致则测试通过
    Assertions.assertEquals(blogListUrl, currentUrl);
}

四、测试用例通过



相关文章
|
6天前
|
敏捷开发 Java 测试技术
探索软件测试中的自动化测试框架
在软件开发的生命周期中,软件测试扮演着至关重要的角色。随着技术的不断进步和软件项目的日益复杂化,传统的手动测试方法已经无法满足高效、准确的测试需求。自动化测试作为一种提高测试效率和质量的有效手段,越来越受到开发者和测试者的青睐。本文将深入探讨自动化测试框架的重要性、常见的自动化测试工具以及如何选择合适的自动化测试框架。
32 10
|
13天前
|
机器学习/深度学习 前端开发 测试技术
探索软件测试中的自动化测试框架选择与优化策略####
本文深入探讨了在当前软件开发生命周期中,自动化测试框架的选择对于提升测试效率、保障产品质量的重要性。通过分析市场上主流的自动化测试工具,如Selenium、Appium、Jest等,结合具体项目需求,提出了一套系统化的选型与优化策略。文章首先概述了自动化测试的基本原理及其在现代软件开发中的角色变迁,随后详细对比了各主流框架的功能特点、适用场景及优缺点,最后基于实际案例,阐述了如何根据项目特性量身定制自动化测试解决方案,并给出了持续集成/持续部署(CI/CD)环境下的最佳实践建议。 --- ####
|
1月前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
1月前
|
测试技术 UED
软件测试的艺术:探索性测试的力量
【10月更文挑战第6天】在软件开发的世界中,测试是确保产品质量的关键步骤。传统的测试方法往往遵循严格的脚本和预定义的路径进行,但探索性测试(ET)则提供了一种更为灵活、创造性的替代方案。通过模拟真实用户的行为和思考过程,ET能够揭示那些传统测试可能遗漏的问题。本文将深入探讨探索性测试的核心原则、实施策略以及它如何提高软件测试的效率和有效性。
|
17天前
|
测试技术 开发者 UED
探索软件测试的深度:从单元测试到自动化测试
【10月更文挑战第30天】在软件开发的世界中,测试是确保产品质量和用户满意度的关键步骤。本文将深入探讨软件测试的不同层次,从基本的单元测试到复杂的自动化测试,揭示它们如何共同构建一个坚实的质量保证体系。我们将通过实际代码示例,展示如何在开发过程中实施有效的测试策略,以确保软件的稳定性和可靠性。无论你是新手还是经验丰富的开发者,这篇文章都将为你提供宝贵的见解和实用技巧。
|
15天前
|
jenkins 测试技术 持续交付
软件测试中的自动化测试策略
在当今快速发展的软件行业中,自动化测试已成为确保软件质量和效率的关键工具。本文将探讨自动化测试的重要性、实施策略以及面临的挑战,旨在为软件开发团队提供实用的指导和建议。
|
24天前
|
测试技术
探索软件测试中的“思维侧翼”——如何以创新思维引领测试策略###
本文旨在探讨软件测试领域中,如何通过培养与运用创新思维,提升测试策略的有效性与效率。不同于传统的技术解析或理论阐述,本文将以“思维侧翼”为喻,启发读者从不同维度审视软件测试,寻找突破常规的思路与方法。我们相信,在快速迭代的软件开发周期中,灵活多变且富有创造力的测试思维,是发现潜在缺陷、保障产品质量的关键。 ###
|
25天前
|
测试技术 定位技术 UED
软件测试的艺术:探索性测试的深度与广度
【10月更文挑战第22天】在软件开发的广阔舞台上,测试扮演着不可或缺的角色。本文将带领读者深入理解探索性测试(Exploratory Testing)的精髓,揭示其在现代软件质量保证中的价值。我们将通过实际案例、生动比喻和具体步骤,展现如何像艺术家一样进行软件测试,确保产品质量的同时,提升测试的效率和乐趣。文章不仅适合初学者建立测试基础,也能帮助资深测试人员深化对探索性测试的理解和应用。
|
23天前
|
监控 安全 jenkins
探索软件测试的奥秘:自动化测试框架的搭建与实践
【10月更文挑战第24天】在软件开发的海洋里,测试是确保航行安全的灯塔。本文将带领读者揭开软件测试的神秘面纱,深入探讨如何从零开始搭建一个自动化测试框架,并配以代码示例。我们将一起航行在自动化测试的浪潮之上,体验从理论到实践的转变,最终达到提高测试效率和质量的彼岸。
|
25天前
|
Kubernetes 测试技术 持续交付
C# 一分钟浅谈:集成测试与系统测试
【10月更文挑战第19天】本文详细介绍了集成测试和系统测试的概念、目的及其在软件开发中的重要性。通过分析常见问题和易错点,结合代码示例,探讨了如何通过代码规范、自动化测试和持续集成等方法提高测试效果,确保软件质量和可靠性。
48 1
下一篇
无影云桌面