by Erik Kuefler  This article was adapted from a Google Testing on the Toilet  (TotT) episode. You can download a printer-friendly version  of this TotT episode and post it in your office.   Programming languages give us a lot of expressive power. this flexibility comes at the cost of increased complexity simplicity is more important than flexibility in tests Tests can avoid complexity by stating their inputs and outputs directly rather than computing them Does this test look correct to you?  @Test public  void  shouldNavigateToPhotosPage() {baseUrl  = "http://plus.google.com/" ;new  Navigator(baseUrl );baseUrl  + "/u/0/photos"  what happens if we simplify the test by inlining the variable?  @Test public  void  shouldNavigateToPhotosPage() {new  Navigator("http://plus.google.com/" );"http://plus.google.com//u/0/photos " , nav.getCurrentUrl()); // Oops!   After eliminating the unnecessary computation from the test, the bug is obvious when a test adds more operators or includes loops and conditionals, it becomes increasingly difficult to be confident that it is correct.  whereas production code describes a general strategy for computing outputs given inputs, tests are concrete examples of input/output pairs When tests do need their own logic, such logic should often be moved out of the test bodies and into utilities and helper functions  
 
I'm usually the guy on my team that resists the temptation to extract out common test setup, but I would regard your example as just too trivial not to pull up.
ReplyDelete