这是<如何用ABP框架快速完成项目 >系列中的一篇文章。
BDD很赞!比TDD先进很多,能够大大提高编码效率。
上一篇文章说了如何在.NET Core里安装Specflow. 然而文章成果只到了hello world级别。
要想真的和实际业务结合,比如要能够IOC new class实例和能够调用数据库和第三方服务。用专业术语来说,就是能跑集成测试和单元测试。这就是这篇文章的目的了。
和.NET不一样的是,.NET Core取消了App.config,并且整个机制都改变了。导致很多.NETer转.NET Core的时候一脸懵逼
所以在.NET Core下运用BDD/TDD也不一样了。这篇文章就讲讲如何配置。
原来app.config一分为二,specflow部分划为specflow.json,在这篇文章里有提到。其他划为appsetting.json
文件格式也从原来的xml文档变为json文档。
同时还需要把appsetting.json文件属性设置为如下
读取配置的方式也从原来的system.configmanager.appsetting变为 IConfigurationRoot[key]方式。示例代码如下:
1234567891011public
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:
为啥集成测试里面数据库返回结果数目总是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基类里的这些方法的。
那怎么办呢?
照如下步骤办即可:
新增一个TestBaseWrappers文件夹
然后根据实际业务从最小化角度来建立TestBaseWrapper类
在这个类里面写IOC代码
然后再Step Definition类里调用这些TestBaseWrapper类。
Q&A:
为什么不用Step Definition类直接继承ABP里面的XXXTestBase基类呢?
答:首先会报错。然后我在这篇文章里面说到,我们只有一个Step Definition类,然后分布在多个文件,通过Partial关键字来组合。所以如果Step Definition这么大的一个类来直接继承TestBase基类,然后在TestBase基类里构造函数来IOC初始化所有要调用Service类实例,第一会遇到性能问题,第二会遇到循环调用问题,这画面太美不敢看啊。
报错: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
所以这道题是我面试必选题之一!!凡是在ABP项目里面使用MapTo扩展方法而不是使用IObjectMapper的,绝对是没写过单元测试的!这样子一下就可以判断出面试者有没有写过单元测试了!!!
为啥你讲了这么多测试方面的知识,开发的知识却很少?
答:因为:
无论是TDD还是BDD,都是测试驱动,先写测试代码然后再写业务开发代码
讲ABP开发的文章太多,不缺我一个,然而讲用ABP去做BDD/TDD的文章却很少,很需要我去补充
我现在自己创业,自负盈亏,不像很多开发人员,每月固定有工资,旱涝保收,可以放心的去空谈理论。所以我一切以出活为主,以交付实际成果为第一目标,而不是以理论和空谈为目标。BDD/TDD可以避免把宝贵的时间投入到项目实际上不需要的理论方面,可以保证我做的东西是客户所想要的。所以我强烈推荐BDD这个核武器。
在上一点里面我说出了核心,如何保证你所做的东西就是客户想要的?这就是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