首页 > 其他分享 >聊聊测试用例编写方法及适用场景

聊聊测试用例编写方法及适用场景

时间:2024-07-18 18:00:40浏览次数:27  
标签:场景 聊聊 边界值 等价 测试用例 测试 输入 边界

有过一定测试理论基础的从业者,对测试用例编写方法基本上可以张口就来,什么等价类划分法,边界值分析法,因果图法,场景设计法,错误猜测法等。

这篇文章主要聊聊等价类划分,边界值分析法两个使用频率稍微较高的测试用例编写方法和适用场景。

等价类划分法:是一种常用的黑盒测试技术,用于减少需要测试的输入数据集,同时确保测试覆盖范围。这种方法将所有可能的输入数据划分为几个不同的类别,在每个类别中,数据的行为和处理方式是等效的。如果测试了等价类中的一个值,就认为测试了整个类。

等价类划分法,大的方面又可以分为有效等价类和无效等价类。

有效等价类:

有效等价类指的是那些符合程序或系统规范的输入数据集合。换句话说,它们是程序期望能够正确处理的输入数据。设计测试用例时,我们从每个有效等价类中选取一个或多个代表值进行测试,以验证系统是否能够按照规格说明正确地处理这些输入。

例如,如果一个系统要求用户输入一个在1至10之间的整数,那么1至10这个区间内的任何整数都属于有效等价类。测试用例可以选取1、3,5,9和10来进行测试,以确保系统对这些数值的处理是正确的。

无效等价类:

无效等价类则是指那些不符合程序或系统规范的输入数据集合。它们是程序不应当接受或处理的数据。测试用例设计时,也需要从每个无效等价类中选取一个或多个代表值,以验证系统是否能够正确地拒绝或处理这些异常输入。

继续上面的例子,小于1或大于10的整数都属于无效等价类。测试用例可以选取0和11,以确保系统能够适当地处理这些超出范围的输入,还可以输入负数,英文,汉字等多个无效的等价类,例如显示错误消息或阻止输入。

通过测试有效等价类和无效等价类,测试人员可以确保软件不仅能够正确处理预期的输入,还能够妥善处理非预期的或错误的输入,从而提高软件的健壮性和可靠性。

等价类划分在编写测试用例时常用的场景有哪些?

等价类划分是软件测试中一个非常实用的技巧,用于减少测试用例的数量,同时确保测试覆盖的全面性。这种方法特别适用于那些有大量潜在输入值的情况,通过将输入域划分为若干个等价类,可以更有效地选择测试数据。

主要有以下几类场景:输入验证,条件判断,数据处理,数值范围,字符串长度,文件大小,文件命名等等

边界值分析法:是一种常用的黑盒测试技术,主要用于识别和测试输入或输出边界条件上的缺陷。在软件开发中,很多错误和缺陷往往出现在输入或输出范围的边界上,而非中间值。因此,边界值分析法强调测试数据的选择应集中在边界值附近,而不仅仅是随机或典型的值。

对输入或输出的边界值进行测试的一种黑盒测试方法。‌通常作为对等价类划分法的补充,‌其测试用例来自等价类的边界,‌包括上点(‌边界上的点)‌、‌离点(‌离边界最近的点)‌和内点(‌范围内的点)‌。

边界值分析法的基本思想

确定边界:首先,确定输入或输出数据的边界,这些通常是等价类划分法中等价类的边界点。例如,如果一个输入参数的有效范围是从1到10,边界点就是1和10。

测试边界值:测试正好在边界上的值,以及紧邻边界之外的值。对于上述例子,你会测试1、10,同时也测试0和11,因为它们紧邻边界外侧。

考虑边界情况:边界值分析不仅关注输入边界,也关注输出边界。这意味着在测试过程中要考虑到输出结果的边界条件。

测试用例设计:为每个边界点设计至少一个测试用例。如果可能,还应该为每个边界点两边的值设计测试用例,以检查边界附近的处理逻辑。

边界值分析法适用场景有哪些?

在设计测试用例时,边界值分析法要求你不仅要考虑边界值本身,还要考虑紧邻边界之外的值,以确保软件在这些临界情况下能够正确运行,通过这种方式,你可以更有效地识别和修复潜在的软件缺陷。

边界值分析和等价类划分它们都有哪些优缺点?

边界值分析法优缺点:

优点:

聚焦边界条件:边界值分析法特别关注输入或输出的边界值,这些地方往往是软件错误的高发区域。

高效性:边界值测试用例的设计相对简单,能够快速生成大量有效的测试用例,提高测试效率。

针对性强:边界值分析法能够帮助测试人员识别和测试那些最容易出错的边界条件,提高测试的针对性。

精准性:通过选择系统输入的边界值和特殊值作为测试用例,能够针对性地发现潜在问题,提高测试的精准度。

全面性:边界值分析法能够覆盖系统边界处的各种情况,保证测试的全面性和覆盖率。

缺点:

忽略内部值:边界值分析法主要关注边界,可能忽略了等价类内部的其他值,导致某些内部错误未被发现。

单一维度:在多维输入情况下,仅测试每个维度的边界可能不足以覆盖所有可能的组合边界。

假定线性关系:边界值分析法假设边界点附近的函数行为是线性的,但这可能并不总是成立,特别是在非线性函数中。

边界确定性:确定系统边界值和特殊值需要具有一定的领域知识和经验,否则可能会选择不当导致测试不完整。

局限性:边界值分析法主要适用于输入变量的测试,对于输出变量的测试效果可能有限。

过度依赖:过度依赖边界值分析法可能会忽略一些非边界情况下的潜在问题,影响测试的全面性。

测试用例数量:对于复杂的系统,边界值分析法可能会产生大量的测试用例,需要更多的时间和资源进行测试。

覆盖性不足:边界值分析法无法覆盖所有可能的输入组合,因为只测试了边界值和一些特殊值,可能会遗漏其他情况。

等价类划分的优缺点:

优点:

详细划分:能对某一个数据子集进行详细的划分,顺序性强,逻辑清晰,确保无冗余。

高效性:等价类划分法能够将无穷的输入数据限制在一个指定范围,能够使用少量数据发现更多Bug。

完备性:通过划分等价类,能够确保测试的全面性,覆盖所有可能的输入情况。

全面覆盖:等价类划分法将输入域划分为不同的等价类,确保测试覆盖了所有可能的输入范围,而不仅仅是边界。

减少冗余:通过从每个等价类中选取代表性的测试用例,等价类划分法可以避免测试用例的冗余,节省测试资源。

易于理解:等价类划分法的原理直观易懂,便于测试团队理解和实施。

缺点:

可能遗漏边界:虽然等价类划分法覆盖了等价类,但它可能不会特别关注边界值,这可能导致一些边界条件的错误被忽略。

过度简化:等价类划分法假设同一等价类中的所有值行为相同,但在复杂系统中,这可能不是完全准确的。

等价类界定困难:在某些情况下,界定等价类可能比较困难,特别是当输入数据的性质或规格模糊时。

数据间牵连性:数据集成输入间的内容过少,数据与数据之间的牵连性会存在考虑不周全的情况,还需要其他用例设计方法来补充测试,如边界值分析法。

期望输出不明确:规格说明一般不说明无效测试用列的期望输出是什么,这可能会给测试带来一定的困难。

强类型语言的限制:对于强类型语言,没有必要考虑无效输入,这可能会限制等价类划分法的应用范围。

尽管它们二者各自有其优缺点,但它们通常被结合起来使用,以达到最佳的测试效果,等价类划分用于确定等价类,而边界值分析法则用于测试每个等价类的边界,这样既覆盖了输入的完整范围,又重点关注了容易出错的边界条件。

下边两条是早些时候编写的测试用例相关文章,有兴趣可以了解一下。

测试用例的作用及重要性

标签:场景,聊聊,边界值,等价,测试用例,测试,输入,边界
From: https://blog.csdn.net/qd_lifeng/article/details/140435579

相关文章

  • MMU和SMMU IOMMU使用场景和区别,SMMU技术与cache
    1.各种MMUMMU是memorymanageunit内存管理单元;SMMU是systemmemorymanageunit系统内存管理单元;IOMMU和SMMU的功能基本相同,只是不同厂商的叫法2.各种MMU的使用场景MMU是cpu和各种处理器对应的内存管理单元;SMMU/IOMMU是DMA使用的内存管理单元MMU/SMMU的发展是围绕着虚拟......
  • 大模型的短期记忆和上期记忆各自的使用场景
    吾名爱妃,性好静亦好动。好编程,常沉浸于代码之世界,思维纵横,力求逻辑之严密,算法之精妙。亦爱篮球,驰骋球场,尽享挥洒汗水之乐。且喜跑步,尤钟马拉松,长途奔袭,考验耐力与毅力,每有所进,心甚喜之。 吾以为,编程似布阵,算法如谋略,需精心筹谋,方可成就佳作。篮球乃团队之艺,协作共进,方显力......
  • 供应链场景使用ClickHouse最佳实践
    关于ClickHouse的基础概念这里就不做太多的赘述了,ClickHouse官网都有很详细说明。结合供应链数字化团队在使用ClickHouse时总结出的一些注意事项,尤其在命名方面要求研发严格遵守约定,对日常运维有很大的帮助,也希望对读者有启发。目前供应链数字化ck集群用来存储实时数据,先通过下面......
  • 【AI应用探讨】—生成对抗网络(GAN)应用场景
    目录1.图像生成2.数据增强3.图像编辑与风格转换4.视频生成5.游戏设计6.其他领域1.图像生成应用场景:艺术创作:艺术家和设计师使用GAN生成的图像作为创作的灵感,创造出新颖、独特的艺术品。GAN可以生成具有特定风格的画作,如油画、水彩画等,为艺术创作提供新的可能......
  • flexbox布局使用场景
    flexbox又称弹性布局,目标是提供一个更有效的布局,对齐方式主要思想:父元素能够调整子元素的宽度,高度,排列方式,从而更好的适用布局空间1、水平垂直居中对齐justify-content主轴对齐方式flex-start(默认值):左对齐flex-end:右对齐center:居中space-between:两端对齐,项目之间的间隔......
  • 性能测试场景设计
    简介性能测试场景设计是指定义和创建用于评估系统性能的模拟场景的过程。这些场景通常包括模拟用户行为、负载模式和使用情况,以便在实际环境下测量系统的性能表现。性能测试场景设计的目标是模拟真实世界中的使用情况,以便评估系统在不同条件下的性能、稳定性和可靠性。性能测试......
  • 【python学习】第三方库之tensorflow的定义、功能、使用场景、代码示例和解释
    引言tensorFlow是一个开源的软件库,最初由GoogleBrain团队的研究员和工程师开发,用于数值计算和大规模机器学习tensorFlow提供了丰富的API来支持各种计算任务,并且能够轻松地在多种计算设备上进行部署,包括CPU、GPU和TPU文章目录引言一、安装`tensorflow`第三方......
  • 36岁,大龄剩男,聊聊2024的上半年......
    不知道我在等什么,也不知道这样等了多久,相信看到这句话的你,可能也是一头雾水吧!还是以往的风格写到哪算哪,写东西真的是看感觉和心情都具备,写出来的东西才更有灵性,或者说更容易引起共鸣吧!我在逃避?可以这么说,但也不完全是,在一部分事情开始收尾的时候,情绪脑就占据了主导地位,就是想......
  • 自动化接口测试用例简单描述
    1.比如创建任务,每次都需要一个name,而且不可重复,可以random随机生成name,作为前置脚本使用:"name":"${job_name}",//namenow_time=DateFormatUtils.format(newDate(),"yyyyMMdd_HHmmss_SSS");random_number=RandomUtils.nextInt(0,1000000);affix=now_time+&......
  • Java身份证识别接口在打车场景的应用
    曾几何时,滴滴打车似乎成了打车一族的首选,评论有好有坏。近几日,美团打车在上海的首秀还不错。为了吸引更多司机加入,美团还设置了新人推荐奖。根据美团打车司机端的信息显示,3月20和3月31日期间,司机每邀请一名新司机,并且新司机完成8单,即可拿到100元奖励。根据美团的宣传,其首日接......