Skip to content

Latest commit

 

History

History
41 lines (25 loc) · 2.76 KB

File metadata and controls

41 lines (25 loc) · 2.76 KB

Frequently needed arguments about software quality

What?

A collection of frequently needed arguments about well established (empirically validated) practices related to software quality.

Why?

As a software engineer that cares about quality and that frequently gets involved with new projects in companies or in the open source environment, I usually see the same discussions about a specific topic happen every now and then.

The problem is that I don't always remember the arguments that led me to a given conclusion, so I'm creating this repository to aggregate these arguments and maybe even change my conclusions by exposing them to different opinions and having discussions around them.

Tests with conditional execution paths should be avoided

Tests with conditional execution paths are intrinsically non-deterministic, they mix responsibilities of what could possibly be multiple test cases in one, turning the outcome of the test difficult to read and reason about. While a deterministic test has two possible results (it has either passed or failed) a test with conditional paths can have multiple reasons for either passing or failure states.

Read more:

BDD is not about testing, it is not a testing approach (same applies to TDD)

BDD is a design activity meant to leverage communication within the team while guiding the development with an outside-in approach. The fact that by aplying BDD you end up with automated tests is just a side effect but not the main goal.

Read more:

TDD vs Unit testing

TDD and Unit testing are orthogonal concepts.

Although it is common to use TDD to drive the design of small pieces of behavior, TDD is not only for this level of granularity.

One can apply TDD at any level of granularity, for instance:

  • in the acceptance level
  • in the integration level or
  • in the unit level

Unit testing is a somewhat vague concept that usually refers to testing the smallest piece of behavior that you care about. You can write unit tests before you write the code for it to pass, while you write the code or after. TDD in the other hand is a design activity that uses tests as specifications to drive the solution in an outside-in fashion. It's the developer's responsibility to define the level of granularity that they want to drive out with the test.