2
0
mirror of https://github.com/LCTT/TranslateProject.git synced 2025-01-25 23:11:02 +08:00
TranslateProject/sources/tech/20190514 Why bother writing tests at all.md
darksun 550c61a6e7 选题: 20190514 Why bother writing tests at all?
sources/tech/20190514 Why bother writing tests at all.md
2019-06-20 17:40:46 +08:00

7.2 KiB
Raw Blame History

Why bother writing tests at all?

In previous posts and presentations I talked about how to test, and when to test. To conclude this series of Im going to ask the question, why test at all?

Even if you dont, someone will test your software

Im sure no-one reading this post thinks that software should be delivered without being tested first. Even if that were true, your customers are going to test it, or at least use it. If nothing else, it would be good to discover any issues with the code before your customers do. If not for the reputation of your company, at least for your professional pride.

So, if we agree that software should be tested, the question becomes: who should do that testing?

The majority of testing should be performed by development teams

I argue that the majority of the testing should be done by development groups. Moreover, testing should be automated, and thus the majority of these tests should be unit style tests.

To be clear, I am not saying you shouldnt write integration, functional, or end to end tests. Im also not saying that you shouldnt have a QA group, or integration test engineers. However at a recent software conference, in a room of over 1,000 engineers, nobody raised their hand when I asked if they considered themselves in a pure quality assurance role.

You might argue that the audience was self selecting, that QA engineers did not feel a software conference was relevantor welcomingto them. However, I think this proves my point, the days of one developer to one test engineer are gone and not coming back.

If development teams arent writing the majority of tests, who is?

Manual testing should not be the majority of your testing because manual testing is O(n)

Thus, if individual contributors are expected to test the software they write, why do we need to automate it? Why is a manual testing plan not good enough?

Manual testing of software or manual verification of a defect is not sufficient because it does not scale. As the number of manual tests grows, engineers are tempted to skip them or only execute the scenarios they think are could be affected. Manual testing is expensive in terms of time, thus dollars, and it is boring. 99.9% of the tests that passed last time are expected to pass again. Manual testing is looking for a needle in a haystack, except you dont stop when you find the first needle.

This means that your first response when given a bug to fix or a feature to implement should be to write a failing test. This doesnt need to be a unit test, but it should be an automated test. Once youve fixed the bug, or added the feature, now have the test case to prove it workedand you can check them in together.

Tests are the critical component that ensure you can always ship your master branch

As a development team, you are judged on your ability to deliver working software to the business. No, seriously, the business could care less about OOP vs FP, CI/CD, table tennis or limited run La Croix.

Your super power is, at any time, anyone on the team should be confident that the master branch of your code is shippable. This means at any time they can deliver a release of your software to the business and the business can recoup its investment in your development R&D.

I cannot emphasise this enough. If you want the non technical parts of the business to believe you are heros, you must never create a situation where you say “well, we cant release right now because were in the middle of an important refactoring. Itll be a few weeks. We hope.”

Again, Im not saying you cannot refactor, but at every stage your product must be shippable. Your tests have to pass. It may not have all the desired features, but the features that are there should work as described on the tin.

Tests lock in behaviour

Your tests are the contract about what your software does and does not do. Unit tests should lock in the behaviour of the packages API. Integration tests do the same for complex interactions. Tests describe, in code, what the program promises to do.

If there is a unit test for each input permutation, you have defined the contract for what the code will do in code , not documentation. This is a contract anyone on your team can assert by simply running the tests. At any stage you know with a high degree of confidence that the behaviour people relied on before your change continues to function after your change.

Tests give you confidence to change someone elses code

Lastly, and this is the biggest one, for programmers working on a piece of code that has been through many hands. Tests give you the confidence to make changes.

Even though weve never met, something I know about you, the reader, is you will eventually leave your current employer. Maybe youll be moving on to a new role, or perhaps a promotion, perhaps youll move cities, or follow your partner overseas. Whatever the reason, the succession of the maintenance of programs you write is key.

If people cannot maintain our code then as you and I move from job to job well leave behind programs which cannot be maintained. This goes beyond advocacy for a language or tool. Programs which cannot be changed, programs which are too hard to onboard new developers, or programs which feel like career digression to work on them will reach only one end statethey are a dead end. They represent a balance sheet loss for the business. They will be replaced.

If you worry about who will maintain your code after youre gone, write good tests.

  1. Writing table driven tests in Go
  2. Prefer table driven tests
  3. Automatically run your packages tests with inotifywait
  4. The value of TDD

via: https://dave.cheney.net/2019/05/14/why-bother-writing-tests-at-all

作者:Dave Cheney 选题:lujun9972 译者:译者ID 校对:校对者ID

本文由 LCTT 原创编译,Linux中国 荣誉推出