When I transitioned to a Team Lead position at Microsoft I was inundated with more training and advice than one could usefully absorb.  The one book that stood out amongst the rest was “First, Break all the Rules”.  Sure the title has a certain appeal to someone in their mid-twenties like me, but there are a lot of truisms in this book and I would recommend it to anyone whether they are in middle management or not.  Testing, like most other professions, requires a healthy mix of natural talents and learned skills to be done right.   If you don’t have people or a team with the right mix of these abilities then you will not ship a quality product no matter what methodology you use, time you have, or any other resources available to you.  What talents and strengths are needed to test your software?

 

Being the Customer:  In my first testing blog I talked about the importance of a customer connection.  Successful testers have a passion for the software they are testing and would otherwise be consumers of that software.  I don’t work there, but I’m willing to bet the best testers at Adobe are people that enjoy playing with digital art.  I know some of the best testers in Visual Studio are people that love developing software and are pretty good developers themselves.   This personal connection enables you to have a good home base from which to base your customer knowledge.  

 

Healthy Paranoia:  Just because your paranoid doesn’t mean someone isn’t trying to spoof your domain.  Good testers don’t take anything for granted, but have a talent for knowing where to place their paranoia when constructing their test plans.

 

Creativity: How long could you spend dreaming up tests for a salt shaker? This, slightly rephrased as “Test this salt shaker”, was my lunch interview at Microsoft.  You still probably haven’t thought of all the ways people will use your software, but it’s best if you can get yourself a good start.  My interviewer got to eat; my food had too much salt in it. 

 

Abstraction: With software becoming increasingly complex and code component re-use it becomes important to understand the big picture without getting lost in the details.  Most new testing methodologies like Model Based testing only succeed when the testers are able to accurately abstract the system at hand. 

 

I’m sure I’ve missed some with the short amount of time I’ve spent on this entry.  I’d love to know if there is a talent I’ve missed that ranks with these four.  IMO, once you get beyond this level you have to start asking more specific questions like “What kind of software are you developing?” or “What approaches do you want to use in order to test?”.  Even before the second question you may have to ask “What other skills and talents does my team posses and what approach makes the best use of these?”   These are all important questions that one must tackle to successfully test, but no matter what your answers are I bet your team will have trouble if you don’t have a mix of these basic ingredients.  

 

Again, I’d love to here your opinions.

josh