<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
		>
<channel>
	<title>Comments on: Exploratory Testing and Philosophical Psycho-babble</title>
	<atom:link href="http://www.testingmentor.com/imtesty/2009/11/10/exploratory-testing-and-philosophical-psycho-babble/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.testingmentor.com/imtesty/2009/11/10/exploratory-testing-and-philosophical-psycho-babble/</link>
	<description>Treatises on the practice of software testing</description>
	<lastBuildDate>Tue, 07 Feb 2012 09:15:11 -0500</lastBuildDate>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.1.3</generator>
	<item>
		<title>By: testingmentor</title>
		<link>http://www.testingmentor.com/imtesty/2009/11/10/exploratory-testing-and-philosophical-psycho-babble/comment-page-1/#comment-7</link>
		<dc:creator>testingmentor</dc:creator>
		<pubDate>Tue, 10 Nov 2009 07:24:11 +0000</pubDate>
		<guid isPermaLink="false">http://testingmentor.com/imtesty/2009/11/10/exploratory-testing-and-philosophical-psycho-babble/#comment-7</guid>
		<description>Hi, BJ... 

&quot;Your assertion that techniques, or engineering principles or concepts are “merely rote, mechanical task[s]” is simply fallacious&quot;. 

Yes, it would be, if that&#039;s what I had said.  I&#039;d invite you to have a look at the sentence to which you refer and read what it says.  Here it is again. 

&quot;I would (and do) teach them that testing is not merely a rote, mechanical task; that it&#039;s not merely the application of engineering principles;...&quot; 

That&#039;s not an assertion that engineering principles are rote mechanical tasks.  HERE is an assertion that engineering principles are rote mechancal tasks: 

&quot;Engineering procedures are rote, mechanical tasks.&quot; 

See the difference between the two sentences?  I do.  Perhaps I can help. Note that I differentiate the two in the first sentence, and equate the two in the second.  Note that I disagree with the second sentence, and stand by the first one.  Let&#039;s go on. 

&quot;...that it&#039;s not simply comparing the product with the spec; or other such simplifications.  Instead, testing is the process of investigating the product to reveal quality-related information about it, for people to whom that information might matter.&quot; 

You agree with that, don&#039;t you? 

You suggest... 

&quot;Software testing is a professional discipline in the field of computer science.&quot; 

I think that&#039;s true to some degree.  Alas it&#039;s not very well supported by the certain professional organizations in the field itself.  The content of the ACM/IEEE&#039;s curriculum guide to this day is less than one full course in a four-year program.  I wish those guidelines addressed testing more; as it is, the I think professional organizations trivialize it. 

So to be clear, testing IS a professional discipline in the field of computer science, but it&#039;s also much more than that.  Testing involves asking questions about the way humans interact with the software.  It involves asking questions about the way that humans can make mistakes as they&#039;re developing software, and as they&#039;re testing it.  So in additional to technical skills, we need other kinds of skills too. 

I agree when you say that &quot;Techniques are not rote mechanical tasks&quot;, but I fear that they can become that way if we teach testers that other skills aren&#039;t important too.  In your original post, you assert &quot;I am not an expert in systems thinking, cognitive psychology, or epistemology.&quot;  I&#039;m not either, but I have studied them a good deal in the effort to gain more expertise.  The value that these studies provide to me is that they add to &quot;great breadth of knowledge and the skills&quot;, and help me to understand ways in which &quot;there is not a single approach that works in all scenarios&quot;, as you put it.  Technical skills are important things, but they&#039;re not the only important things. 

My guess is that we agree on too.  Don&#039;t we?  It&#039;s weird; I see you objecting strenuously to my message, and then proceeding to agree violently with it on many points. 
Thursday, September 07, 2006 10:17 AM by Michael Bolton</description>
		<content:encoded><![CDATA[<p>Hi, BJ&#8230; </p>
<p>&#8220;Your assertion that techniques, or engineering principles or concepts are “merely rote, mechanical task[s]” is simply fallacious&#8221;. </p>
<p>Yes, it would be, if that&#8217;s what I had said.  I&#8217;d invite you to have a look at the sentence to which you refer and read what it says.  Here it is again. </p>
<p>&#8220;I would (and do) teach them that testing is not merely a rote, mechanical task; that it&#8217;s not merely the application of engineering principles;&#8230;&#8221; </p>
<p>That&#8217;s not an assertion that engineering principles are rote mechanical tasks.  HERE is an assertion that engineering principles are rote mechancal tasks: </p>
<p>&#8220;Engineering procedures are rote, mechanical tasks.&#8221; </p>
<p>See the difference between the two sentences?  I do.  Perhaps I can help. Note that I differentiate the two in the first sentence, and equate the two in the second.  Note that I disagree with the second sentence, and stand by the first one.  Let&#8217;s go on. </p>
<p>&#8220;&#8230;that it&#8217;s not simply comparing the product with the spec; or other such simplifications.  Instead, testing is the process of investigating the product to reveal quality-related information about it, for people to whom that information might matter.&#8221; </p>
<p>You agree with that, don&#8217;t you? </p>
<p>You suggest&#8230; </p>
<p>&#8220;Software testing is a professional discipline in the field of computer science.&#8221; </p>
<p>I think that&#8217;s true to some degree.  Alas it&#8217;s not very well supported by the certain professional organizations in the field itself.  The content of the ACM/IEEE&#8217;s curriculum guide to this day is less than one full course in a four-year program.  I wish those guidelines addressed testing more; as it is, the I think professional organizations trivialize it. </p>
<p>So to be clear, testing IS a professional discipline in the field of computer science, but it&#8217;s also much more than that.  Testing involves asking questions about the way humans interact with the software.  It involves asking questions about the way that humans can make mistakes as they&#8217;re developing software, and as they&#8217;re testing it.  So in additional to technical skills, we need other kinds of skills too. </p>
<p>I agree when you say that &#8220;Techniques are not rote mechanical tasks&#8221;, but I fear that they can become that way if we teach testers that other skills aren&#8217;t important too.  In your original post, you assert &#8220;I am not an expert in systems thinking, cognitive psychology, or epistemology.&#8221;  I&#8217;m not either, but I have studied them a good deal in the effort to gain more expertise.  The value that these studies provide to me is that they add to &#8220;great breadth of knowledge and the skills&#8221;, and help me to understand ways in which &#8220;there is not a single approach that works in all scenarios&#8221;, as you put it.  Technical skills are important things, but they&#8217;re not the only important things. </p>
<p>My guess is that we agree on too.  Don&#8217;t we?  It&#8217;s weird; I see you objecting strenuously to my message, and then proceeding to agree violently with it on many points.<br />
Thursday, September 07, 2006 10:17 AM by Michael Bolton</p>
]]></content:encoded>
	</item>
	<item>
		<title>By: testingmentor</title>
		<link>http://www.testingmentor.com/imtesty/2009/11/10/exploratory-testing-and-philosophical-psycho-babble/comment-page-1/#comment-6</link>
		<dc:creator>testingmentor</dc:creator>
		<pubDate>Tue, 10 Nov 2009 07:23:18 +0000</pubDate>
		<guid isPermaLink="false">http://testingmentor.com/imtesty/2009/11/10/exploratory-testing-and-philosophical-psycho-babble/#comment-6</guid>
		<description>Hi again Michael, 

Your assertion that techniques, or engineering principles or concepts are “merely rote, mechanical task[s]” is simply fallacious, and trivializes the excellent work of world renowned industry professionals such as Copeland, Myers, Beizer, Binder, Whittaker, etc. I would expect such a juvenile statement from someone who does not understand formal testing theory or the judicious application of techniques to improve effectiveness and efficiency; not from another professional. 

Techniques are not gimmicks or rote mechanical tasks. In fact they require a great deal of knowledge and skill to apply effectively. Techniques are not the only tools in the professional tester’s toolbox, and similar to tools techniques can be fallible if applied incorrectly or by untrained, unknowledgeable individuals. It is also no secret that all professional testers have used exploratory testing as a testing tool long before Kaner coined the term, and long before a handful of consultants exploited the phrase for monetary gain promoting it as the holy grail of software testing. 

You and I agree that great testing starts with great thinking skills. The difference is I don’t try to teach people how to think, I teach them to unlock their intellectual horsepower and use their knowledge to solve complex problems in software testing effectively and efficiently. The testing courses I teach at Microsoft and the University of Washington, and the presentations at various conferences focus on fundamental discipline knowledge and technical skills necessary to succeed as professional software testers. 

I can teach an intelligent person with great problem solving skills and who knows how to think analytically the fundamental techniques, methods, and engineering concepts and principles used in software testing. More importantly I also need to be able to assess whether or not the people I teach can effectively apply what I taught them via Human Performance Technology (HPT) models and other learning effectiveness measures. 

Software testing is not a religion, it is not a political debate between “us” and “them,” everything has context because real life doesn’t occur in a vacuum, and there are not 4 distinct schools separating testers or their approaches to solving problems in software testing. Software testing is a professional discipline in the field of computer science. Professional testers require great breadth of knowledge and the skills because there is not a single approach that works in all scenarios. At the end of the day, I think we both want professional testers making smart decisions about what and how to test each unique problem space they encounter using the most appropriate technique, method, or approach, in order to present qualified information for accurate risk assessment. 

- Bj - 
Saturday, September 02, 2006 4:34 AM by I.M.Testy</description>
		<content:encoded><![CDATA[<p>Hi again Michael, </p>
<p>Your assertion that techniques, or engineering principles or concepts are “merely rote, mechanical task[s]” is simply fallacious, and trivializes the excellent work of world renowned industry professionals such as Copeland, Myers, Beizer, Binder, Whittaker, etc. I would expect such a juvenile statement from someone who does not understand formal testing theory or the judicious application of techniques to improve effectiveness and efficiency; not from another professional. </p>
<p>Techniques are not gimmicks or rote mechanical tasks. In fact they require a great deal of knowledge and skill to apply effectively. Techniques are not the only tools in the professional tester’s toolbox, and similar to tools techniques can be fallible if applied incorrectly or by untrained, unknowledgeable individuals. It is also no secret that all professional testers have used exploratory testing as a testing tool long before Kaner coined the term, and long before a handful of consultants exploited the phrase for monetary gain promoting it as the holy grail of software testing. </p>
<p>You and I agree that great testing starts with great thinking skills. The difference is I don’t try to teach people how to think, I teach them to unlock their intellectual horsepower and use their knowledge to solve complex problems in software testing effectively and efficiently. The testing courses I teach at Microsoft and the University of Washington, and the presentations at various conferences focus on fundamental discipline knowledge and technical skills necessary to succeed as professional software testers. </p>
<p>I can teach an intelligent person with great problem solving skills and who knows how to think analytically the fundamental techniques, methods, and engineering concepts and principles used in software testing. More importantly I also need to be able to assess whether or not the people I teach can effectively apply what I taught them via Human Performance Technology (HPT) models and other learning effectiveness measures. </p>
<p>Software testing is not a religion, it is not a political debate between “us” and “them,” everything has context because real life doesn’t occur in a vacuum, and there are not 4 distinct schools separating testers or their approaches to solving problems in software testing. Software testing is a professional discipline in the field of computer science. Professional testers require great breadth of knowledge and the skills because there is not a single approach that works in all scenarios. At the end of the day, I think we both want professional testers making smart decisions about what and how to test each unique problem space they encounter using the most appropriate technique, method, or approach, in order to present qualified information for accurate risk assessment. </p>
<p>- Bj &#8211;<br />
Saturday, September 02, 2006 4:34 AM by I.M.Testy</p>
]]></content:encoded>
	</item>
	<item>
		<title>By: testingmentor</title>
		<link>http://www.testingmentor.com/imtesty/2009/11/10/exploratory-testing-and-philosophical-psycho-babble/comment-page-1/#comment-5</link>
		<dc:creator>testingmentor</dc:creator>
		<pubDate>Tue, 10 Nov 2009 07:22:55 +0000</pubDate>
		<guid isPermaLink="false">http://testingmentor.com/imtesty/2009/11/10/exploratory-testing-and-philosophical-psycho-babble/#comment-5</guid>
		<description>I think the quotes in James&#039; use of &quot;invented&quot; are intended to convey irony; they refer to the previous paragraph, in which James had to discover many things about testing for himself,  and that many of the things that he read in the literature ranged from the impractical to the preposterous.  I&#039;ve followed the same kind of path; I noticed over many years as a tester that I could identify serious problems in software without drawing cause-and-effect diagrams, and that the people who were doing the cause-and-effect diagrams were missing lots of important problems.  This was largely because they were okay at the diagramming technique, but they didn&#039;t have a sufficient understand cause and effect and other critical thinking skills. 

I&#039;m confused by your assertion that 

&quot;The idea that solutions to the problems in software testing practices and processes can be found by studying philosophy, psychology, and systems theory is twaddle.&quot;   

You seem to contradict yourself when you say, immediately after that,   

&quot;These are interesting topics and can certainly heighten a person’s ability to think abstractly and question assumptions.&quot;   

Are thinking and questioning assumptions not core to the testing mission?  You seem to agree that they are when you ask 

&quot;But, are these subjects really unique to software testing or do they also apply as equally to development, or to any other job requiring a high degree of innovation and ingenuity?&quot; 

So I&#039;m confused; if these skills are important to development (as I agree) and any other job, etc. (as I agree) are they not important to testing.  Can you help me understand?  Perhaps it would help for you to clarify your ideas about what the big problems of testing might be. 

You point out that &quot;Secondly, the problems of software testing are complex and they certainly aren’t already solved.&quot;  I don&#039;t think that James is suggesting that problems that we&#039;re having in testing have been solved; I think he&#039;s suggesting that we might find solutions if we study these other disciplines. 

I&#039;m not sure how you (or a fictitious archaeologist spouting philosophy while disclaiming it) distinguish fact and truth.  But thinking and reading about epistemology reminds me that issues related to testing and quality are subjective and fundamentally uncertain, just as you point out in your description of trying to decide whether something is a bug.  Asking &quot;wait--how do I know this?&quot; is a question that expert testers ask themselves all the time, isn&#039;t it?  I&#039;d argue that if there&#039;s not some fundamental uncertainty lurking about, I&#039;m not asking enough questions to be testing effectively. 

You suggest (and I agree) that &quot;Systems thinking is related to general systems theory which studies the organization and interdependent relationships of systems.&quot;  Isn&#039;t software testing all about questioning the organization and interdependent relationships of systems? 

You suggest (and I disagree) that &quot;general systems theory is usually applied to natural sciences and systems thinking is typically used to model human organizational behavior.&quot;  I would have thought that general systems theory is applied to systems generally (else it ceases to become general), and that systems thinking is applied to whatever systems you care to think about.  That is, I think your interpretation of general systems is specialized somehow. 

I&#039;d also suggest that in software testing we create models to help us design all of our tests, not just state transition tests.  A model is a subset of a space; it&#039;s a representation of a slice of some reality; it&#039;s a map of some territory.  We model users; we model the input space for functions; we model workflows; we model platforms; we model  everything because we can&#039;t cover everything. 

Finally, you assert &quot;the simple fact is that I don’t need to be an expert in social sciences to be successful as a professional tester.&quot;  Indeed.  These days, one doesn&#039;t have to be an expert in anything to be successful (i.e. employed) as a professional tester; one doesn&#039;t even need to be expert in testing itself.  The quality of the software that we ship and that we use is testament to that.  James (and I, and many others) would like to change that by recognizing that testing is a deeply intellectual and challenging activity; that we provide value to management and to our customers when we think critically about software in ways that others don&#039;t.   

Perhaps your focus is on what you&#039;d teach new testers.  I would (and do) teach them that testing is not merely a rote, mechanical task; that it&#039;s not merely the application of engineering principles; that it&#039;s not simply comparing the product with the spec; or other such simplifications.  Instead, testing is the process of investigating the product to reveal quality-related information about it, for people to whom that information might matter.  I contend that this work starts with thinking skills.  Where does it start for you? 

---Michael B. 
Thursday, August 31, 2006 6:43 AM by Michael Bolton</description>
		<content:encoded><![CDATA[<p>I think the quotes in James&#8217; use of &#8220;invented&#8221; are intended to convey irony; they refer to the previous paragraph, in which James had to discover many things about testing for himself,  and that many of the things that he read in the literature ranged from the impractical to the preposterous.  I&#8217;ve followed the same kind of path; I noticed over many years as a tester that I could identify serious problems in software without drawing cause-and-effect diagrams, and that the people who were doing the cause-and-effect diagrams were missing lots of important problems.  This was largely because they were okay at the diagramming technique, but they didn&#8217;t have a sufficient understand cause and effect and other critical thinking skills. </p>
<p>I&#8217;m confused by your assertion that </p>
<p>&#8220;The idea that solutions to the problems in software testing practices and processes can be found by studying philosophy, psychology, and systems theory is twaddle.&#8221;   </p>
<p>You seem to contradict yourself when you say, immediately after that,   </p>
<p>&#8220;These are interesting topics and can certainly heighten a person’s ability to think abstractly and question assumptions.&#8221;   </p>
<p>Are thinking and questioning assumptions not core to the testing mission?  You seem to agree that they are when you ask </p>
<p>&#8220;But, are these subjects really unique to software testing or do they also apply as equally to development, or to any other job requiring a high degree of innovation and ingenuity?&#8221; </p>
<p>So I&#8217;m confused; if these skills are important to development (as I agree) and any other job, etc. (as I agree) are they not important to testing.  Can you help me understand?  Perhaps it would help for you to clarify your ideas about what the big problems of testing might be. </p>
<p>You point out that &#8220;Secondly, the problems of software testing are complex and they certainly aren’t already solved.&#8221;  I don&#8217;t think that James is suggesting that problems that we&#8217;re having in testing have been solved; I think he&#8217;s suggesting that we might find solutions if we study these other disciplines. </p>
<p>I&#8217;m not sure how you (or a fictitious archaeologist spouting philosophy while disclaiming it) distinguish fact and truth.  But thinking and reading about epistemology reminds me that issues related to testing and quality are subjective and fundamentally uncertain, just as you point out in your description of trying to decide whether something is a bug.  Asking &#8220;wait&#8211;how do I know this?&#8221; is a question that expert testers ask themselves all the time, isn&#8217;t it?  I&#8217;d argue that if there&#8217;s not some fundamental uncertainty lurking about, I&#8217;m not asking enough questions to be testing effectively. </p>
<p>You suggest (and I agree) that &#8220;Systems thinking is related to general systems theory which studies the organization and interdependent relationships of systems.&#8221;  Isn&#8217;t software testing all about questioning the organization and interdependent relationships of systems? </p>
<p>You suggest (and I disagree) that &#8220;general systems theory is usually applied to natural sciences and systems thinking is typically used to model human organizational behavior.&#8221;  I would have thought that general systems theory is applied to systems generally (else it ceases to become general), and that systems thinking is applied to whatever systems you care to think about.  That is, I think your interpretation of general systems is specialized somehow. </p>
<p>I&#8217;d also suggest that in software testing we create models to help us design all of our tests, not just state transition tests.  A model is a subset of a space; it&#8217;s a representation of a slice of some reality; it&#8217;s a map of some territory.  We model users; we model the input space for functions; we model workflows; we model platforms; we model  everything because we can&#8217;t cover everything. </p>
<p>Finally, you assert &#8220;the simple fact is that I don’t need to be an expert in social sciences to be successful as a professional tester.&#8221;  Indeed.  These days, one doesn&#8217;t have to be an expert in anything to be successful (i.e. employed) as a professional tester; one doesn&#8217;t even need to be expert in testing itself.  The quality of the software that we ship and that we use is testament to that.  James (and I, and many others) would like to change that by recognizing that testing is a deeply intellectual and challenging activity; that we provide value to management and to our customers when we think critically about software in ways that others don&#8217;t.   </p>
<p>Perhaps your focus is on what you&#8217;d teach new testers.  I would (and do) teach them that testing is not merely a rote, mechanical task; that it&#8217;s not merely the application of engineering principles; that it&#8217;s not simply comparing the product with the spec; or other such simplifications.  Instead, testing is the process of investigating the product to reveal quality-related information about it, for people to whom that information might matter.  I contend that this work starts with thinking skills.  Where does it start for you? </p>
<p>&#8212;Michael B.<br />
Thursday, August 31, 2006 6:43 AM by Michael Bolton</p>
]]></content:encoded>
	</item>
</channel>
</rss>

