Video: TDD, Where Did It All Go Wrong - Ian Cooper
TDD, Where Did It All Go Wrong - Ian Cooper
Ian Cooper - TDD, Where Did It All Go Wrong
Trigger for writing test
!= new method
!= new class
= requirement
data:image/s3,"s3://crabby-images/ce108/ce108a4e30d0ca7eb399667be29054fe5816f2b2" alt=""
test api
data:image/s3,"s3://crabby-images/56e9c/56e9c450637ec0156b3cdbee73966f253c7ef3fb" alt=""
System Under Test (SUT) != class
Unit test -> exports of module
data:image/s3,"s3://crabby-images/b18c2/b18c21861b0140a8991332a6af42eca98cb5dfbe" alt=""
data:image/s3,"s3://crabby-images/d840e/d840ea6b562f415c76117df06a81e8ef8527687f" alt=""
refactoring = separate implementation detail from things you do need to test
extra
data:image/s3,"s3://crabby-images/b1eed/b1eed98214193de081e63342e48379b4a81e6da2" alt=""
"The word 'test' in TDD confuses people about how to do TDD, when I change it to Behavior, it tends to be better understood"
-- Dan North
data:image/s3,"s3://crabby-images/9aad9/9aad9c0dbc96f94cd2463e3e644006b39926388c" alt=""
todo: re-read 'TDD by example'
design clean api first, then realistic
data:image/s3,"s3://crabby-images/74192/741928ebd9baca5ad39b3b353347f733f4b14c9f" alt=""
test is first consumer of your code
unit of isolation = test, not sut
data:image/s3,"s3://crabby-images/2d18c/2d18cb1fe0e9200dc88e8ca7306ac58eb5a29b79" alt=""
data:image/s3,"s3://crabby-images/bd325/bd3256d60e1b8e654fa45c8ca920d3e96d132dba" alt=""
===
RED-GREEN-REFACTOR
1) write test that fails without implementation
2) make test pass asap, sinful, ducttape
line by line
not nice classes, no patterns
speed > design
3) make good code
"""
You can't do 2 things at once easily
- understand the solution to the problem
- engineer the code right
You will either
- over-engineer
- analysis-paralysis
"""
===
CLEAN CODE WHEN
data:image/s3,"s3://crabby-images/c1d70/c1d700c20e71d77a60ba78a116ad397339530f02" alt=""
refactoring
don't write tests
private/internal visibility
data:image/s3,"s3://crabby-images/b88d4/b88d4aaef78ad3c66a3805a1ac2d9b76cf20a72b" alt=""
only in the refactoring step
now I know I need it
data:image/s3,"s3://crabby-images/d951c/d951c3519b381f9a421a3d7b334e7881403f5c46" alt=""
data:image/s3,"s3://crabby-images/a6148/a6148f8652403e6c8c55e118bfcc8f0e6c2f9904" alt=""
===
HEXAGONAL ARCHITECTURE
PORTS AND ADAPTERS
===
GEARS
throw away helping tests with implementation details when implemented
===
ACCEPTANCE TDD
Don't do it
- customers are not interested
- they're expensive
Maybe you need it, because programmer tests don't focus on the gist of the system.
===
MOCKS
data:image/s3,"s3://crabby-images/75ded/75ded139a5cc0725c7af3346133334e469b622ac" alt=""
data:image/s3,"s3://crabby-images/f4f17/f4f17c90282be2b0418333045bef7e3d58396bc5" alt=""
===
SUMMARY
data:image/s3,"s3://crabby-images/01081/01081d1f293e0c94904a760734dfb8e41710c188" alt=""