写点有价值的测试用例

2024-05-25 21:48
文章标签 测试用例 价值 写点

本文主要是介绍写点有价值的测试用例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这篇文章为《解读Android官方MVP项目单元测试》(以下简称《解读》)的附录部分,行此文的目的有二,其一是这个项目的单元测试齐全,覆盖率很高,有极高的学习价值,笔者希望把每个测试用例都描述一遍,通过这种方式来强迫自己认真的看完。其二,这部分内容难免枯燥,笔者尽力想把它写得可读性高一点点,却发现着实有难度,简直是给自己挖坑,所以从《写点有价值的测试用例》的角度出发,对这篇附录文章稍作修饰。但不管这样,这个MVP项目及其单元测试用例对我们的工作可以带来很多思路,所以不妨速读一遍。

一 什么是有价值的测试用例

以这个项目为例,我觉得对于测试用例的设计,不能离开架构层面和业务层面。

  1. 架构层面
    不同的架构,决定着测试用例的写法不一,比如MVC或者MVP,每一层负责的测试职责是不一样的。 以todo-mvp这个项目为例,笔者在《解读》中已经提到,一个功能的测试需要MVP三层的协作,彼此各司其职,却又互相联系,这里再做一番总结:

    • Presenter层:这一层很清晰,我们为它的每个接口方法,以及每个方法里涉及的多个逻辑路径设计相应的测试用例,值得注意的是,这一层我们不做输入输出的断言,而是验证是否正确覆盖V层和M层的逻辑。
    • Model层:同上,我们为它的每个方法设计测试用例,与P层不同,这一层要断言输入输出数据是否准确。
    • View层:这一层我们放在业务层面来讲。
  2. 业务层面
    做单元测试,测试业务逻辑是重中之重。View层承担着这一重任,设计这一层的测试用例时,不要想太多,站在我们正常使用功能的角度出发,把交互行为翻译成Espresso的代码。由于View是入口,当一种交互行为发生,Presenter开始调度View和Model层各自执行逻辑,因此从这个角度来讲,View层的测试涵盖了MVP三层的逻辑。

聊完有价值的,我们再来看看什么是没价值的测试用例。比如以下几种:

  1. 对成熟的工具类进行测试
  2. 对简单的方法进行测试(比如get、set方法)
  3. MVP各层重复测试,比如P层去断言输入输出的正确性

接下来笔者将完整的展示这个MVP项目中的所有单元测试用例,分为三个维度,androidTest下的、androidTestMock下的和test下的所有测试用例,如果觉得阅读起来枯燥,可以直接阅读每个测试类开篇的概述部分

二 androidTest文件下的测试

V层:导航界面测试——AppNavigationTest

概述:该测试用例做导航测试,即对DrawerLayout打开、关闭、点击Item后打开的Activity等功能进行测试。
意义:告诉我们如何对DrawerLayout设计有价值的测试用例。

  1. clickOnStatisticsNavigationItem_ShowsStatisticsScreen
    打开Left Drawer->点击Statistics按钮->断言StatisticsActivity已经打开
  2. clickOnListNavigationItem_ShowsListScreen
    打开Left Drawer->点击Statistics按钮->打开Left Drawer->点击TO-DO list按钮->断言TasksActivity已经打开
  3. clickOnAndroidHomeIcon_OpensNavigation
    验证通过ActionBar的icon进行关闭和打开Left Drawer

V层:任务模块界面测试——TasksScreenTest

概述:该测试用例针对任务列表和任务详情页的界面功能测试,涵盖所有页面上的交互,包括增删改查任务、改变任务状态,过滤任务列表等,除此之外还验证了横竖屏的交互对界面数据状态的影响。
意义:告诉我们如何设计有价值的功能界面测试用例。

  1. clickAddTaskButton_opensAddTaskUi
    点击添加按钮->断言相应Activity已经打开
  2. addTaskToTasksList
    添加标题1的TO-DO任务后回到列表页->断言标题1存在
  3. editTask
    添加标题1的TO-DO任务后回到列表页->点击此Item进入查看页面->点击编辑按钮->修改成标题2->点击保存->断言标题1不存在和标题2存在
  4. markTaskAsComplete
    添加任务并点击CheckBox设置为已完成->通过过滤器进入All/Active/Completed视图,断言该任务是否存在
  5. markTaskAsActive
    测试标记任务为Active状态,手法同上一点
  6. showAllTasks
    添加2个任务->进入All视图->断言两个任务在界面上存在
  7. showActiveTasks
    添加2个任务->进入Active视图->断言两个任务在界面上存在
  8. showCompletedTasks
    添加2个任务->标记为已完成->进入Completed视图->断言两个任务在界面上存在
  9. clearCompletedTasks
    添加2个任务->标记为已完成->点击Clear completed按钮->断言两个任务不存在
  10. createOneTask_deleteTask
    添加1个任务->点击该任务进入详情页->点击删除->断言该任务不存在
  11. createTwoTasks_deleteOneTask
    创建2个任务->删除第2个->断言第1个存在且第2个不存在
  12. markTaskAsCompleteOnDetailScreen_taskIsCompleteInList
    创建1个任务->点击该任务进入详情页->标记为已完成->回到列表页->断言该任务为选中状态
  13. markTaskAsActiveOnDetailScreen_taskIsActiveInList
    创建1个任务->在列表页标记为已选中->进入详情页标记为未选中->回到列表页->断言该任务未被选中
  14. markTaskAsAcompleteAndActiveOnDetailScreen_taskIsActiveInList
    创建1个任务->在详情页触发两次checkbox的点击- 回到列表页->断言该任务未被选中
  15. markTaskAsActiveAndCompleteOnDetailScreen_taskIsCompleteInList
    创建1个任务->标记为已完成->在详情页触发两次checkbox的点击- 回到列表页->断言该任务被选中
  16. orientationChange_FilterActivePersists
    创建1个任务->标记为已完成->进入Active视图->验证该任务不存在->切换横竖屏->断言该任务状态与之前一致
  17. orientationChange_FilterCompletedPersists
    创建1个任务->标记为已完成->进入Completed视图->验证该任务存在->切换横竖屏->断言该任务状态与之前一致

M层:本地数据库操作测试——TasksLocalDataSourceTest

概述:对数据库中处理Task的增删改查、改变Task状态等进行测试。
意义:持久层的CRUD往往需要配合起来测试和断言,此例很好的诠释了这一点

  1. saveTask_retrievesTask
    • 测试目的:验证保存Task到数据库的逻辑
    • 测试用例:实例化Task对象->保存入库->根据ID获取Task->在回调函数中断言与入库的Task一致
  2. completeTask_retrievedTaskIsComplete
    • 测试目的:验证将任务设置成完成状态的逻辑
    • 测试用例:Task对象保存入库->触发完成任务的逻辑->根据ID获取Task->在回调函数中断言该Task已完成
  3. activateTask_retrievedTaskIsActive
    • 测试目的:验证将任务设置为激活状态的逻辑
    • 测试用例:mock一个回调对象callback->Task对象保存入库->触发完成任务的逻辑->触发激活任务的逻辑->根据ID获取Task->断言callback执行了onTaskLoaded的逻辑
  4. clearCompletedTask_taskNotRetrievable
    • 测试目的:验证清除所有已完成任务的逻辑
    • 测试用例:mock三个回调函数对象,分别是callback1到3->保存任务1,任务2和任务3,其中任务1和任务2为completed状态,任务3为active状态->清理所有已完成的任务->根据3个Task的ID分别获取Task->断言callback1和callback2执行了onDataNotAvailable逻辑- >断言callback3执行onTaskLoaded逻辑
  5. deleteAllTasks_emptyListOfRetrievedTask
    • 测试目的:验证删除数据库中所有任务的逻辑
    • 测试用例:保存任务->mock一个回调函数callback->删除所有任务->获取任务列表->断言callback执行了onDataNotAvailable的逻辑
  6. getTasks_retrieveSavedTasks
    • 测试目的:验证获取数据库中所有任务的逻辑
    • 测试用例:保存2个任务->获取任务列表->在回调函数中断言这2个任务存在

三 androidTestMock文件下的测试

在《解读》一文中,笔者提到该文件夹主要的作用是对网络请求进行Fake,即不发出网络请求,而是返回事先定义好的数据。

V层:新增编辑任务界面测试——AddEditTaskScreenTest

  1. errorShownOnEmptyTask
    • 测试目的:验证保存或编辑任务时,如果输入空标题,会弹出Snackbar提示不能为空
    • 测试用例:打开详情页->输入空标题和空描述->点击保存->通过Snackbar的消息内容验证Snackbar已显示

V层:统计界面测试——StatisticsScreenTest

  1. Tasks_ShowsNonEmptyMessage
    打开统计界面->事先Fake两条任务数据,状态分别为Completed和Active->断言两种统计栏目都已显示

V层:任务详情界面测试——TaskDetailScreenTest

概述:Fake出不同状态的任务并在详情页进行标题、描述和状态的断言。
意义:指导我们如何对网络请求数据进行Fake。

  1. activeTaskDetails_DisplayedInUi
    Fake一条状态为Active的任务->打开详情页->断言标题、描述、任务状态
  2. completedTaskDetails_DisplayedInUi
    Fake一条状态为Complete的任务->打开详情页->断言标题、描述、任务状态
  3. orientationChange_menuAndTaskPersist
    横竖屏的测试手法与TasksScreenTest中一致,不再赘述。

四 test文件夹下的测试

P层:新增编辑任务测试——AddEditTaskPresenterTest

概述:进入Presenter层的测试后,我们不再去断言输入输出了,取而代之的是,断言是否正确的覆盖了View层和Model层的逻辑。AddEditTaskPresenter共有三个方法,分别是createTaskupdateTaskpopulateTask,对应增加、修改、展示任务的功能,其中增加任务涉及到成功和失败的情况,因此有4个测试用例。
意义:这些Presenter层的测试可以教会我们如何Mock,如何verify,如何测试异步回调,以及如何完整的覆盖Presenter层的所有逻辑路径。

  1. saveNewTaskToRepository_showsSuccessMessageUi
    创建Presenter,执行创建任务的逻辑->断言Model层执行了保存的逻辑->断言View层执行了显示任务列表的逻辑
  2. saveTask_emptyTaskShowsErrorUi
    创建Presenter,执行创建任务的逻辑,且任务Title为空->断言View层执行了展示error的逻辑
  3. saveExistingTaskToRepository_showsSuccessMessageUi
    此用例验证的是update任务的逻辑,测试手法同1。
  4. populateTask_callsRepoAndUpdatesView
    • 测试目的:验证详情页展示的任务信息是否正确
    • 测试用例:presenter执行populateTask()->断言执行了getTask(),且参数正确->断言回调函数执行了正确的逻辑->断言View层展示的是正确的Task数据

P层:统计功能测试——StatisticsPresenterTest

概述:该类的presenter接口比较简单,只有一个入口方法start,执行的是加载统计信息的逻辑,执行过程中涉及几个路径:加载空任务列表,加载非空任务列表和数据不可用,分别对应以下1,2,3点。

  1. loadEmptyTasksFromRepository_CallViewToDisplay
    断言加载空任务列表
  2. loadNonEmptyTasksFromRepository_CallViewToDisplay
    断言加载非空任务列表
  3. loadStatisticsWhenTasksAreUnavailable_CallErrorToDisplay
    断言数据不可用

P层:任务详情功能测试——TaskDetailPresenterTest

概述:该Presenter共有5个方法,分别是:

  • start:展示任务详情,涉及三种路径:展示Active任务、展示Compeled任务和展示非法ID的任务,对应1,2,3的测试用例
  • deleteTask:删除任务,对应第4个测试用例
  • completeTask:完成任务,对于第5个
  • activateTask:激活任务,对应第6个
  • editTask:编辑任务,对应第7个,编辑非法ID的任务对应的测试用例为第8个
  1. getActiveTaskFromRepositoryAndLoadIntoView
  2. getCompletedTaskFromRepositoryAndLoadIntoView
  3. getUnknownTaskFromRepositoryAndLoadIntoView
  4. deleteTask
  5. completeTask
  6. activateTask
  7. activeTaskIsShownWhenEditing
  8. invalidTaskIsNotShownWhenEditing

P层:任务列表功能测试——TasksPresenterTest

概述,此TasksPresenter的测试与上一点类似,从接口方法出发,此类共有10个接口方法,为此设计了8个测试用例,分别是展示All/Active/Completed的任务列表、点击打开任务详情页、改变任务状态等。

  1. loadAllTasksFromRepositoryAndLoadIntoView
  2. loadActiveTasksFromRepositoryAndLoadIntoView
  3. loadCompletedTasksFromRepositoryAndLoadIntoView
  4. clickOnFab_ShowsAddTaskUi
  5. clickOnTask_ShowsDetailUi
  6. completeTask_ShowsTaskMarkedComplete
  7. activateTask_ShowsTaskMarkedActive
  8. unavailableTasks_ShowsError

M层:数据操作门面类测试——TasksRepositoryTest

概述:该类的测试用例非常齐全,对于如何设计测试用例让数据过期,如何让数据取自本地或者网络等测试技巧都有极高的学习价值。

  1. getTasks_repositoryCachesAfterFirstApiCall
  2. getTasks_requestsAllTasksFromLocalDataSource
  3. saveTask_savesTaskToServiceAPI
  4. completeTask_completesTaskToServiceAPIUpdatesCache
  5. completeTaskId_completesTaskToServiceAPIUpdatesCache
  6. activateTask_activatesTaskToServiceAPIUpdatesCache
  7. activateTaskId_activatesTaskToServiceAPIUpdatesCache
  8. getTask_requestsSingleTaskFromLocalDataSource
  9. deleteCompletedTasks_deleteCompletedTasksToServiceAPIUpdatesCache
  10. deleteAllTasks_deleteTasksToServiceAPIUpdatesCache
  11. deleteTask_deleteTaskToServiceAPIRemovedFromCache
  12. getTasksWithDirtyCache_tasksAreRetrievedFromRemote
  13. getTasksWithLocalDataSourceUnavailable_tasksAreRetrievedFromRemote
  14. getTasksWithBothDataSourcesUnavailable_firesOnDataUnavailable
  15. getTaskWithBothDataSourcesUnavailable_firesOnDataUnavailable
  16. getTasks_refreshesLocalDataSource


文/geniusmart(简书作者)
原文链接:http://www.jianshu.com/p/0429498d302b
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。

这篇关于写点有价值的测试用例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1002706

相关文章

【Spring boot】编写代码及测试用例入门之 Hello Spring boot _踩坑记

先贴下目录: 这是我从 start.spring.io 里下载的依赖Web的模板 // DemoApplication.javapackage com.abloume.springboot.blog.demo;import org.springframework.boot.SpringApplication;import org.springframework.boot.autocon

python+selenium2学习笔记unittest-05测试用例实例

看一下非常简单的目录结构 test_baidu from selenium import webdriverimport unittestimport timeclass MyTest(unittest.TestCase):def setUp(self):self.driver = webdriver.Firefox()self.driver.maximize_window()self

PMP–一、二、三模–分类–14.敏捷–技巧–帮助团队交付价值的执行实践迭代和增量如何帮助交付工作产品

文章目录 技巧一模14.敏捷--实践--帮助团队交付价值的执行实践--持续集成--在不同层面测试、验收测试驱动开发 (ATDD) 、测试驱动开发和行为驱动开发、刺探 。90、 [单选] 敏捷项目的第一次迭代即将开始。发起人召集团队、Scrum主管、产品负责人和其他项目干系人参加启动会议。发起人强调需要在项目尽可能早的时候以最小的成本识别和应对项目风险。与会者实现发起人要求的最佳方式是什么?

【用户价值分析 RFM模型】用户价值分析

RFM模型是衡量客户价值和客户创利能力的重要工具和手段。RFM分析模型主要由三个指标组成,下面对这三个指标的定义和作用做下简单解释: 1、最近一次消费(Recency) 最近一次消费意指用户上一次购买的时间,理论上,上一次消费时间越近的顾客应该是比较好的顾客,对提供即时的商品或是服务也最有可能会有反应。因为最近一次消费指标定义的是一个时间段,并且与当前时间相关,因此是一直在变动的。最近一次消费

企业做网络SEO的核心价值有哪些?

在当今线上营销十分盛行的时代,能够抓住网络营销的企业在行业市场上都是可以获得良好的更多的用户流量;现今做网站SEO优化的企业数量变得越来越多,那么企业做网络SEO的核心价值有哪些?为何企业都爱做? 1、提升网站的搜索排名 SEO通过研究搜索引擎地抓取和检索规律,让产品网站适应这些规律,并取得好的搜索排名。 2、网站建设优化的质量 通过SEO,可以让网站页面、架构和层次更清晰、合理,更符合普

第一篇 第一章资金时间价值计算及应用 第二章经济效果评价

第1章 资金时间价值计算及应用 资金具有时间价值 1.1 利息的计算 1.1.1 利息和利率 I=F-P 债务人为资金需求方 债权人为资金供给方利息对经济活动的影响(1.影响企业行为 2.影响居民资产选择行为 3.影响政府行为) 利率 1.影响因素(1.社会平均利润率的高低 2.市场资金供求对比状况 3.资金要承担的风险 4.债务资金使用期限长短 5.政府宏观调控政策 6.经济周期所处

【软件测试】设计测试用例

📕引言 本文章重点目标: 测试用例的概念 设计测试用例的万能思路 设计测试用例的方法 ◦ 基于需求的设计方法◦ 具体的设计方法 ▪ 等价类 ▪ 边界值 ▪ 判定表法 ▪ 正交法 ▪ 场景法 ▪ 错误猜测法 🍀测试用例 🚩概念 什么是测试用例? 测试用例(TestCase)是为了实施测试而向被测试的系统提供的一组集合,这组集合包含:测试环境、操作步骤、测试数据、预期结果等要

智慧交通APP开发的价值与前景

随着城市化进程的加快,交通问题日益成为人们日常生活中的痛点。拥堵、交通事故、公共交通的不便等问题都在困扰着城市居民。而智慧交通APP的出现,正是为了缓解这些问题,通过整合各类交通信息和技术手段,为用户提供更便捷、高效、安全的出行体验。下面我们来探讨一下开发智慧交通APP的价值与前景。 1. 实时路况与导航:提升出行效率 智慧交通APP的核心功能之一是提供实时的路况信息和智能导航。当你准备出门时

CDO的核心价值与角色深化

随着数字化浪潮席卷各行各业,首席数据官(CDO)这一角色日益显得重要,成为企业战略规划的核心。 他们的主要任务是深入挖掘数据潜能,通过精确的数据洞察为企业的成长和运营优化提供坚实的数据支持和策略指导。 首席数据官的真正价值在于能够引领企业越过数据隔阂,把复杂多变的数据资源转变为决策的宝贵资产。 在数据成为企业最宝贵的资产之际,CDO不仅要掌握如SOA、BI、大数据整合、数据储存与交换等前沿技

强化学习深入学习(一):价值函数和贝尔曼方程

文章目录 0. 引言1. 回报(Return)2. 价值函数(Value Function)3. 贝尔曼期望方程(Bellman Expectation Equation)4. 贝尔曼最优方程(Bellman Optimality Equation)总结 0. 引言 强化学习(Reinforcement Learning, RL)是一种机器学习方法,通过与环境的交互来学习如何