练习接口测试详细步骤

最近一段时间学了Python语言,重新学了 Java,js,html语言,CSS,linux,一堆测试工具;唉~

在接触接口测试过程中补了很多课,

终于有点领悟接口测试的根本;

偶是个实用派~,那么现实中没有用的东西,基本上我都不会有很大的概念;

下面给的是接口测试的统一大步骤,其实就是让我们对接口测试有一个整体的概念,我们要做或学习接口测试,应该从那些地方着手,也就是告诉你,百度搜索了半天接口测试之后,我还是没有概念,那怎么办呢,那么下面这些步骤就是,你需要把接口测试拆开来了解的步骤;

如第一步,百度之后,要研究什么是resful,怎么个增删改查;

这些步骤都可以拆开来,反复实践,等把这些步骤都拆开来,实践完了,你的接口测试也就通透了,通杀所有接口测试

接口测试:Http类,webservice类  其实大同小异

找一个你自己的项目,没人做过接口测试的也可以,这样你可以自己想明白 怎么测,而不是用别人的思想,思想。。。最重要,可是没有思路到有思路的路程并不长,只是你要开始做这个事情,相信我,会很快,你发现自己确实很聪明~~~~~~

声明:我的这些东西之所以能入门,主要归功于乙醇大神的接口测试概念和冯xx朋友的不吝赐教以及网络上的各种散碎思想;

第一步: 先要明白你要测什么? 本质就是增,删,改,查。(学名叫 resful);

第二步:先用网上推荐的工具来感觉一下(比如:postman, 比如:SoapUI)

第三步:get, post, put, delete 大概怎么个用法,比如传参(比如 json串),怎么看结果(这些确实需要你有些技术基础的,比如 端口,返回值,编码类型)

第四步:那么,那么,我们学了语言,那就来用用吧(一定要拿写好的接口例子来看看,要不然,你不知道用这个语言的什么包或什么函数来帮我们获取到URl的数据等...)

第五步:那么我们加入框架吧(Unittest),这样和前面你的老版本,自创的那一版对比一下,会感触~~,然后明白为什么用框架, 实践确实是个有意思的事情;

第六步:把你的那些参数放入数据库,或者excel等等 实现数据驱动;倒腾吧

第七步:优化你的代码,反复反复倒腾 重构,你应该在通往 python高手的路上了

第八步:当然如果你会Java但是并不会用它写接口测试,那么把这些用例变成Java吧

第九步:那么你还能干嘛,还多着呢,思考:你现在这个接口是否只测试了A接口,那么B接口能测试吗? 比如C调用A接口,那么C是一个接口呢? 是吗~~ 你能分辨出来吗,把它弄清楚,如果不是接口,或者它是什么,能测试吗,怎么测试?

第十步:自己做一个假的接口(Moco):最好和你现在的项目结合的,比如开发正在开发的(和开发沟通);自己测试

第十一步:自己写一个接口(可以先按照之前开发开发好的接口,照葫芦画瓢一个,那也要画,必须画,谁叫你是做测试的,知己知彼呀~),先简单,后复杂,主要倒腾清楚原理就行,反正你也不做开发(当然如果你想做开发,那去做开发吧,别在这浪费时间);自己测试

第十二步: 开始倒腾 测试第二个接口,这次你直接从第六步开始就行(代码优美可不是一天炼成的)

如果你倒腾的很细的话,本人认为倒腾三个接口应该很够了,最后一定记得拿你这个知识到市场去卖钱哟;科技是第一生产力~~

其实,其实 有了这个基础 应该倒腾自动化的其他就不难了

 第一版 unittest 框架源码

 1 # Lawsuit_interface_unittest.py2 # coding:utf-83 4 import json5 import unittest6 from suds.client import Client7 8 9 class Lawsuit_interface_testing(unittest.TestCase):
10 
11     def setUp(self):
12         self.url = "http://.....:8080/sys/webservice/sysNotifyTodoWebService?wsdl"
13         self.client = Client(self.url) #
14 
15     def tearDown(self):
16         pass
17 
18     def test_getTodo(self):
19 
20         notify_TodoGetContext = self.client.factory.create(
21             'notifyTodoGetContext')
22         notify_TodoGetContext.otherCond = ""
23         notify_TodoGetContext.pageNo = 1
24         notify_TodoGetContext.rowSize = 3
25         notify_TodoGetContext.targets = json.dumps(
26             {"LoginName": "xiaoming"})
27         notify_TodoGetContext.type = 1
28         notify_TodoAppResult = self.client.service.getTodo(
29             notify_TodoGetContext)
30         returnState = notify_TodoAppResult.returnState
31         self.assertEqual(returnState, 2)
32 
33     def test_sendTodo(self):
34 
35         notify_TodoSendContext = self.client.factory.create(
36             'notifyTodoSendContext')
37         notify_TodoSendContext.appName = "Lawsuit"
38         notify_TodoSendContext.createTime = "2015-11-27 15:32:39"
39         notify_TodoSendContext.key = ''
40         notify_TodoSendContext.link = 'http://wwww.baidu.com'
41         notify_TodoSendContext.subject = 'Lawsuit_testing'
42         notify_TodoSendContext.modelId = '123456789'
43         notify_TodoSendContext.modelName = "Lawsuit"
44         notify_TodoSendContext.targets = json.dumps(
45             {"LoginName": "xiaoming"})
46         notify_TodoSendContext.type = 1
47         notify_TodoAppResult = self.client.service.sendTodo(
48             notify_TodoSendContext)
49         returnState = notify_TodoAppResult.returnState
50         self.assertEqual(returnState, 2)
51 
52     def test_deleteTodo(self):
53 
54         notify_TodoRemoveContext = self.client.factory.create(
55             'notifyTodoRemoveContext')
56         notify_TodoRemoveContext.appName = "Lawsuit"
57         notify_TodoRemoveContext.modelId = '123456789'
58         notify_TodoRemoveContext.key = ''
59         notify_TodoRemoveContext.modelName = "Lawsuit"
60         notify_TodoRemoveContext.optType = 1
61         notify_TodoRemoveContext.targets = json.dumps(
62             {"LoginName": "xiaoming"})
63         notify_TodoAppResult = self.client.service.deleteTodo(
64             notify_TodoRemoveContext)
65         returnState = notify_TodoAppResult.returnState
66         self.assertEqual(returnState, 2)
67 
68     def test_setTodoDone(self):
69 
70         notify_TodoRemoveContext = self.client.factory.create(
71             'notifyTodoRemoveContext')
72         notify_TodoRemoveContext.appName = "Lawsuit"
73         notify_TodoRemoveContext.modelId = '123456789'
74         notify_TodoRemoveContext.key = ''
75         notify_TodoRemoveContext.modelName = "Lawsuit_testing"
76         notify_TodoRemoveContext.optType = 1
77         notify_TodoRemoveContext.targets = json.dumps(
78             {"LoginName": "xiaoming"})
79         notify_TodoAppResult = self.client.service.setTodoDone(
80             notify_TodoRemoveContext)
81         returnState = notify_TodoAppResult.returnState
82         self.assertEqual(returnState, 2)
83 
84 
85 if __name__ == '__main__':
86     unittest.main()

 第二版 使用excel 数据驱动

 1 # Lawsuit_interface_unittest_excel_v1.1.py2 # coding:utf-83 4 import unittest5 import json6 import xlrd7 from suds.client import Client8 import time9 import sys10 11 12 class Lawsuit_interface_testing(unittest.TestCase):13 14     def setUp(self):15         self.url ='http:// xx?wsdl'16         self.client = Client(self.url)17         self.xlsfile = r'lawsuit_casedata.xlsx'18         self.excel_data(self.xlsfile)19 20     def tearDown(self):21         pass22 23     def test_getToDO(self):24 25         self.Cannot_find_file(self.xlsfile)26 27         notify_TodoGetContext = self.client.factory.create(28             'notifyTodoGetContext')29         notify_TodoGetContext.pageNo = self.pageNo_value30         notify_TodoGetContext.rowSize = self.rowSize_value31         # another way to json32         # notify_TodoGetContext.targets = "{ \"LoginName\": \"xiaoming\" }"33         notify_TodoGetContext.targets = self.targets_value34         notify_TodoGetContext.type = self.ptype_value35 36         notify_TodoAppResult = self.client.service.getTodo(37             notify_TodoGetContext)38         returnState = notify_TodoAppResult.returnState39 40         print returnState41         self.assertEqual(returnState, 2)42 43     def test_sendTodo(self):44         self.Cannot_find_file(self.xlsfile)45 46         notify_TodoSendContext = self.client.factory.create(47             'notifyTodoSendContext')48         notify_TodoSendContext.appName = self.appName_value49         notify_TodoSendContext.createTime = self.creatime_value50         # notify_TodoSendContext.key = ''51         notify_TodoSendContext.link = self.link_value52         notify_TodoSendContext.subject = self.subject_value53         notify_TodoSendContext.modelId = self.modelId_value54         notify_TodoSendContext.modelName = self.modelName_value55         notify_TodoSendContext.targets = self.targets_value56         notify_TodoSendContext.type = self.ptype_value57         notify_TodoAppResult = self.client.service.sendTodo(58             notify_TodoSendContext)59         returnState = notify_TodoAppResult.returnState60         self.assertEqual(returnState, 2)61 62     def test_deleteTodo(self):63         self.Cannot_find_file(self.xlsfile)64 65         notify_TodoRemoveContext = self.client.factory.create(66             'notifyTodoRemoveContext')67         notify_TodoRemoveContext.appName = self.appName_value68         notify_TodoRemoveContext.modelId = self.modelId_value69         # notify_TodoRemoveContext.key = ''70         notify_TodoRemoveContext.modelName = self.modelName_value71         notify_TodoRemoveContext.optType = self.optType_value72         notify_TodoRemoveContext.targets = self.targets_value73         notify_TodoAppResult = self.client.service.deleteTodo(74             notify_TodoRemoveContext)75         returnState = notify_TodoAppResult.returnState76         self.assertEqual(returnState, 2)77 78     def test_setTodoDone(self):79         self.Cannot_find_file(self.xlsfile)80 81         notify_TodoRemoveContext = self.client.factory.create(82             'notifyTodoRemoveContext')83         notify_TodoRemoveContext.appName = self.appName_value84         notify_TodoRemoveContext.modelId = self.modelId_value85         # notify_TodoRemoveContext.key = ''86         notify_TodoRemoveContext.modelName = self.modelName_value87         notify_TodoRemoveContext.optType = self.optType_value88         notify_TodoRemoveContext.targets = self.targets_value89         notify_TodoAppResult = self.client.service.setTodoDone(90             notify_TodoRemoveContext)91         returnState = notify_TodoAppResult.returnState92         self.assertEqual(returnState, 2)93 94     def excel_data(self, xlsfile):95 96         self.Cannot_find_file(self.xlsfile)97         book = xlrd.open_workbook(xlsfile)98         api_sheet = book.sheet_by_index(0)99         nrows = api_sheet.nrows
100         for i in range(1, nrows):
101             caseID = api_sheet.cell(i, 0)
102             appName = api_sheet.cell(i, 1)
103             creatime = time.strftime(
104                 time.strftime('%Y-%m-%d %X', time.localtime(time.time())))
105             link = api_sheet.cell(i, 3)
106             subject = api_sheet.cell(i, 4)
107             modelId = api_sheet.cell(i, 5)
108             modelName = api_sheet.cell(i, 6)
109             targets = api_sheet.cell(i, 7)
110             ptype = api_sheet.cell(i, 8)
111             pageNo = api_sheet.cell(i, 9)
112             rowSize = api_sheet.cell(i, 10)
113             optType = api_sheet.cell(i, 11)
114             # returnstatue = api_sheet.cell(i, 12)
115             # message = api_sheet.cell(i, 13)
116             if api_sheet.cell(i, 0).ctype != 0:
117                 # caseID_value=str(int(caseID.value))
118                 self.appName_value = appName.value
119                 self.creatime_value=creatime
120                 self.link_value = link.value
121                 self.subject_value = subject.value
122                 self.modelId_value = modelId.value
123                 self.modelName_value = modelName.value
124                 # print type(targets)
125                 self.targets_value = targets.value
126                 # print type(targets.value)
127                 self.ptype_value = int(ptype.value)
128                 self.pageNo_value = int(pageNo.value)
129                 self.rowSize_value = int(rowSize.value)
130                 self.optType_value = int(optType.value)
131 
132                 # returnstatue_value=returnstatue.value
133                 # message_value=message.value
134             else:
135                 return 0
136             #    data1=
137 
138         # return data1
139 
140     # exception
141 
142     def Cannot_find_file(self, xlsfile):
143         try:
144             foo = open(self.xlsfile)
145         except EnvironmentError as err:
146             print "Unable to open file:{}".format(err)
147             sys.exit(1)
148 
149 
150 if __name__ == '__main__':
151     unittest.main()

 最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

文档获取方式:

这份文档,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

以上均可以分享,只需要你搜索vx公众号:程序员雨果,即可免费领取

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/75987.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Beats:安装及配置 Metricbeat (二)- 8.x

这篇文章是继文章 “Beats:安装及配置 Metricbeat (一)- 8.x” 的续篇。你可以先阅读之前的那篇文章再继续阅读这篇文章。我们在这篇文章中继续之前的探讨。 使用 fingerprint 来代替证书 在实际的使用中,我们需要从 Elasticsear…

SB树,看这一篇就够了

算法拾遗三十九SB树及跳表 SB树SB树四种违规类型总结 SB树Code 跳表 SB树 SB树是基于搜索二叉树来的,也有左旋和右旋的操作,只是不同于AVL树,它也有它自己的一套平衡性方法。 任何以叔叔节点为头的子树的节点个数不小于自己任何一个侄子树的…

如何自己开发一个前端监控SDK

最近在负责团队前端监控系统搭建的任务。因为我们公司有统一的日志存储平台、日志清洗平台和基于 Grafana 搭建的可视化看板,就剩日志的采集和上报需要自己实现了,所以决定封装一个前端监控 SDK 来完成日志的采集和上报。 架构设计 因为想着以后有机会…

【软考】系统集成项目管理工程师(三)信息系统集成专业技术知识③

一、云计算 1、定义 通过互联网来提供大型计算能力和动态易扩展的虚拟化资源;云是网络、互联网的一种比喻说法。是一种大集中的服务模式。 2、特点 (1)超大规模(2)虚拟化(3)高可扩展性&…

UG\NX二次开发 计算一个向量的反向向量UF_VEC3_negate

文章作者:里海 来源网站:王牌飞行员_里海_里海NX二次开发3000例,里海BlockUI专栏,C\C++-CSDN博客 简介: UG\NX二次开发 计算一个向量的反向向量UF_VEC3_negate 效果: 代码: #include "me.hpp"void ufusr(char* param, int* retcode, int paramLen) {UF…

什么是Docker和Docker-Compose?

Docker的构成 Docker仓库:https://hub.docker.com Docker自身组件 Docker Client:Docker的客户端 Docker Server:Docker daemon的主要组成部分,接受用户通过Docker Client发出的请求,并按照相应的路由规则实现路由分发…

服务器基准测试实践:SysBench的搭建与基本使用

🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。 🏆数年电商行业从业经验,AWS/阿里云资深使用…

VS编译.cu文件源文件无法打开matrix.h和mex.h问题

配置好cu和VS相关库文件后CUDA程序仍然报错:无法打开matrix.h和mex.h,解决办法: (1)这两个头文件是matlab中的,可能无法直接在VS中调用,可以通过添加外部依赖项的方法将matlab中的头文件的文件路…

【数据结构与算法系列4】长度最小的子数组 (C++ Python)

给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 连续子数组 [numsl, numsl1, ..., numsr-1, numsr] ,并返回其长度**。**如果不存在符合条件的子数组,返回 0 。 示例 1: 输入&…

物理层-数据链路层-网络层-传输层-会话层-表示层-应用层

Go网络编程 网络协议 从应用的角度出发,协议可理解为“规则”,是数据传输和数据的解释的规则。假设,A、B双方欲传输文件。规定: 第一次,传输文件名,接收方接收到文件名,应答OK给传输方&…

JVM基础面试题

JDK、JRE、JVM的关系 JVM Java虚拟机,它只识别.class类型文件,它能将class文件中的字节码指令进行识别并调用操作系统向上的API完成动作。 JRE Java运行时环境。它主要包含两部分:Jvm的标准实现和Java的一些基本类库。相对于JVM来说,JRE多出来…

电阻和电容

目录 1、常见的电阻器 2、电容 ​编辑 1、常见的电阻器 对于电阻需要了解三个参数(查询电阻的数据手册): 1、封装:就是电阻的尺寸或者大小,看焊在你的pcb板上是否合适。 2、标称:电阻的电阻大小、精度、…

Unity入门教程||创建项目(上)

一、介绍 目的:通过尝试制作一款使用玩家角色把小球弹飞的简单小游戏,熟悉使用Unity进行游戏开发的基本流程。 软件环境:Unity 2017.3.0f3,Visual Studio 2013 二、创建新项目 1,启动Unity后将出现一个并列显示Pro…

动静态库生成使用

🔥🔥 欢迎来到小林的博客!!       🛰️博客主页:✈️林 子       🛰️博客专栏:✈️ Linux       🛰️社区 :✈️ 进步学堂       &#x1f6f0…

Purple Pi OH(Debian/Ubuntu)使用python控制gpio

本文分享的是Purple Pi OH开源主板搭载Debian/Ubuntu系统如何使用python控制gpio。 Purple Pi OH作为一款兼容树莓派的开源主板,采用瑞芯微RK3566 (Cortex-A55) 四核64位超强CPU,主频最高达1.8 GHz,算力高达1Tops,支持INT8/INT16,支持Tensor…

leetcode 129. 求根节点到叶节点数字之和

2023.9.8 好久没写回溯题了,有点陌生ToT。 本题思路就是通过回溯保存所有根节点到叶子节点的路径,然后将这些路径转化为数字并全部相加。 直接看代码: /*** Definition for a binary tree node.* struct TreeNode {* int val;* Tre…

Mavan进阶之多模块(聚合)

文章目录 Maven 多模块(聚合)非父子关系的多模块项目 Maven 多模块(聚合) Maven 继承和聚合是 2 个独立的概念。工程与工程之间可能毫无关系,也可能是继承关系,也可能是聚合关系,也可能既是继承…

用python实现基本数据结构【01/4】

说明 如果需要用到这些知识却没有掌握,则会让人感到沮丧,也可能导致面试被拒。无论是花几天时间“突击”,还是利用零碎的时间持续学习,在数据结构上下点功夫都是值得的。那么Python 中有哪些数据结构呢?列表、字典、集…

seata的部署和集成:部署Seata的tc-server、微服务集成seata、TC服务的高可用和异地容灾

seata的部署和集成 一、部署Seata的tc-server 1.下载 首先我们要下载seata-server包,地址在http😕/seata.io/zh-cn/blog/download.html 当然,课前资料也准备好了: 2.解压 在非中文目录解压缩这个zip包,其目录结构…

Kafka3.0.0版本——消费者(消费者组初始化流程图解)

一、消费者组初始化流程图解 每个consumer都发送JoinGroup请求,如下图所示: 选出一个consumer作为leader,如下图所示: 把要消费的topic情况发送给leader 消费者,如下图所示: leader会负责制定消费方案…