官术网_书友最值得收藏!

Behavior-driven development

BDD is the addition of business concerns to the technical concerns more typical of TDD. This came about as people became more experienced with TDD. They started noticing some patterns in the challenges that they were facing. One especially influential person, Dan North, proposed some specific language and structure to ease some of these issues. The following are some of the issues he noticed:

  • People had a hard time understanding what they should test next.
  • Deciding what to name a test could be difficult.
  • How much to test in a single test always seemed arbitrary.

Now that we have some context, we can define what exactly BDD is. Simply put, it's about writing our tests in such a way that they will tell us the kind of behavior change they affect. A good litmus test might be asking oneself if the test you are writing would be worth explaining to a business stakeholder. How this solves the previous problem may not be completely obvious, but it may help to illustrate what this looks like in practice. It follows a structure of "Given, When, Then". Committing to this style completely can require specific frameworks or a lot of testing ceremony. As a result, I loosely follow this in my tests, as you will see soon. Here's a concrete example of a test description written in this style: "Given an empty dataset when the classifier is trained, it should throw an invalid operation exception".

This sentence probably seems like a small enough unit of work to tackle, but notice that it's also a piece of work that any business user who is familiar with the domain that you're working in, would understand and have an opinion on.

You can read more about Dan North's point of view in this article on his website at http://dannorth.net/introducing-bdd/.

The BDD adherents tend to use specialized tools to make the language and test result reports be as accessible to business stakeholders as possible. In my experience and from my discussions with others, this extra elegance is typically used so little that it doesn't seem worthwhile. The approach you will learn in this book will take a simplified first approach to make it as easy as possible for someone with zero background to get up to speed.

With this in mind, let's work through an example.

主站蜘蛛池模板: 寿阳县| 栾城县| 防城港市| 巴彦县| 包头市| 南川市| 台南县| 侯马市| 鲜城| 武定县| 平湖市| 西宁市| 大足县| 安吉县| 青海省| 阜城县| 富阳市| 库尔勒市| 江山市| 龙门县| 土默特左旗| 杂多县| 崇礼县| 南阳市| 达孜县| 南汇区| 西平县| 元谋县| 桃江县| 邛崃市| 金秀| 湄潭县| 左贡县| 永平县| 麻江县| 兖州市| 濮阳市| 福建省| 五常市| 楚雄市| 神农架林区|