软件测试之“支付功能”测试
Posted 起码@有故事
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了软件测试之“支付功能”测试相关的知识,希望对你有一定的参考价值。
01
测试思维
要分析测试点之前,我们先来梳理一下测试思维。总结来说,任何事物的测试思路都可以总结如下:
第一步:梳理产品的核心业务流程:明白这是个什么项目,实现了什么业务,以及是怎么实现的?
这个步骤一般是参考公司的需求文档来的,如果产品提供需求文档的同时提供了业务流程图,可以遵循流程图来梳理;如果产品没有提供流程图,就需要测试人员根据需求的理解自己画出流程图,达到梳理业务的目的。
第二步:根据流程进行模块细分,然后针对每个功能模块进行详细的测试点设计和提取。
这个单个功能的测试点提取要覆盖以下几个方面:
正常功能验证:优先覆盖正常的业务流程和功能验证,这其实也是单个功能的冒烟测试。冒烟测试先行,如果不通过,可以直接停止测试等开发修复后继续测试。
异常功能验证:为了更加贴近用户的使用产品,我们也要验证各种异常的场景,故意操作导致出错,检查系统的反馈和提示,保证用户操作失误的情况能够得到系统的友好指示。
因为有很多地方的操作都有可能会导致系统异常和报错,所以为了不漏测,我们需要找出所有可能导致异常的输入项和选项。所以就到了第三步:
第三步:针对具体功能,寻找每个输入项和步骤,从以下三个角度来分析测试点 。
-
长度,数据类型,必填项,重复
-
需求的约束条件 + 隐形需求
-
功能之间的交互
这其中就需要用到一些用例的具体设计方法了,比如场景法,等价类法,边界值法,错误推测法等等
第四步:考虑非功能测试点,包括界面、易用性、兼容性、安全性、性能压力
02
支付功能的测试点
基于上面的测试思路,我们可以分析得出“支付功能”测试点如下:
一、梳理支付的业务流程如下:
点击支付---> 选择支付方式 ---> 确认金额---> 输入密码 ---> 成功支付
完成这个流程测试,也就是完成了项目的冒烟测试!然后需要测试针对流程中的每个阶段和步骤,具体分析可能导致异常的测试点,所以我们按阶段和输入项来进行划分如下:
非现金支付时代,非现金支付已经成为了生活不可或缺的一部分,我们只需要一台手机便可走遍全国各地(前提是支付宝,微信有钱<00>),那么作为测试人员,支付测试也是非常重要的一环,那么下面我就结合一下我的工作中遇到的一些问题,总结一下常见的支付测试:
一:支付的分类:
首先,根据不同维度,通常我们可以把支付分为如下图所示的种类:
其次,一般来讲,线上支付分为两种消费模式。一种是直接支付金额,如淘宝,京东等购物网站,或是360云盘,视频会员等这种会员服务;另一种是充值购买金豆之类的虚拟币,在网站中使用虚拟币进行消费,比如游戏平台、花椒等产品!
二:功能测试
接下来就是测试方面的工作了,首先进行的是功能测试,那么我将边界值、等类划分、错误推测,因果图等各种测试方法相结合,整理出来了一套相对全面的测试案例,对支付功能进行测试,从而确保整个支付流程和涉及到的支付流程在任何情况下都能使用。
三:接口测试
明确整个支付流程所需要调用的接口,分清楚商家和第三方平台的接口以及参数的请求方式,包括对接口特定参数的加密,使用异常单号模拟支付,对服务端的检验等等
四:安全测试
支付都会涉及到金额,那么就需要考虑安全测试这个方面,支付请求的伪造,金额的恶意篡改,恶意模拟第三方接口来调用商家接口等,均是我们需要考虑清楚的问题
五:支付流程:如下图
六:测试点
支付流程测试点
1、付款金额和应付金额是否一致,(比如:扫描的支付二维码,和显示的应支付金额是否一致)。支付还是要走整个支付流程才行,从确认订单到最后的支付成功,任何一步都有可能有问题。
2、同一种支付方式,不同的支付入口(比如:如下图所示,支付宝有两个支付入口。即可通过扫描二维码支付,也可以通过支付宝网页支付。在测试过程中,两个入口都要覆盖到。
3、支付成功后,产品购买是否成功
(比如会员服务产品,购买后会员到期时间是否正常延迟;比如购买商品,支付成功后,订单状态是否更改,商品种类和数量是否正确等等)
4、支付成功后,用户的金额是否扣除成功
支付金额测试点
1.正常金额支付
2.金额的最小值:0.01
3.无意义的值:0元
4.最大金额:设置支付的最大金额
5.银行卡或微信等,设置每日最大消费金额或者单笔最大消费金额
6.银行卡或微信余额不足时支付
支付流程测试点
1.正常完成支付流程
2.调起订单后,取消订单
3.支付中断后,继续支付
4.支付中断后结束支付
5.单笔订单单笔支付
6.多订单合并支付
7.持续点击支付,是否会出现多次购买
支付方式测试点
1.支付宝支付
2.支付宝网页支付
3.微信支付
4.银行卡支付
优惠券或折扣(有一定的优惠)
支付中使用优惠券/折扣,应付金额和实际支付金额是否正确
优惠券/折扣是否是必选,是否可以不选择折扣
支付订单退款完成后,优惠券/折扣是否还能使用
坑一:页面显示的应付金额通过接口vip.product返回了,前端显示出来应付金额。但是,支付的二维码是通过接口vip.getPayUrl这个接口返回的,结果二维码扫出来的值和显示的应付金额不一样呀!!!最后问题是在于,vip.getPayUrl中取的是服务器缓存,导致二维码显示的金额跟前端展示的应付金额不一致。所以测试支付还是要走整个支付流程才行,从确认订单到最后的支付成功,任何一步都有可能有问题。
坑二:通过支付宝网站支付,支付成功后,页面没有跳转回原服务套餐网页。最后的原因是服务配置的return_url不正确,导致支付后,没有跳回原页面。如果测试用例覆盖不到这种场景,那么将会造成非常严重的线上事故。
测试开发系列之Python开发mock接口
本次测试开发系列给大家分享一下怎么用python开发mock接口。本次介绍下什么是mock接口,以及咱们开发之前需要做的准备。
什么是mock接口呢,举个栗子,你在一家电商公司,有查看商品、购物、支付、发货、收获等等等一大堆功能,你是一个测试人员,测测测,测到支付功能的时候,你就要调用第三方支付接口了,真实支付,直接扣你支付宝/微信/银行卡里面的钱了,这下大事不好,测个试还得把自己钱搭进去(当然一般公司都会报销测试的支付费用,但是走报销麻烦),还有一些大额支付的的,可能你账户里面根本就没那么钱,怎么办呢,这时候就要体现出一个高(zhuang)级(bi)测试工程师的价值来,自己写一个支付接口,来模拟第三方支付,反正支付接口就是你把金额传过来,然后扣你账户的钱,返回支付成功就可以了。等到和第三方支付平台联调的时候再去用真实接口进行支付。
下面就按照上面的例子开发一个mock接口,用来模拟支付,先捋一下业务逻辑,首先调用支付接口的时候,要把金额、用户id传进来,因为要知道哪个用户支付的,然后判断传入的金额和用户id是否合法,如果合法的话才会支付,不合法的就返回错误提示信息,这两个参数传入的都正确的话,继续往下走,判断用户余额是否充足,如果充足的话,支付成功,返回成功信息,不足的话,返回错误提示信息。业务逻辑就是这么简单,流程图看下面。
业务逻辑捋清楚了之后,就开始做开发前的准备,需要准备的东西:
1、安装好python3
2、pycharm
3、flask(python第三方模块,一个简单web框架)
使用python开发,python版本是python3,3点几都无所谓,直接去官网下载安装即可,写代码的工具用pycharm,百度搜pycharm官网,下载社区版,社区版不需要注册,安装完python之后,要把python的安装目录和安装目录下的scripts目录加到环境变量里面,把这两个目录加入到环境变量里面之后还有最后一步就是安装flask,flask怎么安装呢,如果你已经把上面的两个目录加入到环境变量里面了,直接在cmd命令行中执行pip3 install flask就可以安装flask了,安装完成后命令行中执行
上面命令执行不报错,flask安装成功,至此开发前准备完成。
以上是关于软件测试之“支付功能”测试的主要内容,如果未能解决你的问题,请参考以下文章