It would seem that in many organizations, "automation" has become something of a buzz word. It's a term that makes upper level managers happy, but which often confound many, including Architects and lower level managers.
In order to achieve automation, especially on products which are GUI based (either as a thick client, or some web based mechanism), there is a tendency to want to use "capture/replay" tools. In essence, these are tools that are designed to capture mouse and keyboard clicks, save them, and replay it later. While this sounds great, and I am not against such a tool as part of the overall test strategy, when it is the SOLE method of testing, I am strongly against it.
I have read many sites talk about the dangers of using capture/replay tools, but they usually just harp on the difficulty of maintaining the "scripts" (the file that holds all the captured events). If the GUI interface changes, then the script becomes useless. While this is a valid point, it is not in my opinion the most serious shortcoming. The most serious shortcoming is that it does not rely on any knowledge about how the product works.
Remember that I said Test Engineer, and not Quality Assurance Engineer in the title of this blog. A QAE could rightfully say that he only does black box testing and should see the system as a customer would see the system. Test Engineers on the other hand should do some white box testing, and should be familiar of the inner workings of the system being tested. Why is this beneficial?
If you don't know how it's supposed to work, how are you supposed to know when you have a correct answer or not? I have often given an analogy that Test Engineers are teachers, and Developers are students. Test Engineers must grade what the Developers do. If the Test Engineer himself doesn't know what the answer is, that is akin to a teacher asking the student what the answer should be before the student takes the test. Letting developers have this level of control over the validity of a product is no different than letting the fox guard the hen house ("oh, that's 'working as designed', we MEANT for it to behave that way").
The second big reason you want Test Engineers to be developers and know how the system works is for first level triage. If your Test Engineers have no clue how the underlying system works, how can you expect them to debug it? Is the problem in the driver? The firmware? Maybe it's somewhere higher up in the stack, and it is a framework or application they are using. Or what if it's a low-level physical problem (jitter, noise, etc)? If all your Test Engineers do is execute tests from a Test Plan, without understanding to at least some level, the interactions of the various components, he will be ineffective at providing first level debugging, and this burden will fall to a developer. The danger here is that an ineffective defect assignment will waste a developer's time (for example, if the Test Engineer assumed the defect was firmware problem, but it turned out to be a driver problem).
And finally, how is a Test Engineer supposed to come up with new Test Cases or ad-hoc tests if he doesn't understand the system from a low-level perspective. At best, he can read a spec and determine what should be tested, but he won't necessarily know how to stress a feature, nor will he necessarily understand how to come up with invalid inputs (negative testing). Being able to "see" the weak points in a product requires knowing how that system works. Many famous martial arts masters of the past were also great healers of their time, because by understanding how the body worked, they were much better at knowing the weaknesses of the body. The same logic applies to testing.
To give you a real world example, suppose you want to use sg_utils to send generic SCSI commands. This is all well and good, but suppose something doesn't go right. Where was the problem? If you don't know what a CDB (command descriptor block) is, or how to read a SAS trace, what good will it do you? At best, you have thrown the problem over the wall to a developer to fix. This is ok for a QAE, but not a Test Engineer.
And as I mentioned in my previous blog, part of the reason Test Engineers get little respect is because they are seen by developers as little more than testers. Although Test Driven Development has gained some traction, notice that it focuses on developers writing better unit tests. The concept of Development Driven Testing has unfortunately not caught on.
No comments:
Post a Comment