Hacker News new | past | comments | ask | show | jobs | submit login
Is user a monkey? (android.com)
147 points by mindaugas on Nov 2, 2010 | hide | past | favorite | 37 comments



In 1993, I was taking a course in Software Verification & Validation at the Univ of Houston Clear Lake, next door to Johnson Space Center and down the street from the IBM division doing the Space Shuttle software. That is the group that is CMM Level 5 and gets a bug report about once a year or so. It happened that the instructor of this course was a mid-level IBM tech guy in that organization. And he had stories...

After Challenger blew up, NASA demanded that every shuttle vendor report the cumulative probability that their component of the system would lead to a loss of vehicle accident. NASA took all those probabilities and came up with their best guess of the probability of a loss of vehicle accident for each flight. While Feynman praised the software process for the shuttle, the software group still had to come up with their number. So the instructor said they took all their statistics from the (individual, unique) software loads for each historical flight, and included the failures from their loss of vehicle accidents.

"Say what? The shuttle software hasn't had any loss of vehicle accidents." Well, turns out it had. Each unique software load for each mission is tested and trained against for many months before it flies. Sometimes they fail, just not yet in actual flight. For example, apparently one time the shuttle crew was practicing launch aborts, where the launch is aborted just after clearing the pad and the orbiter lands like a glider. About the only crew member involved in that is the pilot. Everyone else is just strapped in being bored, and after a few hours of sitting still, the co-pilot got "frisky." During the launch phase, he randomly tapped some keys on his keypad and ... BOOM! Loss of vehicle accident.

Monkeys at work! I suppose it could be argued that with all the bumping around during the launch phase, a stray hand could accidentally "fuzz" that keypad.


That's why modern fly-by-wire aircraft have a crew of two = one man and one dog.

The man's job is to feed the dog, and the dog's job is to bite the man if he tries to touch any of the controls.



when i was doing Palm OS programming back in the stone age, i remember the simulator had a "monkey testing mode", where it would just generate GUI events randomly. it was actually quite useful for uncovering sporadic crashes.

EDIT: ha, i found a reference, they're called Gremlins

http://users.jyu.fi/~mweber/teaching/docs/palmos/book/ch10.h...


Calling them Gremlins is actually a reference to the British Royal Air Force in WWII. The airmen would blame 'gremlins' for mechanical issues or even problems during flight.

http://en.wikipedia.org/wiki/Gremlin#Origins

Famous children's author Roald Dahl popularized them after he left the RAF to become a writer. If you get a chance, read a biography of Roald Dahl. He truely was the most interesting man in the world. (WWII Ace Fighter Pilot, British Secret Agent, invented a brain-heart valve, married an Academy Award winning actress, pioneered a stroke recovery program and sold over 100 million books.)


I remembered reading his books in my younger ages.


That's exactly why this method exists on Android. They have a similar testing tool called Monkey: http://developer.android.com/guide/developing/tools/monkey.h...


Doesn't it defeat the testing purpose if you perform a check to take a different code path when the testing tool runs?


The intended use for the Mac equivalent (described in the folklore.org story linked from another comment here) was to disable the quit command, so the test could be run for longer than it took the "monkey" to quit the application.

I imagine there are similar uses on Android.


You might avoid doing certain write-esque operations if you know you are in test mode. For example, you wouldn't want to charge a credit card or update someone's facebook status.


On the downside this might prevent some great dramatic literature from being created.


That makes sense. It didn't occur to me that someone might want to run a monkey test in a live environment, but I guess it is necessary sometimes.


I'd imagine there are occasional uses for it. You could use it to start the app with a particular state you wish to test with Monkey, while leaving it usable for human users.


It's meant to test some of the more extreme bounds of the system. Filling the event queue faster than the code can handle it, for example. Clicking in odd places at strange times and seeing unexpected behavior.

Monkey testing is going to expose things that you never anticipated in your test spec. It's a stress test.


Maybe. Sometimes no matter how hard you try test and production are significantly different. I wind up in a number of situations where any meaningful testing has to be done in production.


I'll assume that it's best to put in the check after you've found a bug. Perhaps something that the monkey triggers that isn't very high on your human-customer buglist.


I believe it's also called "fuzz testing"


This is referring to a test tool called The Monkey: http://developer.android.com/guide/developing/tools/monkey.h...


The documentation really should mention that.


I guess this goes up there with Be's is_computer_on_fire()

http://www.tycomsystems.com/beos/BeBook/The%20Kernel%20Kit/S...



Skype must to have a similarly named function in it. In skype chat window, when you press random keys on a keyboard in groups, the other side sees a cat icon in the chat. Kind of neat of them to think of that.


"Catlike typing detected" goes back (I think) to this: http://www.bitboost.com/pawsense/


More euphonious in a ternary operator than an if clause:

value = isUserAMonkey() ? left : right ;

if (isUserAMonkey()) { ... }

For an if clause, I prefer userIsAMonkey:

if (userIsAMonkey) { ... }


It also sounds better when you consider that the booleans are called True and False:

isUserAMonkey -> Yes/No

userIsAMonkey -> True/False


Make sure to not use this method when targeting anything below API Level 8.


Always assume yes, at least when it comes to stress testing.


What does it return?



onTransact makes me die a little bit on the inside. Must... refactor....


uhhh, True?


"The customer is not an idiot. She is your wife." --Jean-Louis Gassee


It's David Ogilvy actually.


I stand corrected; Jean-Louis is just fond of saying it.


Infinite monkey theorem applies too I think... http://en.wikipedia.org/wiki/Infinite_monkey_theorem


Doesn't seem to work well, I ran this code on my mom's phone and it returned False. I'll have submit a bug report when I get home...


You're claiming to be directly and immediately descended from a monkey?

Can you come and meet some creationists I know? I can't wait to knock the smug looks off their faces.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: