Tyk API Gateway是一个绿色安全、免费开源的轻量级API网关软件,为开发人员门户和API管理仪表板提供完整生命周期API管理平台,使用这款网关软件用户能够完全控制你的API,可以自由设置API访问权限,从而保证网络的安全性;Tyk API Gateway功能强大、专业实用,使用这款软件用户可以创建多个API,可应用于多个密钥的安全策略,创建密钥可以将配额和速率限制应用于API或者可以从安全策略继承设置,通过该API网关软件可以有效控制和保护网络的访问安全,有需要的朋友可以下载使用。
使用任何协议: REST,SOAP,GraphQL,gRPC和TCP。
行业标准身份验证:OIDC,JWT,承载令牌,基本身份验证,客户端证书等。
开放的API标准:将您的Swagger和OAS2 / 3文档导入Tyk中的脚手架API。
超高性能:低延迟和仅单个CPU即可实现数千rp的水平和垂直扩展。
内容中介:转换所有内容,从请求或响应标头到在SOAP和GraphQL之间转换。
可扩展的插件体系结构:通过以您选择的语言(从Python到Javascript到Go或任何支持gRPC的语言)编写插件来定制Tyk的中间件链。
速率限制和配额:保护您的上游免受过载和/或对每个消费者施加限制。
API版本控制-可以在特定时间和日期轻松设置和弃用API版本。
粒度访问控制-在每个版本和操作的基础上授予对一个或多个API的访问权限。
阻止列表/允许列表/被忽略的端点访问-逐个版本对访问点实施严格的安全模型。
Analytics日志记录-记录有关谁在使用您的API的详细使用情况数据(仅原始数据)
CORS-为某些API启用CORS,以便用户可以进行基于浏览器的请求
Webhooks-针对诸如配额违反和身份验证失败之类的事件触发Webhooks
IP允许列表-阻止对非信任IP地址的访问,以实现更安全的交互
重载-可以动态更改Tyk配置,并重新启动服务,而不会影响任何活动请求
Kubernetes本机声明性API:使用开源Tyk运算符(更多信息参见OSS部分)
RESTFul API
众多访问协议开箱即用。
费率限制
配额的执行
粒度访问控制
钥匙到期日
API版本管理
黑名单/白名单/忽略端点访问。
分析和监测
网络钩
IP白名单
零停机时间重启
通知和活动
向后兼容性
Tyk测试指南
对于测试,主要问题之一是如何在表达性,可扩展性,可重复性和性能之间保持平衡。关于是否应该编写集成或单元测试,是否应该进行模拟,是否应该先编写测试,之后还是之后编写测试等问题,有无数的讨论。由于永远找不到正确的答案,在不断增长的代码基础上,许多人开始介绍自己的方法和独特的测试助手。即使查看我们很小的代码库,您也可以找到3-4种编写相同测试的方法。
本文档介绍了Tyk测试框架和有关编写测试的统一准则。
测试框架的要点是:
所有测试都通过完整的HTTP堆栈运行HTTP请求,与用户执行的操作相同
测试定义逻辑与测试运行程序分开。
仪表板,RPC和Bundler的官方模拟
位于“ github.com/TykTechnologies/tyk/test”包中的框架。参见其API文档https://godoc.org/github.com/TykTechnologies/tyk/test
让我们通过示例学习:
直接Github链接
现在,将其与以前的Go风格方法进行比较:
直接Github链接
请注意,在最后一种“经典”方式中,我们仅定义了一个测试用例,而在我们的新框架中,我们定义了6个,所有这些都是可重复的,并且共享框架提供的相同断言和测试运行器逻辑。
现在,让我们逐一检查使用新框架编写的测试。
初始化测试服务器
核心思想之一是,测试应尽可能接近真实用户。为了实现它,框架为您提供了一种使用tykTestServer对象以编程方式启动和停止完整的Gateway HTTP堆栈的方法,如下所示:
ts := newTykTestServer()
推迟 ts。关闭()
创建新服务器时,它会初始化网关本身,在随机端口上启动侦听器,设置所需的全局变量等。这与启动网关进程时发生的情况非常相似,但是在这种情况下,您可以按需启动和停止它。
您可以使用很少的变量来配置服务器行为,例如通过提供tykTestServerConfigobjectnewTykTestServer作为参数来在单独的端口上设置控件API 。这是所有可能参数的列表:
要关闭服务器,只需调用tykTestServer#Closemethod即可,这将确保所有侦听器都将被正确关闭。
加载和配置API
您具有默认的最低限度的最低API定义(可以使用生成器功能进行配置)以设置测试所需的状态的基本思想。然后,API将被加载到网关中,并准备在测试中使用。
如果需要同时加载多个API,请buildAndLoadAPI支持可变数量的参数:buildAndLoadAPI(, , ...)
您也可以完全不带参数地调用它,在这种情况下,它将加载默认的API定义: buildAndLoadAPI()
实际上,此函数是2个较低级函数的混搭:buildAPI和loadAPI,都返回[]*APISpec数组。在某些情况下,您可能需要构建API模板,并进行一些较小的修改即可根据需要在不同的测试中加载它。因此它看起来像:
在API版本内更新变量可能很棘手,因为API版本对象位于Versionsmap内,并且禁止使用map值进行直接操作。为了简化此过程,有一个特殊的helper updateAPIVersion,可以像这样使用:
在某些情况下,通过Go结构更新API定义可能会有些复杂,您可能需要直接通过JSON解封更新API定义:
运行测试
使用新的test程序包TestCase结构定义测试,该程序包结构允许您定义http请求详细信息和响应断言。例如,使用指定的标头{Method: "GET", Path: "/", Headers: validPassword, Code: 200}告诉对路径的GET请求/。发出请求后,它将声明具有给定值的响应状态代码。
tykTestServer提供了一个测试运行程序,该运行程序根据规范生成HTTP请求并进行断言。大多数情况下,您将要使用tykTestServer#Run(t *testing.T, test.TestCase...) (*http.Response, error)功能。请注意,它使用可变数量的参数,因此,如果您需要传递多个测试用例,请像上面的示例一样传递它:[]test.TestCase{,}...,最后加3个点。
此外,还有RunEx具有完全相同定义的函数,但是在内部它使用overrideDefaults和hotReload选项的不同组合多次运行测试用例(现在为4)。如果您需要测试紧密依赖于热重载功能的功能(例如重载API,加载插件包或侦听器本身),这可能会很方便。
无论Run和RunEx也返回最后一个测试用例响应和错误,在情况下,如果你需要它。
更改配置变量
在许多情况下,测试取决于各种配置变量。您可以直接在config.Global对象上更新它们,并使用resetTestConfig函数恢复默认配置。
上游测试服务器
您可能会注意到默认API已经针对一些为测试目的而创建的上游模拟。上游保留testHttpAny变量的URL ,但是在大多数情况下,您不需要它,因为默认情况下创建的API已经嵌入了它。默认情况下,此上游模拟将成功响应任何url,并且响应将以以下格式包含请求的详细信息:
请注意,它包含最终请求的详细信息,因此,例如,如果您需要测试URL重写功能,原始请求的URL将不同于上游模拟的URL,则可以使用以下内容进行断言:BodyMatch:“ Url”:“” 。还要注意我们如何使用简单的BodyMatch字符串断言来验证JSON响应。
也有一些具有特定行为的特殊URL:
/get仅接受GET请求
/post仅接受POST请求
/jwk.json 用于从upsteram下载JWK令牌的情况
/ws 用于测试WebSockets
/bundles 内置插件包网络服务器,下面有更多详细信息
协同处理插件测试
如果要使用Python,Lua或GRPC插件,则需要将捆绑清单文件和脚本打包到ZIP文件,将它们上传到外部文件Web服务器上的某个位置,然后将Gateway指向捆绑位置。
我们的测试框架包括内置的捆绑文件服务器,为简单起见,您仅提供捆绑文件的内容,它将自动将其作为ZIP文件进行服务器处理。
创建map[string]string具有文件内容的对象,其中键为文件名
呼叫registerBundle("", )将返回唯一的捆绑ID。
创建API时,将其设置spec.CustomMiddlewareBundle为由返回的包IDregisterBundle
加载pythonauth插件的示例:
创建用户会话
您可以通过调用createSession函数来创建类似于API的用户会话:
如果您可以使用默认设置,也可以不带参数调用它 createSession()
如果您需要创建会话对象而不将其添加到数据库中,例如,如果您需要通过API显式创建密钥,则可以使用createStandardSession()函数,该函数返回*user.SessionState对象。
自定义上游模拟
如果您需要创建自定义的上游测试服务器,例如,如果您需要自定义的TLS设置来进行相互TLS测试,则最简单的方法是使用标准的Gonet/http/httptest程序包并覆盖spec.Proxy.TargetURLAPI URL来测试服务器。
模拟仪表板
还没有任何特定对象可以模拟仪表板,但由于Dashboard是标准的HTTP服务器,因此您可以使用类似于“自定义上游模拟”部分中所述的方法:
模拟RPC(混合)
当Gateway在Hybrid模式下工作时,它将使用gorpc库通过RPC通道与MDCB实例进行通信。您可以使用startRPCMock和stopRPCMock函数来模拟RPC服务器。startRPCMock在内部设置所需的配置变量以启用RPC模式。
DNS模拟
在内部测试中,我们将覆盖默认的网络解析器,以使用自定义DNS服务器模拟,并使用强大的github.com/miekg/dns库进行创建。域->通过映射helpers_test.go文件内部设置的IP映射。默认情况下,您可以访问域:localhost,host1.local,host2.local和host3.local。访问所有未知域将引起恐慌。
使用DNS模拟意味着您可以在多个域上使用API创建测试,而无需修改计算机/etc/hosts文件。
测试框架
上述框架的使用不受Tyk Gateway的限制,并且可在各种Tyk项目中使用。主要构建块是测试运行程序。
通过覆盖其变量,您可以调整跑步者的行为。例如,http运行程序可以如下所示:
http处理程序的单元测试可以是:
该软件包已经导出了上述情况的功能:
func TestHttpServer(t testing.TB, baseURL string, testCases ...TestCase)
func TestHttpHandler(t testing.TB, handle http.HandlerFunc, testCases ...TestCase)
CIMCO Edit
276.25 MB/2020-08-17CIMCOEditV5是CIMCO软件公司专为数控编程而设计的专业软件,该软件以其强大的功能、低廉的价格而风靡欧美,它有强大而实用的数控编辑功能、文件的智能比较、刀位轨迹的三维模拟、DNC传输等功能。其完全的Windows界面,一目了然的地址颜色,强大的在线帮助,会使您爱不释手。
CKplayer网页播放器
336 KB/2020-08-17ckplayer是一款在网页上播放视频的免费的网页播放器,功能强大,体积小巧,跨平台,使用起来随心所欲。CKplayer网页播放器主要以adobe的flash(所使用的版本是CS5)平台开发,ckplayer同时也支持html5的视频播放。
WordPress
6.7 MB/2020-08-17WordPress是一种使用PHP语言开发的博客平台,用户可以在支持PHP和MySQL数据库的服务器上架设自己的网志。也可以把WordPress当作一个内容管理系统(CMS)来使用。
Discuz论坛
4.05 MB/2020-08-17Discuz!Board(以下简称Discuz!,中国国家版权局著作权登记号2003SR6623)是一个通用的论坛软件系统,用户可以在不需要任何编程的基础上,Discuz论坛通过简单的设置和安装
Guns后台管理系统
12.5 MB/2020-08-17Guns后台管理系统是一款项目快速开发管理系统网站搭建模板,基于SpringBoot2开发,内置主控面板、组织架构、用户管理、机构管理、职位管理、权限管理、基础数据、系统功能
狂雨小说cms
7.8 MB/2020-08-17狂雨小说是一款体积轻量、简单易用的轻量级小说网站搭建模板,基于ThinkPHP5.1+MySQL的技术开发,网站搭建和部署便捷简单,通过该模板用户可以快速搭建一个属于自己的小说内
Slidev(开发幻灯片展示)
8.52 MB/2020-08-17Slidev是一款非常专业且优秀的开发幻灯片展示软件,作为基于Web的幻灯片制作和演示软件,非常适合开发人员使用,可帮助他们专注于在Markdown中编写内容,软件功能强大,拥有HTML
魔众短链接系统
27.5 MB/2020-08-17魔众短链接系统是一款绿色安全、免费开源的短链接生成网站搭建模板,基于PHP+Mysql开发,可帮助用户快速搭建属于自己的短链接生成网站,该网站界面简洁美观、对SEO非常友好,功
CIMCO Edit
建站专家网站建设系统
Turbo C 2.0库函数速查
PPTV网络电视系统
中英繁公司企业智能自助建站源码
宾馆酒店饭店网站建设模板ASP源码
XOOPS 简体中文版 2.0.3 for Unix
SaurusCMS
Deluge For Linux
我的棋牌官网原版2025版
上阳棋牌最新版
全民炸金花app游戏
棋牌游戏中心手游
三晋棋牌老版本
威尼斯棋牌官网最新2025版本
麒麟棋牌手机版
威尼斯棋牌官网最新956
三晋棋牌攉龙手游
您可能感兴趣的专题
男生必备
男生们看过来!
安卓装机必备
女生必备
女生必备app是拥有众多女性用户的手机软件,作为一个女生,生活中像淘宝、京东这类线上购物软件可以说是少不了的,小红书这种穿搭、化妆分享平台也很受欢迎,类似于西柚大姨妈、美柚这种专为女生打造的生理期app更是手机必备,还有大家用的最多拍照美颜app是绝对不能忘记的,除此之外对于一些追星女孩来说,微博也是一个必不可少的软件。超多女生必备软件尽在下载吧!
迅雷看看使用教程
迅雷看看播放器是一款多功能在线高清多媒体视频播放器,支持本地播放与在线视频点播,采用P2P点对点传输技术,可以在线流畅观看高清晰电影。不仅如此,迅雷看看不断完善用户交互和在线产品体验,让您的工作与生活充满乐趣。
驱动精灵
驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能,也是大家日常生活中经常用到的实用型软件之一了。
拼音输入法
对于电脑文字输入,拼音输入法是一种非常受欢迎的输入法,搜狗拼音输入法、百度拼音输入法、QQ拼音输入法、谷歌拼音输入法、紫光拼音输入法、智能拼音输入法等,你在用哪款呢?一款好用适合自己的拼音输入法一定对您平时帮助很大!下载吧收集了最热门国人最喜欢用的拼音输入法给大家。
b站哔哩哔哩怎么使用
很多人都喜欢在b站哔哩哔哩上观看视频,不单是因为可以提前看到一些视频资源,B站的一些弹幕、评论的玩法也是被网友们玩坏了!下面下载吧小编带来了b站哔哩哔哩怎么使用的教程合集!希望能帮到你啦!
抖音短视频app
抖音短视频app,这里汇聚全球潮流音乐,搭配舞蹈、表演等内容形式,还有超多原创特效、滤镜、场景切换帮你一秒变大片,为你打造刷爆朋友圈的魔性短视频。脑洞有多大,舞台就有多大!好玩的人都在这儿!