Download presentation
Presentation is loading. Please wait.
Published byNorah Chambers Modified over 9 years ago
1
Fighting the monster Agile development on top of a legacy database Gojko Adzic XpDay 2007 – London
2
Two recurring patterns Redundant and Inconsistent interfaces –organic growth over the years –requires authors to be available Unstable foundation – breaks compatibility without warning
3
Build a solid foundation Simplify legacy interfaces Not really nice –keeps the rest clean Anti-corruption layer Extensive test coverage
4
Why are Databases not Agile? Tools are years behind OO Object-relational mismatch DB Code is hard to test DB developers not aware or discard agile practices
5
Fight the attitude Fundamental change requires enthusiasm Reduce the amount of dull work! TDD is a good solution
6
FIT+FitNesse+DbFit = excellent DB unit test tool Tests in tabular form Easier to use than manual tests No Java/.NET knowledge required Fits into agile environment
7
Hit the nerve Spread to other projects Released under GPL Used by banks, insurance companies, bookmakers… Oracle, SQL Server, MySQL Java/.NET integration tests
8
Fight duplication Database is the master source Does not have to be binary –“Create” scripts better Generate everything you can – especially inter-layer code
9
Going for the kill “Create” scripts make DB build automation easy DbFit+FitNesse verify functionality CI with Cruise Control Not everything is automated –but is good enough
10
Conclusions Agile makes as much sense for DB code as for anything else –Just harder to implement To get people enthusiastic, focus on reducing dull work
11
Conclusions Build a reliable foundation Simplify legacy APIs Kill code ownership Use version-control friendly files Generate glue between layers
12
Some links for the end www.dbfit.org www.agiledata.org www.gojko.net gojko@gojko.com
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.