如何测试非固定型概率算法P=p(1+0.1*N)

在上一期讲到如何测试概率型业务接口之后,产品又提出了新的需求,总结来说是非固定性概率算法,有一套“算法”来计算用户下一次中奖的概率。

同样是一个概率获奖的活动,用户话费一定数额金币,有概率获奖,奖项不详细叙述了。

需求更改:用户获奖概率P=p(1+0.1*N),其中p表示原始的中奖概率,N表示连续不中奖的次数,N最大为5。还额外提出一条需求,用户不能连续中奖,为了简化过程每种礼物的中奖概率以1%位单位。

接口:三个接口:一、抽奖接口;二、获取活动配置接口(包括各类礼物配置和信息);三、个人活动详情(个人信息、抽奖次数、获奖情况)

测试工具:Java(不唯一),通过把三个接口提供的功能封装为方法,然后通过方法调用去获取数据,进而统计得到的结果。

测试时间:一天。

其中测试的重点还是概率,但是因为此次的概率有两项:不能连续中奖+不确定概率,所以难点在于如何测试用户获奖概率P=p(1+0.1*N)这个算式需求实现的正确性。

经过讨论大概给出了两个方案:

方案一

通过数学计算,获得用户综合中奖概率P和p对应关系,然后设定不同数值的p,进行大量抽奖测试,统计结果与理论计算结果比较,标准依然采用上一期概率型业务接口的相同的测试标准。

方案二

首先进行大量测试(比如1万次),记录每次用户抽奖的实际情况,比如1(中奖)和0(不中奖),然后计算P和p与N的关系表格,获取某一个p的情况下,N与P的关系,比如连续2次不中奖之后,下一次中奖的概率Pn。然后统计抽奖记录里面“1000”和“1001”出现的次数,计算实际测试中连续两次不中奖,下一次中奖概率Ps,比较Pn和Ps的大小,标准依然采用上一期概率型业务接口的相同的测试标准。

以上两个方案依然会遇到与上一期相同的问题,测试量较大,耗时较长。因为此次方案概率以用户为单位,所以在使用多线程进行测试的过程中需要讲每一个线程单独绑定一个用户。

  • 总结一下,这类需求其实应该直接白盒测试的。

上期文章看往期精选第9篇。

往期文章精选

  1. java一行代码打印心形
  2. Linux性能监控软件netdata中文汉化版
  3. 接口测试代码覆盖率(jacoco)方案分享
  4. 性能测试框架
  5. 如何在Linux命令行界面愉快进行性能测试
  6. 图解HTTP脑图
  7. 写给所有人的编程思维
  8. 如何测试概率型业务接口
  9. httpclient处理多用户同时在线
  10. 成为杰出Java开发人员的10个步骤
  11. 将swagger文档自动变成测试代码

公众号地图 ☢️ 一起来~FunTester

转载于:https://my.oschina.net/u/3973795/blog/3100676

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值