使用.NET Core 编写端到端测试

什么是端到端测试

端到端测试也称E2E,与单元测试、集成测试、组件测试、契约测试相比,端到端测试的目的是验证整个系统是否满足业务目标,而不管使用的组件架构如何,为了实现这一点,系统被视为一个黑盒子,测试尽可能多地运用完全部署的系统,通过GUI和服务API等公共接口进行操作。

由于端到端测试更面向业务,因此它们通常使用业务可读的DSL,以域的语言表达测试用例。同样的,端到端测试也是大部分国内互联网的唯一测试手段,通常由测试部门通过人工方式在浏览器点击一个个的按钮进行测试。

在微服务体系架构中,由于微服务架构包括针对相同行为的更多移动部件,因此端到端测试通过添加服务之间的间隙的覆盖来提供价值。这使得在服务之间传递的消息的正确性更加可靠,但也确保正确配置了任何额外的网络基础结构,如防火墙,代理或负载平衡器。

端到端测试还允许微服务架构随着时间的推移而发展。随着对问题域的了解越来越多,服务可能会分裂或合并,端到端测试可以确保系统提供的业务功能在如此大规模的体系结构重构中保持不变。

使用.NET Core 编写端到端测试用例

先决条件Visual Studio 2017或更高版本、.NET Core SDK 2.1或更高版本、Windows 10 、Web Driver

安装Web Driver

安装VS2019、.NET Core SDK 、 Windows10 不再赘述,主要讲一下如何下载安装WebDriver

本文使用Edge浏览器进行E2E测试,对于Chrome ,请在此处下载http://chromedriver.storage.googleapis.com/index.html

大部分的情况下,你的win10应该会预装微软的Edge 浏览器,预装的浏览器一般情况是18 版本,你可以打开Edge 浏览器,在右上角的··· 按钮点击设置,滑动鼠标滑轮到最下方,如果是18.XXX 则说明是18版本,否则是17版本。

对于18版本,以管理员模式运行命令行或powershell,并键入以下命令
DISM.exe /Online /Add-Capability /CapabilityName:Microsoft.WebDriver~~~~0.0.1.0

对于18之前的版本,在此右侧选择你的edge版本的驱动

打开VS

打开VS2019,新建xunit测试项目,安装Nuget包Selenium.WebDriver引用到你的测试项目中

在默认的测试方法里添加以下代码:

 var driver = new EdgeDriver();
driver.Url = "https://www.bing.com";
var element = driver.FindElementById("sb_form_q");
element.SendKeys(".NET Core");
element.SendKeys(Keys.Enter);
Assert.Contains(".NET Core", driver.Title);
driver.Quit();

你需要添加命名空间引用


using OpenQA.Selenium;
using OpenQA.Selenium.Edge;

上述代码是

  • 启动Edge浏览器

  • 访问必应网站,找到搜索框

  • 找到文本框

  • 模拟输入文本.NET Core

  • 模拟输入Enter 键

  • 判断当前的浏览器的tab页面标题中包含我们搜索的关键词.NET Core

  • 最后,关闭浏览器

至此一个简单的模拟用户操作浏览器的单元测试已经完成,先关闭所有的Edge浏览器。运行测试,测试会自动打开浏览器,执行上述操作,最后关闭

扩展阅读

对于CI服务器,你需要为其安装运行该测试的环境,对于Jenkins,你需要添加一个win10的Slave节点,并安装对应的WebDriver组件;
对于TeamCity,你需要将一个agent代理安装在一个windows10服务器。

最佳实践

你应该尽可能的使用多的浏览器以测试兼容性和模拟行为,所以,你需要在CI的代理服务器上安装对应的浏览器,目前支持大部分的主流浏览器:
Safari 
Chrome 
Firefox 
IE

你需要下载对应浏览器的驱动程序

你可以直接在你的测试项目中,new ChromeDriver 等浏览器驱动实例,如果未安装,会引发异常,在异常内容里,会有驱动的下载地址

原文地址:https://www.cnblogs.com/mt-netcore/articles/10911498.html

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 
640?wx_fmt=jpeg


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

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

相关文章

Manacher

Manacher(马拉车算法) Manacher算法主要用于求解回文串问题,能够统计出以每一个位置为中心的回文串的个数,效率极高。 模板 题目描述 Manacher算法的实现过程: 1.在字符串每两个字符之间插入一个分隔符。 2.iii从111到nnn求解P[i]P[i]P[i…

.NET/C# 使用 ConditionalWeakTable 附加字段(CLR 版本的附加属性,也可用用来当作弱引用字典 )...

如果你使用过 WPF/UWP 等 XAML UI 框架,那么应该了解到附加属性的概念。那么没有依赖属性支持的时候如何做附加属性的功能呢?你可能会想到弱引用。但这需要做一个弱引用字典,要写的代码还是非常麻烦的。本文介绍 .NET 的 ConditionalWeakTabl…

P4548 [CTSC2006]歌唱王国

P4548 [CTSC2006]歌唱王国 题目描述 Solution 这一题在《具体数学(混泥土数学)》里讲得很详细了啊,这里相当于总结一下,想具体了解的直接看书吧。 我们先考虑字符集为222的情况,设硬币正面朝上(H)(H)(H)的概率为pp…

在C#中使用Json.Net进行序列化和反序列化及定制化

序列化(Serialize)是将对象转换成字节流,并将其用于存储或传输的过程,主要用途是保存对象的状态,以便在需要时重新创建该对象;反序列化(Deserialize)则是将上面的字节流转换为相应对…

SRM614 Div1 Hard

SRM614 Div1 Hard 题目描述 Solution 显然有: E(x,y)(E(x−1,y)E(x,y−1))/21E(x,y)(E(x-1,y)E(x,y-1))/21 E(x,y)(E(x−1,y)E(x,y−1))/21 直接高斯消元时间复杂度O((nm)3)O((nm)^3)O((nm)3)。 可以发现这种做法十分浪费,消元之后会有大量冗余元素&…

知乎个人精选 | 绝版的专业书到哪里找最快最高效?

估计书到用时方恨少是很多软件开发人员的苦恼,当然我这里提到的"少"表示稀少,买不到之意~比如你加入一家政府机构或给为政府机构服务的公司做开发,主要做传统软件,对方需要使用 Win Forms做开发,你打算系统性…

HUD4035Maze

HUD4035Maze 题目描述 Solution 很容易写出期望的式子: 令fif_ifi​表示从iii号节点开始期望几步走出迷宫。 令pi1−ki−eip_i1-k_i-e_ipi​1−ki​−ei​表示选择走向其他边的概率。 令did_idi​表示iii号结点的度数。 fikif1pi∑fjdi10eiAnsf1f_ik_if_1p_i\sum…

正反案例介绍SOLID原则

一.概述SOLID五大原则使我们能够管理解决大多数软件设计问题。由Robert C. Martin在20世纪90年代编写了这些原则。这些原则为我们提供了从紧耦合的代码和少量封装转变为适当松耦合和封装业务实际需求的结果方法。使用这些原则,我们可以构建一个具有整洁,…

LOJ#2145. 「SHOI2017」分手是祝愿

LOJ#2145. 「SHOI2017」分手是祝愿 题目描述 Solution 首先有一个结论: 灯的状态序列a1,a2...ana_1,a_2...a_na1​,a2​...an​唯一对应了一个最优操作序列b1,b2...bnb_1,b_2...b_nb1​,b2​...bn​。 因为编号最大的灯只能由开关自己来改变。 因此,…

ASP.NET Core 中的静态文件

1.前言当我们创建Core项目的时候,Web根目录下会有个wwwroot文件目录,wwwroot文件目录里面默认有HTML、CSS、IMG、JavaScript等文件,而这些文件都是Core提供给客户端使用的静态文件。但是这些静态文件需要在Core里面配置才可以对外公开访问。2…

LOJ#2542. 「PKUWC2018」随机游走

LOJ#2542. 「PKUWC2018」随机游走 题目描述 Solution 去过一个点集中所有节点的期望时间不好求,考虑min−maxmin-maxmin−max容斥,转化为求第一次到达某一个点集的期望时间。 我们对于每一个点集sss,都求出fif_ifi​表示从iii结点到点集s…

基于Kebernetes 构建.NET Core技术中台

今天下午在腾讯云社区社区分享了《基于Kubernetes 构建.NET Core技术中台》,下面是演讲内容的文字实录。我们为什么需要中台我们现在处于企业信息化的新时代。为什么这样说呢?过去企业信息化的主流重心是企业内部信息化。但现在以及未来的企业信息化的主…

P3706 [SDOI2017]硬币游戏

P3706 [SDOI2017]硬币游戏 题目描述 Solution 前置技能: P4548 [CTSC2006]歌唱王国 歌唱王国就是n1n1n1的情况。 我们用类似的方法,先考虑两个串的情况。 设SAS_ASA​表示AAA串最先选到的概率,设SBS_BSB​表示BBB串最先选到的概率。 则…

RedLock 实现分布式锁

并发是程序开发中不可避免的问题,根据系统面向用户、功能场景的不同,并发的重视程度会有不同。从程序的角度来说,并发意味着相同的时间点执行了相同的代码,而有些情况是不被允许的,比如:转账、抢购占库存等…

AGC030D - Inversion Sum

AGC030D - Inversion Sum 题目描述 Solution 考虑dpdpdp&#xff0c;fi,jf_{i,j}fi,j​表示第iii个位置的数大于第jjj个位置的数的概率。 对于每一个询问修改贡献即可。 时间复杂度O(nqn2)O(nqn^2)O(nqn2)。 #include <vector> #include <list> #include <m…

[翻译] NumSharp的数组切片功能 [:]

原文地址&#xff1a;https://medium.com/scisharp/slicing-in-numsharp-e56c46826630翻译初稿&#xff08;英文水平有限&#xff0c;请多包涵&#xff09;&#xff1a;由于Numsharp新推出了数组切片这个牛逼的功能&#xff0c;所以.NET社区距离拥有强大的开源机器学习平台又近…

P3978 [TJOI2015]概率论

P3978 [TJOI2015]概率论 题目描述 Solution 设CnC_nCn​表示nnn个节点的树的个数&#xff08;卡特兰数&#xff09;&#xff0c;SnS_nSn​表示nnn个节点的所有树的叶子的个数和。 Cn∑i0n−1CiCn−i−1[n0]Sn2∑i0n−1SiCn−i−1[n1]C_n\sum_{i0}^{n-1} C_iC_{n-i-1}[n0]\\ …

Visual Studio 2019 16.1发布,更快更高效

Visual Studio 2019 16.1 已正式发布&#xff0c;可以看到&#xff0c;新版本的启动速度有了显著的提升&#xff0c;还节省了不少的内存空间。主要更新如下&#xff1a;IDE现已公开发布 Visual Studio IntelliCode&#xff0c;并且可以随任何支持 C#、C、TypeScipt/JavaScript …

牛顿迭代法

牛顿迭代法 定义 在一般意义下&#xff0c;牛顿迭代法可以求出一个函数的零点&#xff0c;而在多项式意义下&#xff0c;牛顿迭代能够求出&#xff1a;给定一个G(x)G(x)G(x)&#xff0c;求F(x)F(x)F(x)&#xff0c;使得G(F(x))≡0(modxn)G(F(x)) \equiv 0\;\;\;(mod\;\;x^n)G…

.NET Core 3.0之创建基于Consul的Configuration扩展组件

经过前面三篇关于.NET Core Configuration的文章之后&#xff0c;本篇文章主要讨论如何扩展一个Configuration组件出来。如果前面三篇文章没有看到&#xff0c;可以点击如下地址访问.NET Core 3.0之深入源码理解Configuration(一).NET Core 3.0之深入源码理解Configuration(二)…