Let's say you have a regression test or fuzzy testing suite that relies on generating a random set of operations, and verifying their results (like ldap-torture).
You want this set operations to be reproducible, so if you find a bug, you can easily get to the exact same conditions that triggered it.
There are many ways to do this, but one simple way is to use one of many pseudo random generators, one that given the same starting seed generates the same sequence of random numbers. Example?
Let's look at perl:
# Seed the random number generator. srand($seed); # Generate 100 random numbers. for (my $count = 0; $count < 100; $count++) { print rand() . "\n"; }
Given the same $seed
, the sequence of random numbers will always be the same. Not surprising, right?
Now, let's go back to our original problem: you want your test to be reproducible, but still be random. Something you can do is get rid of $seed
, and just call srand()
. srand
will return the seed generated, that you can helpfully print on the screen and reuse if you need to. The final code would look like:
if ($seed) { # Use an existing seed to reproduce a failing test. srand($seed); } else { # Let srand pick a seed to start a newly randomized test. $seed = srand(); } print "TO REPRODUCE TEST, USE SEED: " . $seed . "\n";
Now, where is the problem? Well, the problem is that before perl 5.14 (~2011, in case you are wondering), srand()
did not return the seed it set. Just doing $seed = srand()
did not work.
[ ... ]