用ABP只要加人即可马上加快项目进展(二) - 分工篇 - BDD实战篇 - .NET Core里跑Specflow...

这是<如何用ABP框架快速完成项目 >系列中的一篇文章。

 

BDD很赞!比TDD先进很多,能够大大提高编码效率。

 

上一篇文章说了如何在.NET Core里安装Specflow. 然而文章成果只到了hello world级别。

要想真的和实际业务结合,比如要能够IOC new class实例和能够调用数据库和第三方服务。用专业术语来说,就是能跑集成测试和单元测试。这就是这篇文章的目的了。

 

和.NET不一样的是,.NET Core取消了App.config,并且整个机制都改变了。导致很多.NETer转.NET Core的时候一脸懵逼

 

所以在.NET Core下运用BDD/TDD也不一样了。这篇文章就讲讲如何配置。

 

  1. 原来app.config一分为二,specflow部分划为specflow.json,在这篇文章里有提到。其他划为appsetting.json

  2. 文件格式也从原来的xml文档变为json文档。

  3. 同时还需要把appsetting.json文件属性设置为如下

    640?wx_fmt=png

  4. 读取配置的方式也从原来的system.configmanager.appsetting变为 IConfigurationRoot[key]方式。示例代码如下:

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    public class AppEnvConfiguration : ITransientDependency
    {
        private readonly IConfigurationRoot _appConfiguration;       
        public bool IsEnableADFS => bool.Parse(_appConfiguration["ExternalAuth:WsFederation:IsEnabled"]);
        public AppEnvConfiguration(IAppConfigurationAccessor configurationAccessor)
        {
            _appConfiguration = configurationAccessor.Configuration;
        }
    }

      

 

Q&A:

  1. 为啥集成测试里面数据库返回结果数目总是0?

    答:检查一下测试项目目录\bin\Debug\netcoreapp2.1目录下有没有appsetting.json这个文件,没有则看看有没有做上面的第3步

 

通过以上步骤,终于可以调用数据库和第三方服务来跑集成测试了。然而还有一个很大问题,单元测试跑不过啊!!!

 

为什么会跑不过呢?

因为BDD和TDD不一样。

TDD的Test case是可以直接继承ABP里面的XXXTestBase基类的,这个基类里面提供了IOC new class实例等一系列很有用的方法。

但是BDD的Specflow却是Test Case和Step Definition分离的。在Step Definition里面是无法调用XXXTestBase基类里的这些方法的。

 

那怎么办呢?

照如下步骤办即可:

  1. 新增一个TestBaseWrappers文件夹

  2. 然后根据实际业务从最小化角度来建立TestBaseWrapper类

  3. 在这个类里面写IOC代码

  4. 然后再Step Definition类里调用这些TestBaseWrapper类。

 

Q&A:

  1. 为什么不用Step Definition类直接继承ABP里面的XXXTestBase基类呢?

    答:首先会报错。然后我在这篇文章里面说到,我们只有一个Step Definition类,然后分布在多个文件,通过Partial关键字来组合。所以如果Step Definition这么大的一个类来直接继承TestBase基类,然后在TestBase基类里构造函数来IOC初始化所有要调用Service类实例,第一会遇到性能问题,第二会遇到循环调用问题,这画面太美不敢看啊。

  2. 报错:Message: System.InvalidOperationException : Mapper not initialized. Call Initialize with appropriate configuration. If you are trying to use mapper instances through a container or otherwise, make sure you do not have any calls to the static Mapper.Map methods, and if you're using ProjectTo or UseAsDataSource extension methods, make sure you pass in the appropriate IConfigurationProvider instance.如何解决?

    答:不要用MapTo扩展方法去Map,而要使用IObjectMapper,ABP官网十分清晰明确的说明了,要想用Unit Test就必须Always use IObjectMapper, do not use MapTo extension methods

    640?wx_fmt=png

    所以这道题是我面试必选题之一!!凡是在ABP项目里面使用MapTo扩展方法而不是使用IObjectMapper的,绝对是没写过单元测试的!这样子一下就可以判断出面试者有没有写过单元测试了!!!

  3. 为啥你讲了这么多测试方面的知识,开发的知识却很少?

    答:因为:

    1. 无论是TDD还是BDD,都是测试驱动,先写测试代码然后再写业务开发代码

    2. 讲ABP开发的文章太多,不缺我一个,然而讲用ABP去做BDD/TDD的文章却很少,很需要我去补充

    3. 我现在自己创业,自负盈亏,不像很多开发人员,每月固定有工资,旱涝保收,可以放心的去空谈理论。所以我一切以出活为主,以交付实际成果为第一目标,而不是以理论和空谈为目标。BDD/TDD可以避免把宝贵的时间投入到项目实际上不需要的理论方面,可以保证我做的东西是客户所想要的。所以我强烈推荐BDD这个核武器。

    4. 在上一点里面我说出了核心,如何保证你所做的东西就是客户想要的?这就是BDD与TDD相比,BDD最大的优点啦!!!毕竟,绝大多数情况下,业务人员会比开发人员更了解业务!


原文地址: https://www.cnblogs.com/adalovelacer/p/abp-quickly-delivery-16-run-specflow-at-dot-net-core.html

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

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

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

相关文章

【做题记录】CodeForces 做题记录

链接放的是洛谷上的链接&#xff0c;难度就是 CF 上的评分。 <details><summary>$\texttt{solution}$</summary></details> CF10D LCIS 难度&#xff1a;\(\tt{2800}\) 求两个串的最长公共上升子序列。\(n\le 500\) $\texttt{solution}$ 严重虚高题&am…

周末狂欢赛2(冒泡排序,概率充电器,不勤劳的图书管理员)

狂欢2T1&#xff1a;冒泡排序题目题解CODET2&#xff1a;概率充电器题目题解CODET3&#xff1a;不勤劳的图书管理员题目题解CODE我不这么认为。。。。 T1&#xff1a;冒泡排序 题目 下面是一段实现冒泡排序算法的 C代码&#xff1a; for(int i1; i<n; i)for(int j1; j&l…

P5659-[CSP-S2019]树上的数【贪心】

正题 题目链接:https://www.luogu.com.cn/problem/P5659 题目大意 给出nnn个点的一棵树&#xff0c;每个节点上有一个数字&#xff0c;你每次可以选择一条边删除然后交换连接的两个点的数字&#xff0c;在删完所有数字后设pip_ipi​表示数字iii所在节点编号&#xff0c;要求使…

Mine Sweeper II

Mine Sweeper II 题意&#xff1a; 给你两个大小为 n * m 的扫雷图 A, B&#xff0c;要求通过最多 n * m/2 次转换&#xff08;转换指 把一个不是雷的格子变成雷&#xff0c; 或者把一个是雷的格子变成空白格&#xff09;&#xff0c;使得 B图的值 和 A图的值相等&#xff08…

YBTOJ洛谷P3195:玩具装箱(斜率优化dp)

传送门 文章目录前言解析代码前言 斜率优化dp&#xff0c;就是利用斜率优化的dp &#xff08;逃&#xff09; 解析 第一道斜优的题 分析题目 设sumisum_isumi​为1-i的c的前缀和 容易写出dp转移式&#xff1a; dpimin(dpj(sumi−sumji−j−1−L)2)dp_imin(dp_j(sum_i-sum_ji-…

01.微服务系列介绍

微服务系列实践 .NET CORE在开始之前呢&#xff0c;还是得废话一下&#xff0c;毕竟还是需要介绍一下这个系列我们要实现什么样的一套服务架构&#xff0c;也让大家能初步的有一个了解&#xff0c;后续实践起来也有一个完整的概念&#xff0c;相对也会容易的多。互联网架构演变…

【做题记录】Atcoder 做题记录

链接放的是洛谷上的链接。 <details><summary>$\texttt{solution}$</summary></details> ARC083F \(n\times n\) 的正方形上有 \(2n\) 个小球&#xff0c;第 \(i\) 个在 \((x_i,y_i)\)。 有 \(n\) 个 A 类机器人&#xff0c;第 \(i\) 个在 \((0,i)\)&a…

Walker

Walker 题意&#xff1a; 一个区间[0,n]&#xff0c;区间上有两个点&#xff0c;坐标分别是pos1&#xff0c;pos2&#xff0c;速度分别是v1&#xff0c;v2&#xff0c;这两个点是在移动&#xff0c;可以随时改变移动方向&#xff0c;问当区间的每一块均被一个点或两个点移动覆…

P7078-[CSP-S2020]贪吃蛇【贪心,队列】

正题 题目链接:https://www.luogu.com.cn/problem/P7078 题目大意 有nnn条贪吃蛇&#xff0c;第iii条长度为aia_iai​&#xff0c;每次最长的那条蛇可以选择吃掉最短的那条蛇&#xff0c;然后自己的长度减去其长度&#xff0c;也可以不吃然后结束游戏。 现在询问在所有蛇都希…

【网络流】最大流问题(EK算法带模板,Dinic算法带模板及弧优化,ISAP算法带模板及弧优化)上下界网络流

本blog重点是代码网络流的相关概念流网络(flow network)流(flow)网络的流残留网络(residual network)增广路径(augmenting path)Edmonds-Karp算法思想bfs模板调用EK&更新残留网络流模板luogu的AC代码(EK版)Dinic算法思路时间复杂度证明bfs模板模板1模板2dfs模板不带弧优化模…

YBTOJ:消除格子(二分图匹配)

文章目录题目描述解析代码题目描述 在一个n*n的矩阵中&#xff0c;有 k个格子中有杂物&#xff0c;现在你有一种能力&#xff0c;一次可以消除一行或一列格子中的杂物&#xff0c;问你至少需要几次可以将这些杂物全部消完。 解析 看起来像是网络流&#xff0c;结果竟然是二分图…

Rainbond 5.0正式发布, 支持对接管理已有Kubernetes集群

今天很高兴的向大家宣布Rainbond v5.0正式发布&#xff0c;Rainbond是开源的企业应用云操作系统&#xff0c;支撑企业应用的开发、架构、交付和运维的全流程&#xff0c;通过无侵入架构&#xff0c;无缝衔接各类企业应用&#xff0c;底层资源可以对接和管理IaaS、虚拟机和物理服…

【做题记录】P4211 [LNOI2014]LCA

P4211 [LNOI2014]LCA 题意 给出一个 \(n\) 个节点的有根树(编号为 \(0\) 到 \(n-1\)&#xff0c;根节点为 \(0\))。 一个点的深度定义为这个节点到根的距离 \(1\)。 设 \(dep[i]\) 表示点 \(i\) 的深度&#xff0c;\(LCA(i,j)\) 表示 \(i\) 与 \(j\) 的最近公共祖先。 有 \(m\)…

Fibonacci

Fibonacci 题意&#xff1a; f[i]表示第i位的斐波那契数列 给定n&#xff0c;求 题解&#xff1a; 这种题一开始没什么思路&#xff0c;那么枚举就行 g(x,y) 1 是当x * y为偶数时 x * y为偶数说明&#xff1a; x是偶数&#xff0c;y也是偶数 x是奇数&#xff0c;y是偶数 而…

P4383-[八省联考2018]林克卡特树【wqs二分,树形dp】

正题 题目链接:https://www.luogu.com.cn/problem/P4383 题目大意 nnn个点的一棵树&#xff0c;要求删除kkk条边然后接上kkk条边权为000的边后形成的树上选择一对(p,q)(p,q)(p,q)从ppp走简单路径到qqq的权值和最大。 n,k≤3105n,k\leq 3\times 10^5n,k≤3105 解题思路 其实可…

YBTOJ:幻灯片(二分图匹配)

文章目录题目描述数据范围解析解析题目描述 有一堆透明的幻灯片堆叠在一起&#xff0c;每个幻灯片上的随机一个位置会有幻灯片的标号。 因为幻灯片是透明的&#xff0c;所以堆叠在一起的幻灯片使得这些标号分不清各自对应的幻灯片。 现在要求你求出那些能够确定对应关系的幻灯片…

基于.NET Standard的分布式自增ID算法--美团点评LeafSegment

概述前一篇文章讲述了最流行的分布式ID生成算法snowflake&#xff0c;本篇文章根据美团点评分布式ID生成系统文章&#xff0c;介绍另一种相对更容易理解和编写的分布式ID生成方式。实现原理Leaf这个名字是来自德国哲学家、数学家莱布尼茨的一句话&#xff1a;There are no two …

Normal Data Structure Tricks

放一些比较常见的数据结构处理技巧&#xff0c;会一点一点补上来。 P3313 [SDOI2014]旅行 给你一个 \(10^5\) 长的序列&#xff0c;每个点有颜色 \(c\) 和权值 \(v\)。 有修改和查询操作&#xff0c;修改可以为修改一个点的颜色或权值&#xff0c;查询一段区间内颜色为 \(c\) 的…

[费用流专题]Going Home,Minimum Cost,工作安排

文章目录T1&#xff1a;Going Home题目题解CODET2&#xff1a;Minimum Cost题目题解CODET3&#xff1a;工作安排题解CODET1&#xff1a;Going Home 题目 On a grid map there are n little men and n houses. In each unit time, every little man can move one unit step, e…

2021牛客OI赛前集训营-提高组(第五场)C-第K排列【dp】

正题 题目链接:https://ac.nowcoder.com/acm/contest/20110/C 题目大意 一个长度为nnn的字符串SSS&#xff0c;SSS中存在一些???&#xff0c;有N/O/I/PN/O/I/PN/O/I/P四个字符作为字符集&#xff0c;每对相邻的字符会产生不同的贡献&#xff0c;现在要求所有权值不小于xxx…