热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

接口测试之概述1

1、接口测试的技术栈(1)协议HTTP、websocket、Dubbo、gRPC;(2)接口测试的工具:PostMan,JMeter;(3)接口测试的框架;(4)MockServe

1、接口测试的技术栈

(1)协议 HTTP、websocket、Dubbo、gRPC;

(2)接口测试的工具:PostMan,JMeter;

(3)接口测试的框架;

(4)MockServer;

2、 接口测试是目前所有测试人员必须掌握的技术栈

(1)流量回放;

(2)混沌工程(混沌理论);

(3)全链路监控&分布式;

3、接口测试的发展历程

(1)2016年,前后端分离开发模式在企业全面落地;如youyuxi. VUE

(2)2019年之后,UI

   A.走向了API的自动化测试;

   B.开发模式的彻底;

(3)2021年:

   A.走向了API的自动化测试

   B.开发模式的彻底

   C.微服务的架构通信模式

4、接口测试(又称为API测试)的开发模式

主流的架构:单体架构 (单体架构发展到SOA面向服务的架构)、分布式的架构、微服务架构

(1)单体架构的开发模式:单体架构的模式是把前后以及所有的业务场景的代码都整合到一起,其模式如图(如电路的串联):

 

 如:图书管理系统:

业务场景:大家看到自己喜欢的书,然后下单,支付,购买;

业务模块:书籍管理、支付模块、账户模块、物流模块。

(2)微服务架构模式:微服务架构就是根据业务场景,把每个独立的业务场景单独分离成一个服务,这样服务和服务之间通信,通信通过REST API 或者gRPC的协议来进行交互,其模式如图:

 

 如:电路的并联。

(3)常规开发模式中接口测试的流程:

A.开发同学:

一、前端程序员把代码写完,后端程序员把代码写完;

二、前端和后端进行联调(前端把输入的账户和密码拿到,然后发送给(HTTP的协议)后端);

三、后端拿到前端发送的数据进行验证;

Element是一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库,其网址如下:

https://element.eleme.cn/#/zh-CN/component/input

B.测试同学:

一、验证这个过程中业务逻辑是否能够成功;

 

5、金字塔模型

 

在金字塔的模型中,测试分为三个维度来进行思考,分别是单元,服务和UI三个层级。

服务层的测试,在服务层的测试维度中,主要针对的是业务接口的测试,来验证接口功能是否完整,如内部逻辑,异常处理。这样的目的是验证接口它是否稳定,所以接口的测试相对而言比较容易而且更加高效。测试用例的维护成本也低。

有很多主流的测试工具都可以做接口测试,如PostMan,JMeter,SoupUi等,除了工具还有在Python语言中很多的第三方的库都是可以来做接口测试的,如:urllib,requests,aiohttp等。

在金字塔的模型中:

(1)金字塔模型把开发测试的模型分为三层,分别是单元测试、接口测试、和UI测试;

(2)unit:单元测试 services:接口测试(API自动化测试) UI:UI测试(功能测试、UI自动化测试);

(3)越底层的,越应该投入更多的精力去保障,越上层的,投入少量的精力去保障。

6、微服务构架

(1)微服务构架模式

saas化:Software As A Service 软件即服务;

pass化:Platform As A Service 平台即服务。

(2)微服务的架构通信模式

微服务的通信模式使用的方式有两种:

A.采用基于REST API(交互模式)的轻量级的基于HTTP的协议;

B.使用的是gRPC的协议。

7、协议(HTTP、websocket、gRPC)

HTTP即“超文本传输协议”诞生了 :web1.0、 web2.0 、移动互联网。

(1)版本(HTTP)

A.目前业界使用的主流的版本是1997年发布的HTTP/1.1的版本;

B.目前HTTP最新的版本是:HTTP/2.0(gRPC的协议就是基于HTTP/2.0的版本来进行设计的) 但是业界使用的版本是HTTP/1.1。

(2)网络分层

TCP/IP分层管理:TCP/IP协议按层次主要为:应用层,传输层,网络层,数据链路层。

A.应用层

应用层决定了向用户提供应用服务时通信的活动。而HTTP的协议和gRPC的协议就是属于应用层的协议。

B.传输层

应用层的下层是网络传输层,提供处于网络连接中的两台计算机之间的数据传输,传输层UR核心的协议就是TCP/IP的协议。

C.网络层

主要是用来处理网络上流动的数据包,所谓数据包就是网络传输中的最小单位,在该层协议中,规范了通过怎样的路径到达目标计算机,并且把数据包传送给对方。

D.链路层

主要是处理连接网络的硬件部分,如操作系统,硬件设备的驱动等。

(3)websocket协议(auth2.0):客户端与服务端始终保持持久连接不会断开。

物联网:互联网技术的深度发展,互联网使用的协议都是websocket的协议

如:微信

客户端:手机微信、电脑微信,都是客户端;

服务端:腾讯的微信服务器。

(4)TCP/IP通信传输流过程图:

 

 (5)三次握手

 

三次握手的意义:应用层的协议是为了上层应用之间的交互,但是不需要关注底层网络传输层之间的事情,所以为了数据传输的安全和保障,就设计了三次握手。

如何理解三次握手:

A,第一次握手即服务端的确认:客户端发送数据出去,服务端需要确认我收到了;

B.第二次握手即服务端反馈:服务端告诉客户端,你发送的数据我这边确认收到了;

C.第三次握手即客户端确认:客户端需要向服务端再次反馈,客户端收到服务端的反馈了。

 (6)URL和URI

URI可以称为统一资源标识符,而URL是统一资源定位符。URI可以理解为标识某一个互联网的资源,而URL表示的资源的地点。

8、HTTP协议(是应用层的协议)协议本质上就是双方说的话彼此都可以理解(双方指客户端和服务端)

(1)在微服务的架构模式下,使用的也是轻量级的通信模式(REST API),在微服务的架构模式中,需要清楚的是它的通信可以分为同步通信模式和异步通信模式, 或者更加具体本质的说就是请

求/响应和异步请求/响应(发布/订阅模式)。

(2)REST API

A.Java:企业级开发领域具备非常强大的生命力,开发的技术栈非常完善,其中阿里的生态开发语言基本是Java

B.Python:数据分析,数据科学领域非常具备优势

C.Go:容器化的语言,应用在Docker和K8S的开发

D.PHP:轻量级的语言

E.Net:微软系列

场景:如果一个公司用三个语言开发,但是语言之间需要通信,需要数据传输,标准化就是REST API ,使用统一的标准来进行交互。

(3)HTTP完整的请求流程:

 

简要描述:第一步:客户端与服务端建立TCP连接;

第二步:客户端向服务端发送requst请求;

第三步:服务端response客户端响应回复给客户端;

第四步:客户端与服务端关闭请求。

发送Requests请求包括:请求地址、请求方法、请求头、请求参数(可能有,也可能没有)。

 

 

 

 Response回复包括:协议状态码、响应数据、响应头。

 

 

 

 

(4)持久连接(websocket协议)

在HTTP/1.0版本开始以及后面的版本中,有了持久连接,也就是keep-alive, 它的特点是只要客户端或者是服务端没有明确断开连接,那么就得一直保持TCP的连接请求,持久连接减少了TCP 连

接的重复连接和断开造成的性能损耗,减轻了服务端的负载,也提升了整体相求响应时间的性能。

 (5)gRPC协议:流式(stream)的数据

 9、通信模式

(1)同步通信:客户端发送请求给服务端,服务端必须得回应客户端的请求。同步通信又可以说是请求/响应的模式。

存在问题:

A.容易超时,客户端发送请求后,服务端迟迟没有回应客户端的请求;

B.如果请求是存在大的计算量和逻辑存在问题,就会导致请求堵塞,后面的都积压同步通信又可以说是请求/响应的模式

(2)异步通信:在异步的交互中,客户端和服务端互相不需要关注对方的存在,只需要关注对应的MQ的消息,客户端与服务端的交互主要是会通过MQ的消息中间间作为消息的传递来进行交

互的。(三大主流核心的MQ:RabbitMQ,Kafka(linkyin),ActivityMQ(alibaba)),所有的MQ都可以说是队列机制,也可以说是生产者消费者的模式。所谓队列机制,遵守先进先出的规则。生产者

消费者模式:生产后可以进行快速的消费。

 

 

 

场景:如下载500MB的文件,下载需要半小时,要求下载期间可以进行做其他事情,通信模式是属于异步请求。 

 




推荐阅读
  • Istio是一个用来连接、管理和保护微服务的开放平台。Istio提供一种简单的方式来为已部署的服务建 ... [详细]
  • 阿里首席架构师科普RPC框架
    RPC概念及分类RPC全称为RemoteProcedureCall,翻译过来为“远程过程调用”。目前,主流的平台中都支持各种远程调用技术,以满足分布式系统架构中不同的系统之间的远程 ... [详细]
  • websocket深入,tomcat,jetty服务器使用对比
    转载整理自https:www.zhihu.comquestion20215561http:www.open-open.comlibviewopen1435905714122.ht ... [详细]
  • 微服务之总体架构篇
    一、单体架构存在的问题缺点:1、难以维护:当单体应用业务不断迭代后代码量非常臃肿,模整个项目非常复杂,每次更改代码都可能带来新的bug;2、部署项目麻烦:庞大之后项目部署效率 ... [详细]
  • postmain报400_Postman测试@RequestBody发送请求时报400错误
    postman测试requestbody时碰到400错误图1原因:传参数如果不使用RequestBody,在使用Postman进行Post请求时,通常做 ... [详细]
  • 前面的已经介绍过如何用webpack打包一个项目,细心的人会发现,打包后想要项目运行起来必须要把打包后的项目上传到服务器中,或者静态的项目 ... [详细]
  • HTTP协议之总结展望篇
    文章目录HTTP2HTTP2内核HTTP3Nginx:高性能的Web服务器OpenResty:更灵活的Web服务器网络应用防火墙(WAF)CDN ... [详细]
  • 在这分布式系统架构盛行的时代,很多互联网大佬公司开源出自己的分布式RPC系统框架,例如:阿里的dubbo,谷歌的gRPC,apache的Thrift。而在我们公司一直都在推荐使用d ... [详细]
  • 阿里云监控URL的配置笔记
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了阿里云监控URL的配置笔记相关的知识,希望对你有一定的参考价值。有很多细节需要记录 ... [详细]
  • GithubGitea安装包pipinstalldjangowebsocket更改我的项目下asgi.py文件importosfromdjango.core.asgiimportg ... [详细]
  • 12 个提升程序员软技能与效率的必备工具。
    文章目录1.draw.io2.ProcessOn3.Excalidraw4.whistle5.EasyMock6.Fiddler7.GitHub统计8.墨刀9.蓝湖10.PxCoo ... [详细]
  • 服务注册中心到底应该选AP模型还是CP模型?
    当下,分布式系统正变得越来越重要,大型网站几乎都是分布式的。分布式系统的最大难点,就是各个节点的状态 ... [详细]
  • 基于.NET Core框架nacos的简单应用
    什么是Nacos?服务(Service)是Nacos世界的一等公民。Nacos支持 ... [详细]
  • 为什么需要WebSocket在HTTP协议中,所有的请求都是由客户端发起的,由服务端进行响应,服务端无法向客户端推送消息,但是在一些需要即时通信的应用中,又不可避免地需要服务端向客 ... [详细]
  • k8s入坑之路(14)scheduler调度 kubelet管理及健康检查
    kubelet主要功能Pod管理在kubernetes的设计中,最基本的管理单位是pod,而不是container。pod是kubernetes在容器上的一层封装,由一组运行在同一 ... [详细]
author-avatar
dotagod12
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有