Skip to content

Latest commit

 

History

History
138 lines (96 loc) · 8.74 KB

File metadata and controls

138 lines (96 loc) · 8.74 KB

TDD

TDD (Test-driven development)

Index

TDD "The Great Unknown"

The TDD concept is generally misunderstood by people. Perhaps the acronym TDD "Test-driven development " are not the most convenient. The "T" of TDD cheats a bit for TDD is not a testing methodology else a development methodology and design software. In practice TDD tends to confuse concepts are interrelated but do not start from the same root:

Self -testing -code ! = TDD ! = Unit testing

Self -testing -code ! = TDD , TDD has not primary mission the test coverage. This coverage is a benefit that is obtained by applying the methodology. This means that you can have high test coverage making after developing the product. It isnt´t condition applying TDD or to have high test coverage.

TDD ! = Unit testing , unit test as much as possible try to be decoupled by definition. In exchange for not applying the compulsory decoupling TDD code is required although it is convenient. Moreover, in many parts of it will be convenient to be a "small" coupled for some tests. Moreover establish any automated test framework is a consequence of applying the methodology.

People also believed that applying TDD the need for other types of tests is eliminated. This is completely false as there are types of test as system test "End to End" performing QA that do not comply with the principles that must meet a test in TDD. TDD therefore does not eliminate the QA work even if indirectly reduced because the number of bugs that can appear in higher-level test without having appeared in unit testing or integration of lower level is very low probability occur.

What is TDD?

The definition of wikipedia express:

"Test-driven development (TDD) is a software development process that relies on the repetition of a very short development cycle: first the developer writes an (initially failing) automated test case that defines a desired improvement or new function, then produces the minimum amount of code to pass that test, and finally refactors the new code to acceptable standards"

TDD is more than just perform test at first. As a result of applying the methodology produced automated test and also occur following the first TFD "Test - First- development". But we must not forget that the main mission of the methodology is to design the software product by examples. These examples are translated in getting test emerging architecture of our product iteratively and incrementally only what the customer asks us .

Advantages and disadvantages

The main advantages and disadvantages are:

Advantages disadvantages
The tests act as low documentation Always focus on micro design
Debugging less time The developer makes testing : it goes against good testing practices
Higher quality software More development time delay so the feedback to the user
Lower maintenance costs Learning curve for new teams
Avoid overdesigned : a test requires us to write the minimum functionality
Solid test coverage

Based Features

TDD methodology provides a basis features:

Written by developers (TDD)
How does the system
Test code
Vocabulary solution
With implementation detail

Tdd test properties

All unit test that applies tdd must to be:

  • FAST: Large number of test should be very fast.
  • INDEPENDENT: You can not depend on another to produce a satisfactory result.
  • REPEATABLE: Innocuous. You should not alter the system. It will run just 20 times.
  • SMALL: Atomic. Proving the minimum amount of functionality possible.
  • TRANSPARENT: Clear the purpose of the test, even without comment.

Cycle of TDD

The iterative cycle methodology is divided in three easy steps: RED - GREEN - REFACTOR

alt text

  • We write a test
  • We run all tests
  • Check that the last written test fails (RED)
  • Write code implementation
  • We run all tests
  • Check that all tests pass (GREEN)
  • Refactored the code (Refactoring)
  • We run all tests
  • We check that all tests pass

Speed is the key

Speed is the key to success of TDD. We must make the cycle in minutes, even seconds. You can compare it like a game of ping pong.

  • We write and execute all test (PING).
  • We write implementation (PONG).
  • Refactored and confirm that all tests pass (POINT).

Executable documentation

One consequence and benefit of applying the TDD methodology is the generation of an executable documentation. The tests act as documentation for developers. Practically we do not need to put comments in the code. The nomenclature should explain the functionality test. It is easier to understand the code does a test that implementation of the code itself. The documentation does not conflict with other documents of higher or wider level. Code documentation is completely further. The documentation is kept current without any extra work because it belongs flow methodology.

Design Principles

  • YAGNI (“You ain’t gonna need it”):

It is aimed at eliminating unnecessary code and focus on functionality. Less code means less maintenance and less chance of bugs.

  • DRY (“Don’t repeat yourself”):

We reuse previously written code. The benefit is less code to maintain and use code that we know works.

  • KISS (“Keep it simple, stupid”):

Keep the code as simple as possible while performing their function.

  • OCCAM'S RAZOR (“Philosophical principle”):

Being equal, the simplest explanation is usually the most likely. That is, when you have two solutions to the same problem, the simplest is often the best.

Recommendations

There are problems in applying the methodology tdd.

  • TDD with an unknown technology:

It is common when we started with new tools that problems occur when following the TDD methodology. As a first approximation is convenient "spikes " or concept testing tools. Before driving the car it is important to know where the steering wheel, brake etc.

  • TDD middle of a project:

One of the questions that arise when we start implementing TDD is: *Can you apply TDD project started?*For the new that has to implement course. The problem comes to what is already developed. In this case you could abusing lot of mocks. There are many legacy without coverage test and difficult to use parts. So they can live the parties will be necessary in many mocks even penalize fragility test. Best parachute jump without it!

Conclusions

To apply the TDD methodology is necessary to change the mindset of how teams have worked in traditional development methodologies. This usually has a significant learning curve to start. TDD program "now" is not programmed thinking " it just in case. "Cast the first stone that the developer has not set then things have not been used. In the end this is just in case it not using!

The developments do not work with the super architect who owns the application. So the super enterprise architect does not mount the foundation product for developers to add functionality? The answer is a resounding no. The super architect remains a reference and asked for advice and help, but the technical team will be responsible for emerging architecture. That is all developers act as architects, designers and developers. TDD promotes the concept of "collective code" leaving aside the stereotype that certain portions of code only the certain technical touch.

Note that this method works to be met mainly two things ; first the whole team and the second TDD make the team and the client has a constant flow of communication following an iterative and incremental manner any agile methodology like Scrum. Without this low success we have applied the methodology.

References


BEEVA | Technology and innovative solutions for companies