Content deleted Content added
m →Scientific studies: WP:CHECKWIKI error fixes using AWB (12016) |
Jnestorius (talk | contribs) |
||
(42 intermediate revisions by 27 users not shown) | |||
Line 1:
{{Short description|Software testing approach}}
'''Exploratory testing''' is an approach to [[software testing]] that is concisely described as simultaneous learning, [[test design]] and test execution. [[Cem Kaner]], who coined the term in 1984,<ref>Cem Kaner, "[http://www.kaner.com/pdfs/QAIExploring.pdf A Tutorial in Exploratory Testing] {{Webarchive|url=https://web.archive.org/web/20130612043734/http://www.kaner.com/pdfs/QAIExploring.pdf |date=2013-06-12 }}", p.2</ref> defines exploratory testing as "a style of software testing that emphasizes the personal freedom and responsibility of the individual tester to continually optimize the quality of his/her work by treating test-related learning, test design, test execution, and test result interpretation as mutually supportive activities that run in parallel throughout the project."<ref>Cem Kaner, ''[http://www.kaner.com/pdfs/QAIExploring.pdf A Tutorial in Exploratory Testing] {{Webarchive|url=https://web.archive.org/web/20130612043734/http://www.kaner.com/pdfs/QAIExploring.pdf |date=2013-06-12 }}'', p. 36.</ref>
While the software is being tested, the tester learns things that together with experience and [[creativity]] generates new good tests to run. Exploratory testing is often thought of as a [[black box testing]] technique. Instead, those who have studied it consider it a test ''approach'' that can be applied to any test technique, at any stage in the development process. The key is not the test technique nor the item being tested or reviewed; the key is the cognitive engagement of the tester, and the tester's responsibility for managing his or her time.<ref>Cem Kaner, ''[http://www.kaner.com/pdfs/QAIExploring.pdf A Tutorial in Exploratory Testing] {{Webarchive|url=https://web.archive.org/web/20130612043734/http://www.kaner.com/pdfs/QAIExploring.pdf |date=2013-06-12 }}'', p. 37-39, 40- .</ref>
== History ==
Exploratory testing has always been performed by skilled testers. In the early 1990s, [[ad hoc]] was too often synonymous with sloppy and careless work. As a result, a group of test methodologists (now calling themselves the [[Software testing controversies|Context-Driven School]]) began using the term "exploratory" seeking to emphasize the dominant thought process involved in unscripted testing, and to begin to develop the practice into a teachable discipline. This new terminology was first published by [[Cem Kaner]] in his book ''Testing Computer Software'' <ref name=Kaner7-11>Cem Kaner, ''Testing Computer Software'', TAB Books, Blue Ridge Summit, PA, 1988. p. 6, 7-11.</ref> and expanded upon in ''Lessons Learned in Software Testing''.<ref>
{{cite book
|last = Kaner
|first = Cem
|
|title = Lessons Learned in Software Testing
|publisher = [[John Wiley & Sons]]
|year = 2001
|isbn = 978-0-471-08112-
</ref><!--The entire book discusses techniques used in Exploratory testing. They can also be used in other types of testing.--> Exploratory testing can be as disciplined as any other intellectual activity.
== Description ==
Exploratory testing seeks to find out how the software actually works, and to ask questions about how it will handle difficult and easy cases. The quality of the testing is dependent on the tester's skill of inventing [[Test case (software)|test case]]s and finding [[software bug|defects]]. The more the tester knows about the product and different [[test method]]s, the better the testing will be.
To further explain, comparison can be made of freestyle exploratory testing to its antithesis [[test script|scripted testing]]. In the latter activity test cases are designed in advance. This includes both the individual steps and the expected results. These tests are later performed by a tester who compares the actual result with the expected. When performing exploratory testing, expectations are open. Some results may be predicted and expected; others may not. The tester configures, operates, observes, and evaluates the product and its behaviour, critically investigating the result, and reporting information that seems likely to be a bug (which threatens the value of the product to some person) or an issue (which threatens the quality of the testing effort).
Line 22 ⟶ 23:
In reality, testing almost always is a combination of exploratory and scripted testing, but with a tendency towards either one, depending on context.
According to
The documentation of exploratory testing ranges from documenting all tests performed to just documenting the [[software bug|bugs]]. During [[pair testing]], two persons create test cases together; one performs them, and the other documents.
Line 41 ⟶ 42:
== Scientific studies ==
Replicated experiment has shown that while scripted and exploratory testing result in similar defect detection effectiveness (the total number of defects found) exploratory results in higher efficiency (the number of defects per time unit) as no effort is spent on
== See also ==
{{portal|Software Testing}}▼
* [[Ad hoc testing]]
* [[Spike (software development)|Spike testing]]
== References ==
Line 72 ⟶ 54:
== External links ==
* James Bach, ''[http://www.satisfice.com/articles/et-article.pdf Exploratory Testing Explained]''
* Cem Kaner, James Bach, ''[http://www.testingeducation.org/a/nature.pdf The Nature of Exploratory Testing] {{Webarchive|url=https://web.archive.org/web/20080511190045/http://testingeducation.org/a/nature.pdf |date=2008-05-11 }}'', 2004
* Cem Kaner, James Bach, ''[http://www.context-driven-testing.com The Seven Basic Principles of the Context-Driven School]''
* Jonathan Kohl, ''[http://www.methodsandtools.com/archive/archive.php?id=65 Exploratory Testing: Finding the Music of Software Investigation]'', Kohl Concepts Inc., 2007
{{DEFAULTSORT:Exploratory Testing}}
|