Testing on the Toilet

June 26, 2008

Defeat "Static Cling" You're pair programming and, as many brilliant people are apt to do, talking out loud. "I'll make a mock, inject it, and rerun the test. It should pa- ...D'OH" Your partner notices the exception "ConnectionFactory not initialized". "What?" she says, "Something is using the database? Dang, and this was supposed to be a small test." Upon inspection you find that your class is calling a static method on some other class. You've got Static Cling! If you're (ab)using a data persistence layer that generates code which relies on static methods, and weren't careful, your code might look something like this: public class MyObject { public int doSomething(int id) { return TheirEntity.selectById(id).getSomething(); }

As a result, you can't call doSomething without calling TheirEntity's static method. This code is hard to test because static methods are impossible to mock in Java. So, how do you get rid of this form of Static Cling and get that small test to pass? You can use a technique sometimes known as the Repository Pattern, a form of Abstract Factory. Create an interface and an implementation with the unmockable static method calls: interface TheirEntityRepository { TheirEntity selectById(int id); // other static methods on TheirEntity can be represented here too } public class TheirEntityStaticRepository implements TheirEntityRepository { public TheirEntity selectById(int id) { // method not static return TheirEntity.selectById(id); // calls static method }

Next, inject a TheirEntityRepository into MyObject and use it instead of calls to the static method: public class MyObject { private final TheirEntityRepository repository; public MyEntity(TheirEntityRepository arg) { this.repository = arg; } public int doSomething(int id) { return repository.selectById(id).getSomething(); }

You can do this even if you don't have access to source code for TheirEntity, since you're not changing the source itself, but merely encapsulating its static methods in an injectable interface. The techniques shown here generalize to the case where a static method acts as a Factory of objects. Now you can inject different implementations of the repository for different tests, such as "never finds anything," "always throws an exception," "only returns a TheirEntity if the id is a prime," and so forth. These kinds of tests would've been impossible before this refactoring.

More information, discussion, and archives: http://googletesting.blogspot.com Copyright © 2007 Google, Inc. Licensed under a Creative Commons Attribution–ShareAlike 2.5 License (http://creativecommons.org/licenses/by-sa/2.5/).

public_static_cling - NeoOffice Writer Code

Jun 26, 2008 - "always throws an exception," "only returns a TheirEntity if the id is a prime," and so forth. These kinds of tests would've been impossible before this refactoring. More information, discussion, and archives: http://googletesting.blogspot.com. Copyright © 2007 Google, Inc. Licensed under a Creative Commons.

186KB Sizes 1 Downloads 134 Views

Recommend Documents

TimeIsRandom.odt - NeoOffice Writer Code
3 Apr 2008 - There are two barriers to effectively testing this method: 1. There is no easy way to test corner cases; you're at the mercy of the system clock to supply input conditions. 2. When nextMinuteFromNow() returns, the time has changed. This

too_many_tests - NeoOffice Writer Code
Testing on the Toilet. Feb. 21, 2008. Too Many Notes Tests. In the movie Amadeus, the Austrian Emperor criticizes Mozart's music as having “too many notes.” How many small tests are “too many” to test one function? Consider the method decide:

too_many_tests - NeoOffice Writer Code
Testing on the Toilet. Feb. 21, 2008. Too Many Notes Tests. In the movie Amadeus, the Austrian Emperor criticizes Mozart's music as having “too many notes.” How many small tests are “too many” to test one function? Consider the method decide:

TotT-StroopEffect - NeoOffice Writer Code
Feb 7, 2008 - RED, GREEN, BLUE, ... (Try it now!) 2. ...say all 25 colors out loud: GREEN, YELLOW, WHITE... (Try it now!) Did the second task require more time and effort? If so, you're experiencing the Stroop Effect, which roughly says that when a l

public_file_flakiness - NeoOffice Writer
Apr 17, 2008 - The callers of CreateGapLease can continue invoking it as usual, but the unit test can pass in a different path: def testCreateGapLease(self):.

public_file_flakiness - NeoOffice Writer
Apr 17, 2008 - In this case, clearing the file at the start of the test can reduce its brittleness: def testCreateGapLease(self): if os.path.exists(lease_file):. RemoveFile(lease_file) ... Unfortunately, this doesn't completely eliminate the flakines

testng-on-the-toilet - NeoOffice Writer Code
20 Mar 2008 - TestNG is a test framework for Java unit tests that offers additional power and ease of use over JUnit. Some of TestNG's features will help you to write your PirateShip tests in such a way that you'll be well prepared to take on the Adm

testng-on-the-toilet - NeoOffice Writer Code
Mar 20, 2008 - TestNG's capacity for running tests in parallel. You can do this in the definition of ... in an XML file) with the parallel and thread-count attributes.

canberraplanreview.odt - NeoOffice Writer
For Marco Polo in Italo Calvino's Invisible Cities,1 Venice is the one true city from whose structure all possible cities can be deduced. In that case, Venice is the reciprocal of Canberra, whose plan was abstracted from all the many actual cities, b

Public Friends You Can Depend On.odt - NeoOffice Writer
Jun 12, 2008 - More information, discussion, and archives: http://googletesting.blogspot.com. Copyright © 2007 Google, Inc. Licensed under a Creative ...

Public Friends You Can Depend On.odt - NeoOffice ... Code
Jun 12, 2008 - A Stub overrides the real object and returns hard-coded values. Testing with ... implementing an in-memory database, or using a fake BigTable.

Letter Writer
Use specifics (precise character names and events)?. YES. NO. • Talk about book events in a way that suggests familiarity with causes, effects, outcomes, etc.? YES. NO. • Convey maximum information with minimal words? YES. NO. • Connect the ref

Eus, Personae e Grupos.odt - NeoOffice Writer.pdf
Eus, Personae e Grupos.odt - NeoOffice Writer.pdf. Eus, Personae e Grupos.odt - NeoOffice Writer.pdf. Open. Extract. Open with. Sign In. Main menu. Whoops!

Becoming a Writer
questions, toss these cards into a recipe box, and then review the contents of the recipe box ... reward myself with one after each paragraph that I succeed in writing.) ... direct, thorough, and helpful feedback as students develop as writers. I als

Writer: Gali Sree Kar Writer: Gali Sree Kar M.Sc, B ... -
It is used in glass and soap and paper industries. 2. It is also ...... Sometimes fruits like mango, banana, papaya, sapota and custard apple are often ripen by.

pdf writer for windows 98
Page 1. Whoops! There was a problem loading more pages. pdf writer for windows 98. pdf writer for windows 98. Open. Extract. Open with. Sign In. Main menu.

RAMON LLULL AS A VERNACULAR WRITER
scientific works in his maternal Catalan while, at the same time, he was deeply involved in the circulation of such works in other Romance .... Daytime telephone.

IT Practical Questions Writer
IT Practical Questions. Writer. Q1. Q2. Q3. Page 2. Q4. Q5. Page 3. Q6. Q7. Page 4. Q8. Q9. Page 5. Q10. Q11. Page 6. Q12. Calc. Q1. Page 7. Q2. Q3. Page 8 ...

Sparse-parametric writer identification using heterogeneous feature ...
The application domain precludes the use ... Forensic writer search is similar to Information ... simple nearest-neighbour search is a viable so- .... more, given that a vector of ranks will be denoted by ╔, assume the availability of a rank operat

2016.12.28 E-Commerce Product Writer English & Vietnamese.pdf ...
Please send your CV to [email protected]. Page 3 of 3. 2016.12.28 E-Commerce Product Writer English & Vietnamese.pdf. 2016.12.28 E-Commerce Product ...

PDF The Longman Writer Read online
The Longman Writer Download at => https://pdfkulonline13e1.blogspot.com/0321914139 The Longman Writer pdf download, The Longman Writer audiobook download, The Longman Writer read online, The Longman Writer epub, The Longman Writer pdf full ebook,