Testing on the Toilet

Apr. 3, 2008

Time is Random How can a method be well tested when it's inputs can't be clearly identified? Consider this method in Java: /** Return a date object representing the start of the next minute from now */ public Date nextMinuteFromNow() { long nowAsMillis = System.currentTimeMillis(); Date then = new Date(nowAsMillis + 60000); then.setSeconds(0); then.setMilliseconds(0); return then; }

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 means the test will not be an assertion, it will be a guess, and may generate low-frequency, hard-to-reproduce failures... flakiness! Class loading and garbage collection pauses, for example, can influence this. Is System.currentTimeMillis() starting to look a bit like a random number provider? That's because it is! The current time is yet another source of non-determinism; the results of nextMinuteFromNow() cannot be easily determined from its inputs. Fortunately, this is easy to solve: make the current time an input parameter which you can control. public Date minuteAfter(Date now) { Date then = new Date(now.getTime() + 60000); then.setSeconds(0); then.setMilliseconds(0); return then; } // Retain original functionality @Deprecated public Date nextMinuteFromNow() { return minuteAfter(new Date(System.currentTimeMillis())); }

Writing tests for minuteAfter() is a much easier task than writing tests for nextMinuteFromNow(): public void testMinuteAfter () { Date now = stringToDate("2012-12-22 11:59:59.999PM"); Date then = minuteAfter(now); assertEquals("2012-12-23 12:00:00.000AM", dateToString(then)); }

This is just one way to solve this problem. Dependency Injection and mutable Singletons can also be used.

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/).

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 means the test will not be an assertion, it will be a guess, and may ...

188KB Sizes 2 Downloads 128 Views

Recommend Documents

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.blog

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,