灰太狼与红太狼抓羊 - 记一次应用云测试经历

2023-10-12 22:18

本文主要是介绍灰太狼与红太狼抓羊 - 记一次应用云测试经历,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

     灰太狼和红太狼(它们是用户)从羊羊村抓了6只羊放在羊圈(云)中,并且羊圈总共有5扇门。现在它们想吃羊,但是有一定的条件:

l   吃羊必须经过两个步骤:

u  将羊经过5扇门中任何其中一扇从羊圈中牵出

u  将羊吃掉

l   从同一扇门中可以分批次牵出15只羊不等。

l   总共能从羊圈中牵出5只羊。

l   抓出来的羊归属一旦确定,不能相互交换,即灰太狼的羊不能给红太狼吃,反之亦然。

l   从羊圈中抓羊的事情只有灰太狼能完成,如果红太狼想吃羊,必须要灰太狼去抓,并且灰太狼每经过一扇门,就要将抓来的羊中分一只给灰太狼,作为酬劳。

l   在羊从羊圈中牵出后,如果狼突然不想吃羊了,可以将羊放回羊圈中。

l   从同一扇门中牵出的,当前还没有吃掉的羊,如果想放回羊圈中,必须同时放回,不可以单独放回。

l   上述同一扇门中放回的羊,如果突然之间又想吃了,可以选择一次性将这些羊从羊圈中牵出。

l   在开始抓羊前,灰太狼和红太狼知道羊圈中总共有6只羊,但是在抓羊的过程中灰太狼和红太狼不知道羊圈中还剩余多少只羊。

 

我们要验证的是:

l  在满足上述条件的前提下,灰太狼和红太郎抓羊,吃羊都能正常进行。

l  当灰太狼和红太狼从羊圈中不管以哪种方式牵出了5只羊后,如果它们想牵出第6只羊,系统将给出警告:“牵羊失败,请从羊羊村再5只羊放在羊圈中!”

 

     现在我们来分析探索一下上述灰太狼与红太狼抓羊与吃羊模型该怎么测试,情况很复杂,原因主要分为以下几点:

l   灰太狼抓羊经过的门可以有5种选择。

l   5扇门(测试设备)在真实的测试环境中由于资源受限,无法达到这个要求。

l   红太狼要吃羊要靠灰太狼去抓,且要分给灰太狼一只,且没有一一配对原则存在。

l   羊不吃的情况还可以将羊放回羊圈,而且还有限制条件。

l   在抓羊未到6只得前提下,系统不能给出任何提示,灰太狼和红太狼也不能清点羊圈中羊的数量。

 

         情况复杂到我连完整的数据流程图都画不出来,所以如果按照场景测试方法,根本无法下手,即使能写出一些,也不可能做到高覆盖率或全覆盖率。还有其他办法吗,或许想到了组合测试,但仔细想想,组合测试也不适合,因为组合测试的对上述原因中的第二和第三点无能无力。杯具啊!看来只能妥协了,既然做不到全覆盖路径,看来只能测试基本路径了:

l   灰太狼能抓羊,吃羊。

l   红太狼能靠灰太狼抓羊,且自己能吃羊。

l   能将没吃的,且从同一扇门中牵出的羊送回羊圈。(这个需要通过后续其它门中牵出羊的数量来加以验证)

 

         为了保证云应用提供商的利益(不能牵出第6只羊),我们还必须对资源耗尽后(已经牵出了5只羊)的各种情况加以覆盖:

l   灰太狼再从羊圈中抓羊会失败。

l   红太狼委托灰太狼抓羊会失败。

l   从任何一扇门尝试抓羊都会失败。

 

         至此,测试能做的似乎也只能这样了,总觉得有些许遗憾,因为对于场景的覆盖还没有找到很好的办法加以全列举或组合列举,希望通过苦练用例设计的内功能在将来的某一天找到合适的方法来重新审视这个案例!

 

这篇关于灰太狼与红太狼抓羊 - 记一次应用云测试经历的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

zoj3820(树的直径的应用)

题意:在一颗树上找两个点,使得所有点到选择与其更近的一个点的距离的最大值最小。 思路:如果是选择一个点的话,那么点就是直径的中点。现在考虑两个点的情况,先求树的直径,再把直径最中间的边去掉,再求剩下的两个子树中直径的中点。 代码如下: #include <stdio.h>#include <string.h>#include <algorithm>#include <map>#

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测