2018年和1998年其中两大区别就是:
  1. 前端蓬勃发展, 前后端分离是一个十分大的趋势.
  2. 专门的测试人员角色被取消, 多出了一个很重要的角色, 产品经理
 
ABP只要加入即可马上加快项目进展, 选择前后端+产品经理分工结构会比前面的全栈篇好十分多!!! 因为:
  1. 分工协作和流水线作业工作效率会远远比传统的个人全能型先进很多, 这个道理很多同学都懂, 我就不赘述了.
  2. 前端快速和迅猛发展, 6个月发布一次大版本, 浏览器6周发布一次小版本, 导致传统程序员光是学习新技术就已经很吃力, 要谈精通更难了.请欣赏此图:
  3. 招人扩展团队加快项目进度更容易了!!! 这才是重点!!!
    流水线作业减低每个人的技术难度, 让招人和培训新手更容易
    招校招生上手难度降低, 更容易招聘和更快能够有产出
    招社招生更容易, 质量更高, 特别现在是前端爆发期
 
接下来说说是怎么流水线作业的.
 
考虑到并不是所有同学都运用过BDD, 有很多同学只用过TDD的. 所以我分成两套流水线作业讲述. 
先说第一套没有BDD只有TDD的流水线作业工序吧:
  1. 前后端一起定义接口
  2. 后端写好C# interfaces用Swagger生成接口文档
  3. 前端将后端写好的接口用refresh.bat生成前端ts proxy
  4. 前后端各自干各自的活
 
以上流水线自然而然就运用了如下技术思想和技术点, 避免为了技术而技术, 为了思想而思想:
  1. TDD
  2. IOC/Mock
  3. Interface
让技术和思想自然而然的为你服务, 而不是你为技术和思想服务.
 
大家看到, 在第一套流水线里面, 产品经理并没有参与进来. TDD是由开发人员写的, 与产品经理无关.
而在接下来的第二套流水线里, 产品经理通过运用BDD参与进来了:
  1. 前端根据产品经理写好的Specflow的.feature文件用cucumber写BDD代码
  2. 前后端一起定义接口和实现BDD的step definition代码
  3. 后端写好C# interfaces用Swagger生成接口文档
  4. 前端将后端写好的接口用refresh.bat生成前端ts proxy
  5. 前后端各自干各自的活

这么说有可能会比较抽象, 在往后的日子里我会增加具体实际操作文章和视频.
 
与第一套流水线相比:
  1. 产品经理参与进来, 给开发人员写明了详细操作步骤级的测试结构代码.
  2. 开发人员不需要思考详细操作步骤, 只需要实现具体每个操作步骤.
  3. 每个操作步骤是独立分割的, 遇到项目紧急时, 通过临时调人加人来加快项目进度变得更可行.
  4. BDD与TDD相比, 天然的具备了结构性, 避免书写重复代码, 减少了测试代码的书写量.
  5. 很多公共的测试代码可以分割出来, 让专门的技术专家去写 (这会在后面一节里提到)
 
可以看到, 第二套流水线比第一套流水线先进十分多.
 
那么有个问题, 产品经理有能力写BDD吗? 
从目前市场现状来看, 从测试人员改行过来做产品经理的, 是十分有能力写好BDD的.
反而开发人员很难写好BDD, 甚至写好TDD都很困难. 这也是为什么BDD和TDD在很多企业推广不起来的原因之一, 因为角色和能力错配了.
 
2010年开始, 行业里面逐步减少测试人员, 到了2015年, 这个趋势终于成了气候, 微软在2015年大量裁减测试人员成了这类现象的里程碑事件.
那么这么多被裁减的测试人员都去哪里了呢? 绝大多数人并没有离开IT这个这么火的行业, 很多都改为做产品经理了. 他们写测试用例的能力和写BDD能力是对标的, 并且切换很容易.
 
在这里要说明一下, 产品经理来源有两类:
  1. 校招/美工/市场销售转过来的, 会用Axure等原型设计工具,这种情况应该由三个人结对编程写BDD.
  2. 测试人员改行的, 这种人写测试用例的能力就很容易很天然的演变为写BDD的能力

Talk is cheap, just show your code. 为了更形象的表现出产品经理有能力写BDD,我贴一个BDD .feature文件示例:

Feature: 登录
此文件包含登录成功和失败的例子 Scenario: 输入正确的用户名和密码能够正常登录
Given 我来到登录页面
When 输入用户名"admin"
And 输入密码"123qwe"
And 点击"登录"按钮
Then 跳转到首页 Scenario: 输入正确的用户名和错误的密码则登录失败
Given 我来到登录页面
When 输入用户名"admin"
And 输入密码"111111"
And 点击"登录"按钮
Then 依旧停留在登录页面
And 提示"用户名或密码错误" Scenario: 输入错误的用户名则登录失败
Given 我来到登录页面
When 输入用户名"admin"
And 输入密码"111111"
And 点击"登录"按钮
Then 依旧停留在登录页面
And 提示"用户名或密码错误" Scenario: 输入空的用户名则提示要输入空用户名
Given 我来到登录页面
And 点击"登录"按钮
Then 依旧停留在登录页面
And 提示"用户名必须填写" Scenario: 输入空的密码则提示要输入空密码
Given 我来到登录页面
When 输入密码"admin"
And 点击"登录"按钮
Then 依旧停留在登录页面
And 提示"密码必须填写"

  从这个示例我们可以看到,除了少数几个大家都看得懂的英语单词外,全部都可以为中文,全部都可以为人类可以识别的语言,没有一行代码!不需要产品经理会写代码。

除了以上这个好处外,BDD在程序员方面还带来了天然的很良好的测试代码结构。让我们看一下示例:

using TechTalk.SpecFlow;

namespace Bowling.SpecFlowXUnit.StepDefinitions
{
[Binding]
public sealed class 公用测试代码
{
[When(@"输入密码""(.*)""")]
public void When输入密码(string p0)
{
//ScenarioContext.Current.Pending();
//具体测试代码
} [Given(@"我来到登录页面")]
public void Given我来到登录页面()
{
//ScenarioContext.Current.Pending();
//具体测试代码
} [When(@"输入用户名""(.*)""")]
public void When输入用户名(string admin0)
{
//ScenarioContext.Current.Pending();
//具体测试代码
} [When(@"点击""(.*)""按钮")]
public void When点击按钮(string 登录0)
{
//ScenarioContext.Current.Pending();
//具体测试代码
} [Then(@"跳转到首页")]
public void Then跳转到首页()
{
//ScenarioContext.Current.Pending();
//具体测试代码
} [Then(@"依旧停留在登录页面")]
public void Then依旧停留在登录页面()
{
//ScenarioContext.Current.Pending();
//具体测试代码
} [Then(@"提示""(.*)""")]
public void Then提示(string 用户名或密码错误0)
{
//ScenarioContext.Current.Pending();
//具体测试代码
} [Given(@"点击""(.*)""按钮")]
public void Given点击按钮(string 登录0)
{
//ScenarioContext.Current.Pending();
//具体测试代码
}
}
}

  从上面示例可以看到,以上代码结构都可以用Specflow自动生成,程序员不需要像TDD一样要自己去组织测试代码结构,这也是BDD优于TDD的很大一个特点。这里有个小秘诀,自动生成之后把Class Name全改为一致然后加上Partial关键字就可以有重复Step Definition会编译不通过提醒。

这系列文章是实战文章,所以不止止停留在理论上,在实际运用过程中会遇到各种问题。比如:

  1. 如何在.NET Core下安装Specflow.
  2. .NET Core里跑Specflow - 可以跑集成测试和单元测试.

用ABP只要加人即可马上加快项目进展(二) - 分工篇的更多相关文章

  1. 如何用ABP框架快速完成项目(10) - ABP只要加人即可马上加快项目进展- 全栈篇(1) - 发挥DDD理论优势的时候到了!

    正如我在<程序员英语二三事(2) - 从听开始>里说的, 任何技术/工具/语言都有其适用场景和上下文环境. DDD理论同样是如此.   现在, 终于到了发挥DDD理论优势的时候啦!   一 ...

  2. 如何用ABP框架快速完成项目(11) - ABP只要加人即可马上加快项目进展- 全栈篇(2) - 不推荐模块组件化, 推荐微服务

    一个人写代码不需要担心会和别人的代码冲突, 不需要做代码合并, 不需要担心自己的代码被覆盖. 但是多个人一起写代码就需要担心这些问题.   解决这些问题的方法很多, 比如用AzureDevOps(TF ...

  3. HBase 中加盐之后的表如何读取:Spark 篇

    在 <HBase 中加盐之后的表如何读取:协处理器篇> 文章中介绍了使用协处理器来查询加盐之后的表,本文将介绍第二种方法来实现相同的功能. 我们知道,HBase 为我们提供了 hbase- ...

  4. 高效能Windows人士的N个习惯之一:启动篇

    接触电脑十多年,经历了各种折腾阶段,这几年开始沉静下来,不再追求花哨的界面与应用,只注重工作的效率,逐渐养成了一套自己的操作习惯,感觉不错,特撰文分享.标题借用了一下<高效能人士的七个习惯> ...

  5. 尝试从零开始构建我的商城 (一) :使用Abp vNext快速一个简单的商城项目

    尝试从零开始构建我的商城 (一) :使用Abp vNext快速搭建一个简单的项目 前言 GitHub地址 https://github.com/yingpanwang/MyShop 此文目的 本文将尝 ...

  6. java连接数据库加载驱动到java项目

    java连接数据库 package com.cook.zheng; import java.sql.Connection; import java.sql.DriverManager; public ...

  7. 关于加了hibernate 框架的项目启动特别慢的问题

    今天突然遇到一个问题,就是加了hibernate 框架的项目在启动的时候,特别慢,竟然达到了4分多钟,查来查去,看到我的bean类里*.hbm.xml,有这样的写法: <?xml version ...

  8. 多人开发的git项目如何保持提交日志为一条直线?

    多人开发的git项目如何保持提交日志为一条直线? 一.Git的项目的git常用操作 a)Git clone 项目地址 从远程仓库克隆项目到本地 b)Git pull 从当前分支拉取更新代码 c)Git ...

  9. ABP WebApi 加载错误

    [TypeLoadException:类型'Abp.WebApi.Validation.AbpApiValidationFilter'中的方法'ExecuteActionFilterAsync'从程序 ...

随机推荐

  1. JVM和GC垃圾回收机制和内存分配

    JVM运行期间 线程共享 线程私有 线程共享: 方法区 堆方法区:存放可以共享数据,静态常量,类的共有方法属性字段等,可以共享的存在方法区. 堆:存放class对象 . 线程私有:本地方法栈 虚拟机栈 ...

  2. Java 虚拟机对锁优化所做的努力

    作为一款公用平台,JDK 本身也为并发程序的性能绞尽脑汁,在 JDK 内部也想尽一切办法提供并发时的系统吞吐量.这里,我将向大家简单介绍几种 JDK 内部的 "锁" 优化策略. 1 ...

  3. Too many connections

    在一次启动项目的过程中报了如下一个错误信息: [ERROR] [2019-03-20 13:14:43] com.alibaba.druid.pool.DruidDataSource.init(629 ...

  4. @vue/cli 构建得项目eslint配置

    如下:package.json // package.json { "name": "ecommerce-mall-front", "version& ...

  5. H5 notification浏览器桌面通知

    Notification是HTML5新增的API,用于向用户配置和显示桌面通知.上次在别的网站上看到别人的通知弹窗,好奇之余也想知道如何实现的.实际去查一下发现并不复杂,且可以说比较简单,故写篇博客分 ...

  6. ML - 特征选择

    1. 决策树中的特征选择 分类决策树是一种描述对实例进行分类的树型结构,决策树学习本质上就是从训练数据集中归纳出一组分类规则,而二叉决策树类似于if-else规则.决策树的构建也是非常的简单,首先依据 ...

  7. Centos7使用docker搭建gitlab服务器

    了解到docker的优点,搭建快,运行要求资源低,最重要的是实现的功能和效果都能达到预期,于是决定使用docker来搭建gitlab服务器. 效果图如下: 系统环境:CentOS Linux rele ...

  8. 关于 Kubernetes 中的 Volume 与 GlusterFS 分布式存储

    容器中持久化的文件生命周期是短暂的,如果容器中程序崩溃宕机,kubelet 就会重新启动,容器中的文件将会丢失,所以对于有状态的应用容器中持久化存储是至关重要的一个环节:另外很多时候一个 Pod 中可 ...

  9. Spring的@Transactional事务注意事项

    1.@Transactional应该放在方法级别,不需要使用事务的方法,就不要放置事务,2.查询方法声明不要事务,否则对性能是有影响的.3.对同一个类里的方法调用, @Transactional无效 ...

  10. zend studio快捷键

    某些快捷键会失效,多尝试就好.快捷键就是一种减轻工作量的方式,或者说展示码农码代码的熟练度,重要的还在于对一个问题的看法和角度,说的具体些就是算法和数据结构,不看会后悔,不学设计模式也会吃亏. 应用场 ...