Arvet kode (ofte utestet, vanskelig å endre kode) er utfordrende å teste — den kan ha rotete avhengigheter og ingen tester. Det å legge til tester på en sikker måte innebærer teknikker som karakteriseringstester, seams for å bryte avhengigheter, og gradvis forbedring, noe som muliggjør tryggere endringer.
Utfordringen med arvet kode
Legacy code is often: untested, tightly coupled, hard to understand, risky to change:
→ no tests → changing it is dangerous (you can't tell if you broke something)
→ hard to test → dependencies are tangled (can't isolate units); not designed for testing
→ a chicken-and-egg problem: to change safely you need tests, but it's hard to test.
