<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/atom10full.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.feedburner.com/~d/styles/itemcontent.css"?><feed xmlns="http://www.w3.org/2005/Atom" xmlns:openSearch="http://a9.com/-/spec/opensearch/1.1/" xmlns:georss="http://www.georss.org/georss" xmlns:gd="http://schemas.google.com/g/2005" xmlns:thr="http://purl.org/syndication/thread/1.0" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" gd:etag="W/&quot;C0cBSX0-fSp7ImA9WhRUEkw.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481</id><updated>2012-01-22T11:14:18.355+05:30</updated><category term="Everyday Bugs" /><category term="Management" /><category term="About blogging" /><category term="Testing Process" /><category term="Automation" /><category term="programming" /><category term="Learning Resource" /><title>In Pursuit Of the Elusive</title><subtitle type="html">Experiences with technology, software testing, development and management.</subtitle><link rel="http://schemas.google.com/g/2005#feed" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/posts/default" /><link rel="alternate" type="text/html" href="http://elusivebug.blogspot.com/" /><link rel="next" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default?start-index=26&amp;max-results=25&amp;redirect=false&amp;v=2" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><generator version="7.00" uri="http://www.blogger.com">Blogger</generator><openSearch:totalResults>27</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>25</openSearch:itemsPerPage><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/atom+xml" href="http://feeds.feedburner.com/InPersuitOfTheElusive" /><feedburner:info uri="inpersuitoftheelusive" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><entry gd:etag="W/&quot;CUIBQ3g_fCp7ImA9WhRQE0g.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-1485260441709428407</id><published>2011-12-08T19:42:00.000+05:30</published><updated>2011-12-08T19:42:32.644+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-12-08T19:42:32.644+05:30</app:edited><title>GTAC 2011:  Opening Keynote Address - Test is Dead</title><content type="html">&lt;iframe width="480" height="270" src="http://www.youtube.com/embed/X1jWe5rOu3g?fs=1" frameborder="0" allowfullscreen=""&gt;&lt;/iframe&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Thought provoking Keynote address from &lt;a href="http://www.gtac.biz/talks"&gt;GTAC&lt;/a&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-1485260441709428407?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/gW5NUrir5i0" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/1485260441709428407/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=1485260441709428407" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/1485260441709428407?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/1485260441709428407?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/gW5NUrir5i0/gtac-2011-opening-keynote-address-test.html" title="GTAC 2011:  Opening Keynote Address - Test is Dead" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="http://img.youtube.com/vi/X1jWe5rOu3g/default.jpg" height="72" width="72" /><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2011/12/gtac-2011-opening-keynote-address-test.html</feedburner:origLink></entry><entry gd:etag="W/&quot;D08NRX0-eSp7ImA9WhRQEks.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-4805261462397365801</id><published>2011-12-07T19:06:00.001+05:30</published><updated>2011-12-07T19:21:34.351+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-12-07T19:21:34.351+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Management" /><title>Managing the Test People : Judy McKay</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
&lt;br /&gt;
&lt;div class="separator" style="clear: both; text-align: center;"&gt;
&lt;a href="http://i43.tower.com/images/mm107284702/managing-test-people-guide-practical-technical-management-not-available-paperback-cover-art.jpg" imageanchor="1" style="clear: left; float: left; margin-bottom: 1em; margin-right: 1em;"&gt;&lt;img border="0" src="http://i43.tower.com/images/mm107284702/managing-test-people-guide-practical-technical-management-not-available-paperback-cover-art.jpg" /&gt;&lt;/a&gt;&lt;/div&gt;
&lt;br /&gt;
&lt;div style="text-align: justify;"&gt;
I'd &lt;a href="http://elusivebug.blogspot.com/2007/09/due-share-for-test-management.html" target="_blank"&gt;blogged &lt;/a&gt;previously about the lack of availability of &amp;nbsp;Test management resources and information. Here's an excellent &lt;a href="http://shop.oreilly.com/product/9781933952123.do" target="_blank"&gt;book &lt;/a&gt;by Judy McKay about this subject.&amp;nbsp;&lt;/div&gt;
&lt;div style="text-align: justify;"&gt;
Judy's style of writing is casual yet very involved in details. &amp;nbsp;Its an excellent resource new managers and leads &amp;nbsp;as well as experienced hands. &amp;nbsp;Much of what's mentioned in this book is applicable for any management position. However there are specifics&amp;nbsp;challenges on managing&amp;nbsp;&amp;nbsp;testers. Judy has provided practical approaches in dealing with these challenges.&amp;nbsp;&lt;/div&gt;
&lt;div style="text-align: justify;"&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div class="separator" style="clear: both; text-align: center;"&gt;
&lt;/div&gt;
&lt;br /&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-4805261462397365801?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/WFG-KY7x22E" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/4805261462397365801/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=4805261462397365801" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/4805261462397365801?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/4805261462397365801?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/WFG-KY7x22E/managing-test-people-judy-mckay.html" title="Managing the Test People : Judy McKay" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2011/12/managing-test-people-judy-mckay.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DUIBQ3g4eSp7ImA9WhRSEU0.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-3581582598656413657</id><published>2011-11-12T13:15:00.001+05:30</published><updated>2011-11-12T19:49:12.631+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-11-12T19:49:12.631+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Management" /><title>I'm Hiring!</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
New job openings in my group. Please click on details below:&lt;br /&gt;
&lt;br /&gt;
&lt;div class="contentlinepanel" id="requisitionDescriptionInterface.d3495e309.row1" title=""&gt;
&lt;span class="titlepage" id="requisitionDescriptionInterface.d3495e310.row1" title=""&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;&amp;nbsp;&lt;a href="http://sas.taleo.net/careersection/10080/jobdetail.ftl?lang=en&amp;amp;job=11002708" target="_blank"&gt;Sr. Analytical Tester - DDCF&lt;/a&gt;&lt;/span&gt;&lt;/div&gt;
&lt;br /&gt;
&lt;div class="contentlinepanel" id="requisitionDescriptionInterface.d3495e309.row1" title=""&gt;
&lt;span class="titlepage" id="requisitionDescriptionInterface.d3495e310.row1" title=""&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;&amp;nbsp;&lt;a href="http://sas.taleo.net/careersection/10080/jobdetail.ftl?lang=en&amp;amp;job=11003022" target="_blank"&gt;Functional Tester -- PAM&amp;nbsp;&lt;/a&gt;&lt;/span&gt;&lt;/div&gt;
&lt;div class="contentlinepanel" id="requisitionDescriptionInterface.d3495e309.row1" title=""&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-3581582598656413657?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/yU2S_56S_NA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/3581582598656413657/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=3581582598656413657" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/3581582598656413657?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/3581582598656413657?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/yU2S_56S_NA/im-hiring.html" title="I'm Hiring!" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2011/11/im-hiring.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUcNRng-eyp7ImA9WhZaEEg.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-9110969167873186706</id><published>2011-06-26T07:10:00.005+05:30</published><updated>2011-06-26T07:21:37.653+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-26T07:21:37.653+05:30</app:edited><title>Tools for Exploratory testing: In development...</title><content type="html">I'm working on developing a tool for exploratory testing.  My idea for GUI design is &lt;a href="http://en.wikipedia.org/wiki/Minimalism_%28computing%29"&gt;Minimalism&lt;/a&gt; taking into account the bare essentials required while performing an exploratory session. Screen recorder, snapshot tool, rich text editor, copy/paste, annotations.&lt;br /&gt;I've been scouting the web for various open source API and reusable code and still in very initial design and research.&lt;br /&gt;Any ideas welcome!&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-9110969167873186706?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/UMgD-JPEUXo" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/9110969167873186706/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=9110969167873186706" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/9110969167873186706?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/9110969167873186706?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/UMgD-JPEUXo/tools-for-exploratory-testing-in.html" title="Tools for Exploratory testing: In development..." /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2011/06/tools-for-exploratory-testing-in.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CEQHQHc-eSp7ImA9WhZaEEg.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-5206503608343131772</id><published>2010-03-28T17:19:00.004+05:30</published><updated>2011-06-26T07:08:51.951+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-26T07:08:51.951+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="programming" /><title>Strategy design pattern</title><content type="html">Strip the changeable method in a class to a hierarchy class.&lt;br /&gt;ie changing a 'has-a' relationship to an 'is-a' relationship&lt;br /&gt;Introduction: http://www.youtube.com/watch?v=9n3gF39-trE&lt;br /&gt;Overview : http://www.youtube.com/watch?v=F1841_llRSw&amp;amp;NR=1&lt;br /&gt;Coding : http://www.youtube.com/watch?v=vYByr2u8gqk&amp;amp;feature=related&lt;br /&gt;Execution: http://www.youtube.com/watch?v=mmiWFcjMTLw&amp;amp;feature=related&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-5206503608343131772?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/HLb6ioMBhGo" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/5206503608343131772/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=5206503608343131772" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/5206503608343131772?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/5206503608343131772?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/HLb6ioMBhGo/strategy-design-pattern.html" title="Strategy design pattern" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2010/03/strategy-design-pattern.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CEQDRnc4cCp7ImA9WhZaEEg.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-3833076600449321191</id><published>2010-03-28T17:08:00.004+05:30</published><updated>2011-06-26T07:09:37.938+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-26T07:09:37.938+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="programming" /><title>Design Patterns Study Session: Decorator Pattern</title><content type="html">Here's an excellent description of the Decorator Pattern:&lt;br /&gt;Usage of wrapper to extend the functionality of a class without modifying the original class.&lt;br /&gt;&lt;br /&gt;Introduction : http://www.youtube.com/watch?v=Xk8durvtiys&amp;amp;feature=related&lt;br /&gt;Overview        http://www.youtube.com/watch?v=MI_qyfeRk8c&amp;amp;feature=related&lt;br /&gt;Code:               http://www.youtube.com/watch?v=HkOdDMePE4Q&amp;amp;feature=related&lt;br /&gt;Executing http://www.youtube.com/watch?v=Ra-33SFHq6M&amp;amp;feature=related&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-3833076600449321191?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/_Ph4hLBljD0" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/3833076600449321191/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=3833076600449321191" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/3833076600449321191?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/3833076600449321191?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/_Ph4hLBljD0/design-patterns-study-session-decorator.html" title="Design Patterns Study Session: Decorator Pattern" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2010/03/design-patterns-study-session-decorator.html</feedburner:origLink></entry><entry gd:etag="W/&quot;AkEGQH0_cCp7ImA9WxBaF0g.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-8188303391083606675</id><published>2010-03-28T12:03:00.002+05:30</published><updated>2010-03-28T12:13:41.348+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-03-28T12:13:41.348+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Automation" /><title>Design Patterns in Automation</title><content type="html">&lt;a href="http://at4qa.blogspot.com/"&gt;Peter Kartashov&lt;/a&gt; has an interesting blogpost on application of design patterns in test automation. &lt;a href="http://at4qa.blogspot.com/2010/01/20-essential-design-patterns-for.html"&gt;http://at4qa.blogspot.com/2010/01/20-essential-design-patterns-for.html&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-8188303391083606675?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/FG5qEbMY1GA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/8188303391083606675/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=8188303391083606675" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8188303391083606675?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8188303391083606675?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/FG5qEbMY1GA/design-patterns-in-automation.html" title="Design Patterns in Automation" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2010/03/design-patterns-in-automation.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CE8MSXw5fyp7ImA9WxBQEU8.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-8418972155574166150</id><published>2010-01-09T16:41:00.012+05:30</published><updated>2010-01-10T16:58:08.227+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-01-10T16:58:08.227+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Learning Resource" /><title>Reading HWTSAM</title><content type="html">&lt;div style="TEXT-ALIGN: justify"&gt;I realized only after I got a ping from &lt;a href="http://testertested.blogspot.com/"&gt;Pradeep &lt;/a&gt;that its been quite a while since I've visited by own blog, leave along adding new blog posts.&lt;/div&gt;&lt;div style="TEXT-ALIGN: justify"&gt;Its my usual excuse as the case is from any IT folk, release pressures, busy schedules, blah, blah.....&lt;/div&gt;&lt;div style="TEXT-ALIGN: justify"&gt;I've picked up a copy of &lt;a href="http://www.hwtsam.com/"&gt;'How we test software at Microsoft'&lt;/a&gt; and half way done with the book when I came across a very interesting story from &lt;a href="http://www.hwtsam.com/page/About-Bj.aspx"&gt;Bj Rollison &lt;/a&gt;one of the co-authors of the book. Here's how the abridged version goes.&lt;/div&gt;&lt;div style="TEXT-ALIGN: justify"&gt;&lt;br /&gt;&lt;/div&gt;&lt;em&gt;&lt;div style="TEXT-ALIGN: justify"&gt;A kindergarten teacher asked her students 'Who knows the color of the apples?' Several students raised their their hands followed by the answers, some mentioned red, others green and few other yellow. The teacher thanked the students for their answer , the appreciated their knowledge of apples and was about continue with her lesson when she noticed a little girl with her hands still raised. The teacher called upon the child and the little girl replied 'apples are white'. The somewhat puzzled teacher politely replied, 'Elizabeth, the apples are red, green and yellow, but I've not seen a white apple'. Elizabeth peered over the glasses looked at the teacher and bluntly declared, 'All apples are white on the inside!'&lt;/div&gt;&lt;/em&gt;&lt;div style="TEXT-ALIGN: justify"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="TEXT-ALIGN: justify"&gt;Rollinson describes the story as a prelude to describing structural testing techniques. However the story brings into perspective what many testers fear &lt;a href="http://searchsoftwarequality.techtarget.com/news/article/0,289142,sid92_gci1256314,00.html"&gt;testing traps!&lt;/a&gt;&lt;/div&gt;&lt;div style="TEXT-ALIGN: justify"&gt;HWTSAM is certainly a good book and must read for all testers. More reviews to follow once I complete the book.&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-8418972155574166150?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/nYk2MCNSeJc" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/8418972155574166150/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=8418972155574166150" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8418972155574166150?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8418972155574166150?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/nYk2MCNSeJc/reading-hwtsat.html" title="Reading HWTSAM" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2010/01/reading-hwtsat.html</feedburner:origLink></entry><entry gd:etag="W/&quot;AkUBQX07fCp7ImA9WxVbE08.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-3574951951609732814</id><published>2009-03-29T16:58:00.004+05:30</published><updated>2009-03-29T17:34:10.304+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2009-03-29T17:34:10.304+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Learning Resource" /><title>Course in Basic Statistics</title><content type="html">Those who're are interested to learn statistics, here's a very good &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_0"&gt;resource&lt;/span&gt;. &lt;a href="http://webcast.berkeley.edu/course_details.php?seriesid=1906978493"&gt;http://webcast.berkeley.edu/course_details.php?seriesid=1906978493&lt;/a&gt; . This is the video recordings for the "Stats 2 Introduction to Statistics" of &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_1"&gt;UC&lt;/span&gt; Berkeley. Instructor Prof. Hank &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_2"&gt;Ibser&lt;/span&gt; lectures are pretty interesting to listen to. The unfortunate part is that you do not have access to the course website where you have access to the &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_3"&gt;homework&lt;/span&gt; and the other course materials.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-3574951951609732814?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/TkAvWU92NhE" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/3574951951609732814/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=3574951951609732814" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/3574951951609732814?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/3574951951609732814?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/TkAvWU92NhE/course-in-basic-statistics.html" title="Course in Basic Statistics" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2009/03/course-in-basic-statistics.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DEcNRXg7cSp7ImA9WxVbE08.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-492190286558616472</id><published>2008-08-25T20:33:00.005+05:30</published><updated>2009-03-29T16:58:14.609+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2009-03-29T16:58:14.609+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>Practical Estimation Lesson</title><content type="html">In wring this blog as response to the comment from Raj in one of my &lt;a href="http://elusivebug.blogspot.com/2007/03/gutless-estimating-excerpts-from.html"&gt;earlier post&lt;/a&gt;. He's asked me about the estimation techniques I use for testing efforts.&lt;br /&gt;&lt;div align="justify"&gt;I've never used any standard estimation process such as Function point analysis, &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_0"&gt;COCOMO&lt;/span&gt; etc. Testing estimation always is very much tied to the development estimates. So an independent estimation &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_1"&gt;without&lt;/span&gt; &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_2"&gt;taking&lt;/span&gt; into consideration development &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_3"&gt;schedules&lt;/span&gt; always fails. At a very high level, I ask team members and test leads to use work break down structure (&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_4"&gt;WBS&lt;/span&gt;) to estimate how much it'd take to complete the task on an optimistic and &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_5"&gt;pessimistic&lt;/span&gt; count. I've found &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_6"&gt;WBS&lt;/span&gt; method to be effective when testers have performed similar task &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_7"&gt;previously&lt;/span&gt;. These estimates are subjective, and that is also fine. Behavioural and emotional factors also comes into picture when it comes to &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_8"&gt;estimation&lt;/span&gt; in &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_9"&gt;WBS&lt;/span&gt;. It always helps if you meet as a group and ask 'why'/'what-if'/'how' questions to &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_10"&gt;further&lt;/span&gt; refine the estimates. Probing questions can be 'why is time taken for testing &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_11"&gt;testing&lt;/span&gt; the feature more on Unix than on windows?', 'did you consider the factor in your estimates that feature XXX may be unstable because its based on a libraries our developers had inherited from a team that no longer exist?', 'how did you come up with this estimate?'. Many of these questions are intrusive in nature, some testers may be &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_12"&gt;uncomfortable&lt;/span&gt; with this style. However, the team lead/manager should remember the need to perform this within a team meeting context. It requires to be stated very clearly that its the process that is being questioned and not the person .&lt;br /&gt;What I typically do, is to have a 'long-term' estimate for the management when the project is initiated. This is generally a one-time estimate and as a test manager, you'd need to convince the stakeholders that the estimates comes with 'risk'. Identification of risks is important at this stage, and the most important risk is the 'risk the feature not delivered for testing in the schedule time', 'no clarity on what the requirement is' etc. &lt;/div&gt;&lt;div align="justify"&gt;What I also do is to have internal estimates of individual tasks. These are 'near-term' estimates of individual tasks. These tasks are more granular and gives a foresight of tasks for typically next 3 weeks. Tasks performed by individual team member tasks should be stated to a level not exceeding 2 to 3 days. These estimates are more realistic and have dependencies. For example, these tasks can be very &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_13"&gt;specific&lt;/span&gt; something like 'verify defect fixed in last 2 weeks', 'test the fund transfer module for inoperative accounts', 'get the latest build installed on the &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_14"&gt;UNIX&lt;/span&gt; box', 'review the latest modifications for the user doc'. For each and every task &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_15"&gt;taken-up&lt;/span&gt; by team members, a standard question to be asked is 'how long will it take?'. In my experience, typically for a mid-sized project, on a typically day, you may tend to ask this question over 3 to 4 times. Often so, every one in the team gets used to this question that they have this answer ready. It helps to track the near-term estimates if you are using a spread sheet or similar project tracking tools. &lt;/div&gt;&lt;div align="justify"&gt;From my experience and the context in which we are working on, the stakeholders are more interested progress of work rather than the estimates. Enough advanced communication with the stakeholders about the progress, issues and risks are more important than the accuracy of the estimates. &lt;/div&gt;&lt;div align="justify"&gt;With enough experience in the project, you can derive your next long term extimate from your previous near-term estimates. I've heard of "&lt;a href="http://en.wikipedia.org/wiki/Wideband_delphi"&gt;Wideband Delphi&lt;/a&gt;" estimation and seems to be a promising technique for estimating testing efforts. &lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-492190286558616472?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/XWP8I_sXd68" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/492190286558616472/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=492190286558616472" title="3 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/492190286558616472?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/492190286558616472?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/XWP8I_sXd68/practical-estimation-lession.html" title="Practical Estimation Lesson" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>3</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2008/08/practical-estimation-lession.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUcNQnoyfCp7ImA9WxdbEko.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-6225890581734014499</id><published>2008-08-09T12:54:00.004+05:30</published><updated>2008-08-09T14:41:33.494+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-08-09T14:41:33.494+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>Test Cases as security blanket</title><content type="html">&lt;div align="justify"&gt;There's a raging controversy going on,  at least in the Indian software testing community about "test cases centric testing" vs "non test cases centric" testing. Pradeep has posted &lt;a href="http://testertested.blogspot.com/2008/07/most-test-cases-fail.html"&gt;here &lt;/a&gt;at length on this subject, also has the imprints of the controversy all over the web, from forum posts to blogs to yahoo groups. &lt;/div&gt;&lt;p align="justify"&gt;My take on this is to consider a test case as a security blanket. Wiki defines &lt;a href="http://en.wikipedia.org/wiki/Security_blanket"&gt;security blanket &lt;/a&gt;as &lt;em&gt;"A security blanket is any familiar object whose presence provides comfort or security to its owner, such as the literal &lt;/em&gt;&lt;a title="Blanket" href="http://en.wikipedia.org/wiki/Blanket"&gt;&lt;em&gt;blankets&lt;/em&gt;&lt;/a&gt;&lt;em&gt; often favoured by small children&lt;/em&gt;". It gives the sense of comfort for the person using it. &lt;em&gt;"Person"&lt;/em&gt; I mean not just testers running the test script but also developers developing the product, product managers or end customers. Everyone derives comfort from the fact that &lt;em&gt;"test cases have been executed and passed"&lt;/em&gt;&lt;/p&gt;&lt;p align="justify"&gt;Are security blankets necessarily bad? certainly not!. For me as a test manager, it gives me comfort ( and thereby the sense of security) to the fact that the software &lt;em&gt;I'm going to sign-off will not fail when used within the confines of the test scenarios that my team has found to be passing.&lt;/em&gt; Does it mean that my test cases are foolproof /security blanket is without holes? Certainly not and its my responsibility as a test manager to make it understand to the stakeholders that the test cases are never foolproof. &lt;/p&gt;&lt;p align="justify"&gt;To find bugs in a software is the most important responsibility of a test team and a set of predefined execution paths ( aka test cases ) will certainly not find many defects. But the test cases has its rightful and important place as a security blanket within the confines of a software development cycle. During the final phases of the release cycle, several rounds of test cases executions provide the necessary confidence to the stakeholders that the product is ready for release. &lt;/p&gt;&lt;div align="justify"&gt;Again, I've never seen anyone questioning "&lt;em&gt;what's a test case?&lt;/em&gt;" all thoughout the controversy.  When I mention a test case in this blogpost, I'd need to make it clear that "I" mean by a "test case". This will be a topic for another blogpost.&lt;/div&gt;&lt;p align="justify"&gt;Equate test cases to &lt;a href="http://en.wikipedia.org/wiki/Comfort_object"&gt;comfort object&lt;/a&gt; ; certainly not harmful in anyway and certainly provide the psychological  strength. To conclude it all, software development is all about human behavior and interactions!&lt;br /&gt;&lt;/p&gt;&lt;p align="justify"&gt;&lt;br /&gt; &lt;/p&gt;&lt;div align="justify"&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-6225890581734014499?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/kQCx8imOvO0" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/6225890581734014499/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=6225890581734014499" title="6 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/6225890581734014499?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/6225890581734014499?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/kQCx8imOvO0/test-cases-as-security-blanket.html" title="Test Cases as security blanket" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>6</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2008/08/test-cases-as-security-blanket.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DEUGSX4_cCp7ImA9WxdbEks.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-6571396829299210376</id><published>2008-07-28T18:48:00.007+05:30</published><updated>2008-08-09T12:47:08.048+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-08-09T12:47:08.048+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>Lessons From an Expert.</title><content type="html">&lt;div align="justify"&gt;Last two days my team had attended a class on &lt;a href="http://www.edistatesting.com/index.php?option=com_content&amp;amp;view=article&amp;amp;id=82"&gt;Skilled &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_0"&gt;Exploratory&lt;/span&gt; Testing &lt;/a&gt;from the expert himself, &lt;a href="http://testertested.blogspot.com/"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_1"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_0"&gt;Pradeep&lt;/span&gt;&lt;/span&gt; &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_2"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_1"&gt;Soundararajan&lt;/span&gt;&lt;/span&gt;&lt;/a&gt;. More than the classroom sessions, it was the interactions we had with &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_3"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_2"&gt;Pradeep&lt;/span&gt;&lt;/span&gt; that made a difference. It had reinforced many a of my personal beliefs about testing and also busted some of the myths.&lt;br /&gt;&lt;br /&gt;I'd always believed that testing a software product was an intellectual exercise, its a skill that needs to be practiced and the practitioners will get better at it by "&lt;em&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_3"&gt;riyaz&lt;/span&gt;"&lt;/em&gt; aka practise. For those who'd like to know about &lt;a href="http://www.pathcom.com/~ericp/bansuri11simms.pdf"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_4"&gt;riyaz&lt;/span&gt; &lt;/a&gt;here the link of what it means to a musician. We can relate what it means to a software tester. &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_5"&gt;Pradeep&lt;/span&gt; had demonstrated what can be &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_6"&gt;achieved&lt;/span&gt; by &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_7"&gt;riyaz&lt;/span&gt; with 1 hour of exploratory testing of a product he's never seen before! &lt;/div&gt;&lt;div align="justify"&gt;&lt;br /&gt;I'd believed my team always did exploratory testing, this was reinforced to some degree but also we found some flaws in the process we'd been following. Most of the testers did not follow a "written script" of any kind while they were testing. Even those who had a script, may not have followed it in letter or spirit. Most of our testers did not really document when they were 'exploring' the product. The mission statement for the exploratory testing session they performed was often in their head and changing when they were testing. They were &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_8"&gt;focused&lt;/span&gt; on the activity, but the testing "sessions" were often long, extending over days or even weeks. We &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_9"&gt;didn't&lt;/span&gt; have a debriefing meeting.  Defect finding, investigations, debugging, environment creation, data creation, even status meetings were all part of these "sessions" ( or whatever name we'd have given to this &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_10"&gt;until&lt;/span&gt; of time" ) . On the other hand, we were not bounded by any detailed written scripts that stated, "click this", "click that", "if this than pass, if not then fail". At least we did not take away the creativity from the testers, but then again we did not have a structure were by we could focus the testers creativity. Important thing to note, we were finding defects in the product, critical ones and all of us were getting better and better at finding defects and that's whats expected from a testing team. &lt;/div&gt;&lt;div align="justify"&gt;&lt;br /&gt;There are tools that we could use to &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_11"&gt;amplify&lt;/span&gt; our effectiveness, pair-testing, heuristics, oracles and many more. Again, automated test execution has its rightful place and so do "intelligent human testing", one is never a &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_12"&gt;substitute&lt;/span&gt; for the other.&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-6571396829299210376?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/542IKa9Eyj8" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/6571396829299210376/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=6571396829299210376" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/6571396829299210376?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/6571396829299210376?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/542IKa9Eyj8/lessons-from-expert.html" title="Lessons From an Expert." /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2008/07/lessons-from-expert.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CEUGQH8_cSp7ImA9WxdWGEo.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-6543302460525709268</id><published>2008-07-12T19:35:00.003+05:30</published><updated>2008-07-12T19:47:01.149+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-07-12T19:47:01.149+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Management" /><title>The Final Days And The Finish Line!</title><content type="html">The past several weeks were rather hectic. We were reaching the end of release our our product. From the &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_0"&gt;inception&lt;/span&gt; of the project to the final testing signoff, its been two long years.&lt;br /&gt;The final build had arrived last week and our testing team had performed the routine sanity checks on all the four supported operating systems.&lt;br /&gt;Activity of the signoff was rather a non-event. A simple click on a "signed-off" checkbox.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-6543302460525709268?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/xO51AfxhdOc" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/6543302460525709268/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=6543302460525709268" title="3 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/6543302460525709268?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/6543302460525709268?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/xO51AfxhdOc/final-days-and-finish-line.html" title="The Final Days And The Finish Line!" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>3</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2008/07/final-days-and-finish-line.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CU8BQnY7fip7ImA9WxZVGEo.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-2649368578935783267</id><published>2008-03-23T08:55:00.007+05:30</published><updated>2008-03-30T16:14:13.806+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-03-30T16:14:13.806+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>Regression Testing:What is it anyway?</title><content type="html">My project is in the 'Regression Testing' phase. So I felt it was &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_0"&gt;appropriate&lt;/span&gt; to have a blogpost on regression testing. I did a quick googling and came up with some definitions &lt;a href="http://en.wikipedia.org/wiki/Regression_testing"&gt;here &lt;/a&gt;and &lt;a href="http://www.testingcenter.com/c100mr00.html"&gt;here &lt;/a&gt;and &lt;a href="http://www.wrox.com/WileyCDA/Section/id-291252.html"&gt;here&lt;/a&gt; and many more. These definitions do make sense, but the crux of the matter is where do these explanations fit into the context of my project?&lt;br /&gt;To put it in simple terms, regression testing is one step in the of the following sequence of events in the life of a software tester:&lt;br /&gt;Testers find bugs, developers fixed it, testers verify the defect fixes, testers again tests, find new bugs. developer fix them and so on and so on...&lt;br /&gt;The regression testing is "testers again tests, find new bugs".&lt;br /&gt;Testers in my project have been working for the past several months, testing various aspects of the application, finding defects, getting those fixed. Eventually a times comes when the defect finding rate comes down and the application is "relatively stable".&lt;br /&gt;&lt;br /&gt;The questions from a person not involved in the project will be as below.&lt;br /&gt;&lt;em&gt;&lt;/em&gt;&lt;br /&gt;&lt;em&gt;Q) So is the application ready for release? &lt;/em&gt;&lt;br /&gt;A) For sure not!&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;em&gt;Q) What else is remaining to be done, you've completed all the application features you've planned to test?&lt;/em&gt;&lt;br /&gt;A) We've to test for regressions.&lt;br /&gt;&lt;br /&gt;&lt;em&gt;Q) Is'nt that what you've been doing all these days?&lt;/em&gt;&lt;br /&gt;A) Nope! We were doing the 1st round of testing until now. We were hunting for defects in the application. We've ensured that the defect fixes provided to us fixes the specific problem we've raised. And that's all we've done.&lt;br /&gt;&lt;br /&gt;&lt;em&gt;Q) What more you've to do?&lt;/em&gt;&lt;br /&gt;A) The defect fixes made in the application may have introduced more defects, we've got to find them. We call them regression testing.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;em&gt;Q) So what's it that you've not done in your 1st round of testing that you've gonna do in regression testing?&lt;/em&gt;&lt;br /&gt;A) One thing for sure, test the application again. Rerun the test cases and scenario we've already executed.&lt;br /&gt;&lt;br /&gt;&lt;em&gt;Q) Why did'nt you do the regression testing earlier?&lt;/em&gt;&lt;br /&gt;A) Because the application had defects, defects were being fixed, lots of code churn happening. Its not the good time to start regression testing. Regression testing should start only when the defects are "under control". Regression testing can start only the changes to the code is so much under control that the sanity test suites can be executed on the entire application to ensure there are no additional problems introduced in the code as a result of the defect fixes.&lt;br /&gt;&lt;br /&gt;Q) What's this "under control" thing you keep referring to?&lt;br /&gt;A) When the product was delivered to testing at the begining of the testing phase we were finding on the average 15 defects a day. Out of these lets say on the average 10 defects were getting fixed. With so much defects getting fixed and even when new features were sneaked in into the code nobody kept a watch on how these code changes are doing to affect the application. Testers where busy finding new defects in the application and testing newer and newer areas of the application for the first time. Testers never had the time to check if "a particular" defect fix has broken something that was already working. Developers never had the time to see how their fix in one area of the application is going to integrate with the rest of the application. Now things are different. Testers have completed testing the application as a whole, average number of new defect found per day is very low, maybe one or two. Developers have lesser number of defects to deal with. Developers now can do detailed impact analysis of how their fix will impact the rest of the application. They in turn can pass this information to testers. Testers in turn know where to focus their thier efforts&lt;br /&gt;&lt;br /&gt;&lt;p&gt;&lt;/p&gt;&lt;p&gt;&lt;em&gt;Q) And when are you doing to release this?&lt;/em&gt;&lt;/p&gt;&lt;p&gt;A) As soon as the 1st regression test is complete, we'd go in for a relatively faster 2nd regression test. This should give us an gut feel of the quality of the product. As soon as the 2nd or third regression test do not detect any major new defects we are ready for release.&lt;br /&gt;&lt;/p&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-2649368578935783267?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/MoP8H-BtGWg" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/2649368578935783267/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=2649368578935783267" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/2649368578935783267?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/2649368578935783267?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/MoP8H-BtGWg/regression-testingwhat-is-it-anyway.html" title="Regression Testing:What is it anyway?" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2008/03/regression-testingwhat-is-it-anyway.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DUMEQnY_cSp7ImA9WxZSFU0.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-2783265184937809306</id><published>2008-01-11T08:20:00.000+05:30</published><updated>2008-01-28T13:33:23.849+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-01-28T13:33:23.849+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>Automating Tests: A Suggested Classification</title><content type="html">My last &lt;a href="http://elusivebug.blogspot.com/2007/12/lessons-learned-implementing-dbvte.html"&gt;Post &lt;/a&gt;had described about the our teams experiences in implementing an automated build verification tests. There's been lot of talk and blog post over pros and cons of automated execution of test scripts during past couple of weeks. &lt;a href="http://www.satisfice.com/blog/archives/118"&gt;This post &lt;/a&gt;Post in James Bach's blog and Steve Rowe's &lt;a href="http://blogs.msdn.com/steverowe/archive/2007/12/19/what-is-test-automation.aspx"&gt;this post &lt;/a&gt;are indicative of where the discussions are heading.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;I've found automated execution of test as a significant productivity booster for testers. It relieves testers from the drudgery of &lt;span style="color:#ffff00;"&gt;&lt;span style="color:#000000;"&gt;re-running&lt;/span&gt; &lt;/span&gt;tests that were already executed and found to pass.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;The current project I'm working on is first version of a business intelligence suite. Being the first version, there's quite of lot of GUI redesign and this is a challenge for development of automated test. However we've been successful in getting the initial level of test automated and successfully executed on &lt;a href="http://elusivebug.blogspot.com/2007/12/lessons-learned-implementing-dbvte.html"&gt;daily images&lt;/a&gt; &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_1"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_0"&gt;vericiations&lt;/span&gt;&lt;/span&gt;.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;We've been fortunate in our project to learn from the mistakes made from other project groups as far as automation approach is concerned.&lt;br /&gt;&lt;br /&gt;We've taken the approach for classification of tests to be automated under the following levels. &lt;strong&gt;Level-0&lt;/strong&gt; or build verification tests, &lt;strong&gt;Level-1&lt;/strong&gt; or happy path tests, &lt;strong&gt;Level-2&lt;/strong&gt; or error conditions, &lt;strong&gt;Level-3&lt;/strong&gt; or detailed user scenarios &lt;strong&gt;Level-4&lt;/strong&gt; advanced automation strategies.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;Level-0&lt;/strong&gt; tests are used to check the testability of the product. This is &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_2"&gt;preferably&lt;/span&gt; executed on your daily build before this is released for testing. The level-0 tests are often the first to get automated. These tests are also known as smoke tests.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;Level-1&lt;/strong&gt; tests are used to test the positive paths of the application, mostly focusing your test goals on testing the application features from the user interface. For example, in an banking application, test for correctness of balance', 'check for transfer from one account to another' 'check for clearing of check'. These tests check for your correctness of your GUI and check for the integration of the GUI with the overall system.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;Level-2&lt;/strong&gt; These will be automated tests for checking the error conditions or conditions that do not occur on normal working of the application. In case of the banking application, this may be be something like 'test for check &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_4"&gt;bouncing&lt;/span&gt;', 'test for incorrect signature matches' etc.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;Level-3&lt;/strong&gt; test are the detailed user cases. For example, create a scenario where a customer opens an accounts and does couple of deposits and withdrawal and closes the account. A suite of these tests can also be used as user acceptance tests.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;Level-4&lt;/strong&gt; These are tests that typically cannot be carried out without the aid of an tool. &lt;a href="http://www.kaner.com/pdfs/highvolCSTER.pdf"&gt;High Volume Test Automation&lt;/a&gt; is a good example of this type of tests. For a banking application, simulating a typical year end closing procedure or executing hundreds of concurrent accounting transactions.&lt;br /&gt;&lt;br /&gt;These classification of test needs to be looked at withing the context of the project in which you are testing. The levels are not really a &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_5"&gt;classification&lt;/span&gt; of the order in which the automation project should be implemented. You may very well have tests automated from level-0 and level-2 , skip tests in level 1, level3 and automate tests in level-4&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-2783265184937809306?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/fwiIUrFatdw" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/2783265184937809306/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=2783265184937809306" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/2783265184937809306?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/2783265184937809306?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/fwiIUrFatdw/automating-your.html" title="Automating Tests: A Suggested Classification" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2008/01/automating-your.html</feedburner:origLink></entry><entry gd:etag="W/&quot;D0UGRno_fSp7ImA9WB9bGU4.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-8527674988089602726</id><published>2007-12-29T18:52:00.000+05:30</published><updated>2007-12-29T19:03:47.445+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-12-29T19:03:47.445+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>Lessons Learned Implementing DBVTE</title><content type="html">&lt;div align="justify"&gt;"&lt;strong&gt;DBVTE&lt;/strong&gt;" is an acronym I'd made up about 2 minutes ago when I decided to blog this. It stands for &lt;strong&gt;Daily Build Verification Test Executions&lt;/strong&gt;.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;The Background:&lt;/strong&gt;&lt;br /&gt;&lt;br /&gt;My current project has gained much notoriety among testing team for the poor quality builds delivered for testing. Early in the project iterations, the issue was there was no testing build at all. Later on after much delay the daily build process was finally got booted up. But then it came up with its on set of issues. Lack of a coherent integration test ensured the daily builds never work as a single unit. It'd be a miracle if build picked on any particular day will be of minimum quality for testers to start the tests. The situation demanded a consistent way of delivering testable builds on a periodic basis.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;The Approach:&lt;/strong&gt;&lt;br /&gt;&lt;br /&gt;The way to go here was for the functional testing team to take-up the integration testing activity. We'd started with documenting the bare minimum use case &amp;amp; scenarios of the product in sufficient detail that a novice computer user could read the document and execute those scenarios. These were written mostly from a GUI perspective like "Step 7. click OK button", "Step 11. Right Click, select Edit From Menu", "Step 23. Verify Graph". These are also called smoke tests or sanity tests. &lt;/div&gt;&lt;div align="justify"&gt;&lt;br /&gt;The important activity here was to identify a dedicated machine for the integration testing purpose. Its very important to have a consistent, reproducible and stable environment for the integration testing machine. &lt;/div&gt;&lt;div align="justify"&gt;&lt;br /&gt;Now that the nightly builds were getting build, we'd developed a series of simple windows batch scripts. The purpose of these scripts were to download the build files ( java jar files, codes developed in SAS scripts, configuration files...) from build machine. The scripts did administrative activities such as stopping the application services, restarting services etc as well lay down the build files like the installer would have performed. The purpose of the script was to eliminate human error in the installation process and to save the time in the install process. A typical install process of the application we test will require 3 hours of install &amp;amp; configuration time. The automated install scripts does this in 10 minutes flat!. &lt;/div&gt;&lt;div align="justify"&gt;&lt;br /&gt;We'd chosen the "&lt;a href="http://safsdev.sourceforge.net/"&gt;SAFS&lt;/a&gt;" as our automation tool for automating the smoke tests. Although its not mandatory to automate your smoke tests, we'd taken the approach to automate primarily to ease the drudgery of executing the tests by a human tester. SAFS is an excellent tool and it very neatly took care of incremental changes to the application. Moreover SAFS is developed and supported within our company.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;The Process: &lt;/strong&gt;&lt;br /&gt;&lt;br /&gt;Now that we've had the tools in place, its time to work on the process around it. The most important part of any process is to get the buy in from the stakeholders. The good part about it was the development and project mangers were already aware of the problem with integration. Just that they never had given enough thoughts about how to tackle the problem. Our case is that we've the tools in place for integration tests. A quick demo of the automated install scripts and the automated smoke test was a very well accepted. Now was the case to present the case for the process and the development teams commitment for the process. &lt;/div&gt;&lt;br /&gt;&lt;div align="justify"&gt;The process was simple; testing team will download daily builds from the build machine, execute the automated scripts and send in the results of executions to the entire team. In case of defects, encountered in the automated scripts, these will be logged and will be part of the execution results. The development team on its part, should fix the defects immediately or back out the changes in the next build.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;The Lessons:&lt;/strong&gt;&lt;br /&gt;&lt;/div&gt;&lt;strong&gt;&lt;ol&gt;&lt;li&gt;&lt;div align="justify"&gt;&lt;/strong&gt;Developing Automation scripts of any GUI tests is hard. We were baffled bySAFS automation tool limitations for which workaround were found. Our GUI was developed on &lt;a href="http://en.wikipedia.org/wiki/Eclipse_(software)"&gt;Eclipse&lt;/a&gt; framework and support for it was limited in SAFS.&lt;/div&gt;&lt;/li&gt;&lt;li&gt;&lt;div align="justify"&gt;Development of Automation scripts for GUI is incremental. Develop scripts with smaller features, test, stabilize and then operationally. &lt;/div&gt;&lt;/li&gt;&lt;li&gt;&lt;div align="justify"&gt;Concentrate on the breadth of the functionality, not the on the depth while developing the smoke tests. Check all basic features of the application rather than the complex features.&lt;/div&gt;&lt;/li&gt;&lt;li&gt;&lt;div align="justify"&gt;Automate the install and configuration process of daily builds. This will avoid human error in the installation as well as speedup the installation process.&lt;/div&gt;&lt;/li&gt;&lt;li&gt;&lt;div align="justify"&gt;Start with a clean machine for installing the first build on the integration machine. In case of windows, format and reinstall the OS. On Unix, this process is expensive.&lt;/div&gt;&lt;/li&gt;&lt;li&gt;&lt;div align="justify"&gt;Cherish your process. Follow your integration process religiously and advocate it within your entire team. &lt;/div&gt;&lt;/li&gt;&lt;/ol&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-8527674988089602726?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/8aCxWQOF5og" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/8527674988089602726/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=8527674988089602726" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8527674988089602726?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8527674988089602726?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/8aCxWQOF5og/lessons-learned-implementing-dbvte.html" title="Lessons Learned Implementing DBVTE" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/12/lessons-learned-implementing-dbvte.html</feedburner:origLink></entry><entry gd:etag="W/&quot;Dk8HRnk-fSp7ImA9WB9UF0U.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-174596693473760548</id><published>2007-12-16T11:14:00.000+05:30</published><updated>2007-12-16T11:30:37.755+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-12-16T11:30:37.755+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="About blogging" /><title>Search Power @ Google Reader</title><content type="html">This is one feature everyone using Google Reader all longed for from Google. Its come pretty late as a feature at GoogleReader. Finally Yes, its here and makes life easier searching for blog posts.&lt;br /&gt;I'd read this list "&lt;a href="http://jtaylorgoodlife.blogspot.com/2007/06/how-to-get-things-done-colin-powell.html"&gt;How to Get Things Done - Colin Powell Version&lt;/a&gt;" and wanted to share it in my Shared Items. All it took me is a few seconds search on Colin Powell and ther it was.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-174596693473760548?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/NmHHaWcOoqE" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/174596693473760548/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=174596693473760548" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/174596693473760548?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/174596693473760548?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/NmHHaWcOoqE/search-power-google-reader.html" title="Search Power @ Google Reader" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/12/search-power-google-reader.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CU8BQng9fip7ImA9WB9UF0U.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-8454356455928191314</id><published>2007-11-11T22:57:00.000+05:30</published><updated>2007-12-16T11:14:13.666+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-12-16T11:14:13.666+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>What's your Top Five?</title><content type="html">I've found the 'Top Five" approach in defect disposition quite effective. Here's how its done.&lt;br /&gt;&lt;br /&gt;&lt;em&gt;&lt;strong&gt;Q) What's the "Top Five" approach?&lt;/strong&gt;&lt;/em&gt;&lt;br /&gt;&lt;br /&gt;A) Simple, create a the list of top five defects you'd need urgent fixes for.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;&lt;em&gt;Q) Is it different from Test Holdup Defects?&lt;/em&gt;&lt;/strong&gt;&lt;br /&gt;&lt;br /&gt;A) Well, to some degree it is and to some degree it is not. Holdup defects are the ones where your testing activity is &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_0"&gt;held up&lt;/span&gt;. This needs urgent fix, so naturally the holdup defects should be part of your top five defect list. However you should have defects that &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_1"&gt;aren't&lt;/span&gt; holding up your testing.&lt;br /&gt;&lt;br /&gt;&lt;em&gt;&lt;strong&gt;Q) Why only five defects in the list?&lt;/strong&gt;&lt;/em&gt;&lt;br /&gt;A) From our experience we've found that anything more than 5 defects in your top five list becomes &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_2"&gt;unmanageable&lt;/span&gt; for development and test leads and thereby this list loses it effectiveness. The idea is to have only so much defects in the list that the test and development leads can memorize.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;&lt;em&gt;Q) How to manage this list?&lt;/em&gt;&lt;/strong&gt;&lt;br /&gt;A) You'd require a solid development team backing for this approach. Speak with your development lead and manager before you embark upon this step. Ask for the commitment from their team that the defects in the &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_3"&gt;TopFive&lt;/span&gt; will get their utmost attention and will be &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_4"&gt;dispositioned&lt;/span&gt; fast.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;&lt;em&gt;Q) Are there tools to manage the list?&lt;/em&gt;&lt;/strong&gt;&lt;br /&gt;A) Reports from your defect system should be sufficient. If your defect system supports tagging of defects, this is the best way of doing it. Tag your TopFive defects and create a report. Simple excel sheet or an email message with predetermined format will also work.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;em&gt;&lt;strong&gt;Q) What types of defects should not be in this list?&lt;/strong&gt;&lt;br /&gt;&lt;/em&gt;A) Defects that you know will take longer time to get &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_5"&gt;dispositioned&lt;/span&gt; should not be in this list. We've defined a 'longer time' as over two weeks. Since you know these defects will take longer, do not keep these defects in this list as these will &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_6"&gt;take up&lt;/span&gt; a &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_7"&gt;permanent&lt;/span&gt; slot in your Top Five defect list.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;&lt;em&gt;Q) What type of projects are &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_8"&gt;TopFive&lt;/span&gt; list effective?&lt;/em&gt;&lt;/strong&gt;&lt;br /&gt;A) Typically medium to large project with current open defect count of over 150 defect count. For smaller projects, may not require the overhead of &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_9"&gt;maintaing&lt;/span&gt; this list.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;&lt;em&gt;Q) When do you create a &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_10"&gt;TopFive&lt;/span&gt; list?&lt;/em&gt;&lt;/strong&gt;&lt;br /&gt;A) We typically create a list of 5 or less defects every week ( say &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_11"&gt;monday&lt;/span&gt;) and communicate this to list to the development manager.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;&lt;em&gt;Q) What's the turnaround time for &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_12"&gt;TopFive&lt;/span&gt; defects?&lt;/em&gt;&lt;/strong&gt;&lt;br /&gt;A) Typically, we've found to have one week time for these defects. i.e. When you enter a defect in this list it takes typically one week to get fixed.&lt;br /&gt;&lt;br /&gt;&lt;strong&gt;&lt;em&gt;Q) What's the followup process?&lt;/em&gt; &lt;/strong&gt;&lt;br /&gt;A) Typically we do a status check with development manager every 3 to 4 day and disucss the list in our weekly meetings.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-8454356455928191314?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/4-9QctfP3Do" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/8454356455928191314/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=8454356455928191314" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8454356455928191314?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8454356455928191314?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/4-9QctfP3Do/whats-your-top-five.html" title="What's your Top Five?" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/11/whats-your-top-five.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUUEQ3szeCp7ImA9WB9TEkw.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-8956476076841592401</id><published>2007-09-19T20:14:00.001+05:30</published><updated>2007-09-19T20:16:42.580+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-09-19T20:16:42.580+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Management" /><title>Looking at afterthoughts</title><content type="html">&lt;div align="justify"&gt;&lt;br /&gt;With customer reported defects in their inbox, tester have this sense of "if only we could have done this too", "why did we miss that?", "i though we'd tested that". Its a mad scramble to find an explanation when things get uglyOften at the release time, the opposite is true. The feeling is "I know i did;nt get to that, but it not important", "I know its not tested to my satisfaction, but its too late to holdup a release now, should have raised this earlier", "the test data is not comprehensive, customer data may uncover more issues"Looking at hind-side, the the emotive and tense aspects are overlooked. With the count down to release time ticking, the challenge is to get the risks covered. Testers often overlook minor aspects of the product Being in the lowest end of the "software food chain", its the testing time that most of the other entities in the food chain eatup. Again and again, we hear this around our cubicles and meeting room, "its taking more than expected to complete this feature, but its critical". The routine activity done under these circumstances are "lets take up few more days", and the "few more days" come at the cost of testing time. Of course the delay in project is not affordable since we cant miss the market!.In these days of agile &amp;amp; iterative development, a lot is being discussed about the importance of testing early and getting testers involved early in the development process. Better said than done? May be, maybe not!&lt;br /&gt;The projects I've worked on have for past few years have a structure with a development manager looking at development activities, a test manager on the testing activities and a project manager managing the project timelines and external liason required by the project. The project manger often holds the key for success of the project and the effective delivery of the project depends on the effectiveness of the project manager. Project manager do not have anyone reporting to him/her. This person's primary responsibility is to maintain the timelimes, make sure everyone in the project adheres to the timelines, look out for possible risks and escalate issues. Often with the prior experience in development teams, the project managers unfortunately champions the cause of development team often at the expense of testing team. The schedules prepared by project manager puts overlay emphesis on development delivery and ignores the fact that testing resources can be optimally in an iterative developmment mode. The schedule prepared by the project manager turns out to be a waterfall method that leaves little time for the testing team.&lt;br /&gt;Of course there are project managers who considers themselves as the independent authority and creates the project plan with optimal utilization of all the resources in the project. A project manager stern on the timelines are the ones with successful project delivery. &lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-8956476076841592401?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/Sa9c_kZ9YZk" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/8956476076841592401/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=8956476076841592401" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8956476076841592401?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8956476076841592401?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/Sa9c_kZ9YZk/looking-at-afterthoughts.html" title="Looking at afterthoughts" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/09/looking-at-afterthoughts.html</feedburner:origLink></entry><entry gd:etag="W/&quot;C0EHQng5fyp7ImA9WB9TEkw.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-2406601542656465086</id><published>2007-09-09T11:34:00.001+05:30</published><updated>2007-09-19T19:50:33.627+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-09-19T19:50:33.627+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Management" /><title>Due share for Test Management?</title><content type="html">&lt;div align="justify"&gt;Over the past several months I've been keeping myself updated with blog activities on software testing. Yahoo group on software testing has also been very interesting read.&lt;br /&gt;Overall, majority of the blogs discuss about the testing processes &amp;amp; techniques, what I'd term as the "last mile" in the software testing. Certainly this is the most important aspect of our software testing field. &lt;/div&gt;&lt;div align="justify"&gt;Very few blogs I've been reading discuss about the "mangement" aspects of software testing. Aspects in testing such as "negotiation", "risk management", "analysis what'if scenarios", "work allocation" "work allocation" generally have very few post in the blog world, at least the one I keep track of regularly. &lt;/div&gt;&lt;div align="justify"&gt;In general these areas comes under project management and several blogs discuss software project management. There are areas where software development project management differs from the management of testing projects. For example, there is negotiation for time and budget on both development and testing projects, however testing team generally find themselves between "hard place and a rock" in negotiation situations. Testing risks generally get better attention from higher management than risks from development team. Development teams have proven estimation techniques, testing team generally estimates on their prior experiences.&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-2406601542656465086?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/PtGd6C4SHj4" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/2406601542656465086/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=2406601542656465086" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/2406601542656465086?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/2406601542656465086?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/PtGd6C4SHj4/due-share-for-test-management.html" title="Due share for Test Management?" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/09/due-share-for-test-management.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DUEBSHo7fyp7ImA9WB5WF0s.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-6006156029805039150</id><published>2007-07-30T09:23:00.000+05:30</published><updated>2007-07-30T09:24:19.407+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-07-30T09:24:19.407+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>Testing for performance</title><content type="html">&lt;div style="text-align: justify;"&gt;Ben Simo's post on &lt;a href="http://qualityfrog.blogspot.com/2007/04/performance-testing-lessons-learned.html"&gt;performance testing&lt;/a&gt; is an interesting read. These lessons learned more or less maps to my limited experience of testing application for an often overlooked aspect of functional testers.&lt;br /&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="text-align: justify;"&gt;&lt;div style="text-align: justify;"&gt; This subject is sub categorized into various sections such as performance, scalability, load, volume testing. For the matter of simplicity I'll refer these here under the general term performance testing.&lt;br /&gt;&lt;br /&gt;&lt;/div&gt;Performance is the last thing that appears in many of the requirements document I've come across. One reason for this could be that requirements are created by business analyst or product managers with limited exposure to the software development process. For them, performance is not a requirement, its "implied that the system works to the satisfaction of the end users". For the end user a non performing system is a defective system. While developing a "custom-made solution" for "&lt;span style="font-style: italic;"&gt;a&lt;/span&gt; specific client" also known as consulting implementations, performance requirement can be defined specifically and these are part of the service level agreements. Here the number of users, data volume, hardware specifications are know before the system is developed. Its often difficult to specify performance requirement when it comes to development of "generic solution" that can be configured in complex ways on multiple operating platforms and implemented at clients ranging from big corporates to small and medium enterprises.&lt;br /&gt;I've seen mixed reaction from developers on the performance requirement. Developers fall into many categories based on their interpretation of the "implicit" requirement. Some ignore requirement and assume their design takes care of performance. Some make implicit assumptions on the performance requirement. &lt;span style="font-size:85%;"&gt;"&lt;span style="font-style: italic;"&gt;My assumption&lt;/span&gt; is on a typical setup about 100,000 records gets uploaded to the transaction_history table by the nightly process", "&lt;span style="font-style: italic;"&gt;I feel&lt;/span&gt;&lt;/span&gt; there may be about 10 users requesting a customer record search". Few others ask the business analyst/Product manager about the performance expectations, they may or many not get the answers they are looking for. With the inputs they get, they design the system to take care of the worst case scenario. Others realize their design design may not scale to the performance expectations but time pressures makes him to attend to more important tasks. There are of course developers who go to great lengths to ensure there code is meets any performance goals.&lt;br /&gt;&lt;br /&gt;Testers have their own view of performance. Unless there is a mandate on performance to be tested, testers have these low in their priority. The testers asked to test for performance is functional testers with limited experience with testing for performance. In the iterative development cycles, performance can be tested only after the last iteration is delivered for testing. This leaves very less time to test for performance. Creation of sample data for performance is also a difficult proposition. Functional testers create their own data for the specific scenario or may use a 'limited' set of client data that may be easier to detect functional data integrity issues.&lt;br /&gt;&lt;br /&gt;Performance testing needs to be considered as a specialized area of testing and not to be mixed with the area of functional testing. This again depends on the budget of the project. The 'low end' performance tests can be done by testers huddles in a single room banging away on the system with the intend that something may go wrong. This type of testing, very labor intensive may detect many of the concurrency issues. Unless there's development support for this type of effort, the defects detected as a result of this effort are marked as non-reproducible.&lt;br /&gt;A cost conscious project can choose from a wide range of open source tools available for performance testing.&lt;br /&gt;&lt;br /&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-6006156029805039150?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/nrc9TJrGy7A" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/6006156029805039150/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=6006156029805039150" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/6006156029805039150?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/6006156029805039150?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/nrc9TJrGy7A/testing-for-performance.html" title="Testing for performance" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/07/testing-for-performance.html</feedburner:origLink></entry><entry gd:etag="W/&quot;D08AQHkzfip7ImA9WB5WFEw.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-5115398651477888553</id><published>2007-06-17T07:06:00.000+05:30</published><updated>2007-07-26T07:40:41.786+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-07-26T07:40:41.786+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Testing Process" /><title>Why do we test?</title><content type="html">&lt;div style="text-align: justify;"&gt;This post is not by any chance a comprehensive look on the reasons why software needs to be tested. I'm discussing here two reasons why software needs to be tested. These may not be the only reasons software testing is required, there are endless reasons. However these two reasons very clearly shows the way in which testers and developers view software testing.&lt;br /&gt;&lt;br /&gt;"To prove the software works". No prizes in guessing where this reason comes from. This blog post has its roots from an email from somewhere up in the management chain asking me to do something that was quite unassuming. "&lt;span style="color: rgb(153, 51, 0);"&gt;Rajesh, Can you test feature &lt;span style="font-style: italic;"&gt;so-and-so&lt;/span&gt; just completed by developer &lt;span style="font-style: italic;"&gt;John Doe&lt;/span&gt;. We'd like to take stock of how much of the features are  complete&lt;/span&gt;". Reading between the lines, its obvious what management wants me to do. Prove to them that the &lt;span style="font-style: italic;"&gt;developer &lt;/span&gt;had done with his code and checked them into the version control system. "To prove the software works" is something that developer of the feature has to do themselves. Unit-Test!!!. And the management has to as &lt;span style="color: rgb(153, 51, 0);"&gt;"John Doe, Can you show us the unit-test results?" &lt;/span&gt;&lt;br /&gt;&lt;br /&gt;Given the background of the situation, I'd mentioned to the management, we do not have a build to test yet. The build scripts are broken. We will not be able to replicate the customer environment. To this the management's reply&lt;span style="color: rgb(153, 51, 0);"&gt; "oh, just do this in the developer setup, we just want to know if the feature is complete".&lt;/span&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="color: rgb(153, 51, 0);"&gt;&lt;span style="color: rgb(0, 0, 0);"&gt;The second reason for testing "To find defects in the software so that your customers do not to find them". ( I'm mentioning this as &lt;span style="font-style: italic;"&gt;second&lt;/span&gt;, not the the point of view of important, but as the second point discussed here ) Again,  no guesses for who's the proponent for this view point. For the testing group, the imperative mandate is to find defects and absolute NOT to prove the software works. This mandate is something that needs to be reiterated to every tester everyday however experienced they are. &lt;/span&gt;&lt;/span&gt;&lt;br /&gt;The summary is Testers test &lt;span style="color: rgb(153, 51, 0); font-weight: bold;"&gt;&lt;span style="color: rgb(0, 0, 0);"&gt;"To find defects in the software so that your customers do not to find them" &lt;/span&gt;&lt;/span&gt;&lt;span style="color: rgb(153, 51, 0);"&gt;&lt;span style="color: rgb(0, 0, 0);"&gt;Developers test &lt;/span&gt;&lt;/span&gt;&lt;span style="font-weight: bold;"&gt;"To prove the software works". &lt;/span&gt;The success of any software project where the management bets their money on.&lt;span style="font-weight: bold;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-5115398651477888553?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/Dzjrfq5GqA0" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/5115398651477888553/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=5115398651477888553" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/5115398651477888553?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/5115398651477888553?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/Dzjrfq5GqA0/why-do-we-test.html" title="Why do we test?" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/06/why-do-we-test.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUMFRno9eCp7ImA9WBFWEEQ.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-5885522124246248864</id><published>2007-03-28T19:59:00.000+05:30</published><updated>2007-03-28T20:20:17.460+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-03-28T20:20:17.460+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Management" /><title>"Gutless Estimating" - Excerpts from "The Mythical Man-Month"</title><content type="html">The following is a excerpt from the classic book "&lt;a href="http://search.safaribooksonline.com/0201835959"&gt;The Mythical Man-Month&lt;/a&gt;".&lt;br /&gt;Read on the following paragraph carefully. Sit back,  close your eyes and think for the next 2 minutes. &lt;a href="http://en.wikipedia.org/wiki/Frederick_P._Brooks"&gt;Frederick P. Brooks, Jr.&lt;/a&gt;  the "father of the IBM System/360," has written these lines 20 years ago. So little has changed over these 20 years...&lt;br /&gt;&lt;br /&gt;&lt;h3  style="text-align: justify; font-weight: normal;font-family:georgia;" class="docSection1Title" id="-100000"&gt;&lt;span style="font-size:130%;"&gt;Gutless Estimating&lt;/span&gt;&lt;/h3&gt;&lt;div style="text-align: justify; font-family: georgia;"&gt; &lt;/div&gt;&lt;p  style="text-align: justify;font-family:georgia;" class="docText"&gt;&lt;span style="font-size:130%;"&gt;&lt;a name="Observe that"&gt;&lt;/a&gt;Observe that for the programmer, as for the chef, the urgency of the patron may govern the scheduled completion of the task, but it cannot govern the actual completion. An omelette, promised in two minutes, may appear to be progressing nicely. But when it has not set in two minutes, the customer has two choices—wait or eat it raw. Software customers have had the same choices.&lt;/span&gt;&lt;/p&gt;&lt;div style="text-align: justify; font-family: georgia;"&gt; &lt;/div&gt;&lt;p  style="text-align: justify;font-family:georgia;" class="docText"&gt;&lt;span style="font-size:130%;"&gt;&lt;a name="turn up"&gt;&lt;/a&gt;The cook has another choice; he can turn up the heat. The result is often an omelette nothing can save—burned in one part, raw in another.&lt;/span&gt;&lt;/p&gt;&lt;div style="text-align: justify; font-family: georgia;"&gt; &lt;/div&gt;&lt;p  style="text-align: justify;font-family:georgia;" class="docText"&gt;&lt;span style="font-size:130%;"&gt;&lt;a name="managers have"&gt;&lt;/a&gt;Now I do not think software managers have less inherent courage and firmness than chefs, nor than other engineering managers. But false scheduling to match the patron's desired date is much more common in our discipline than elsewhere in engineering. It is very difficult to make a vigorous, plausible, and job-risking defense of an estimate that is derived by no quantitative method, supported by little data, and certified chiefly by the hunches of the managers.&lt;/span&gt;&lt;/p&gt;&lt;div style="text-align: justify; font-family: georgia;"&gt; &lt;/div&gt;&lt;p  style="text-align: justify;font-family:georgia;" class="docText"&gt;&lt;span style="font-size:130%;"&gt;&lt;a name="solutions are"&gt;&lt;/a&gt;Clearly two solutions are needed. We need to develop and publicize productivity figures, bug-incidence figures, estimating rules, and so on. The whole profession can only profit from sharing such data.&lt;/span&gt;&lt;/p&gt;&lt;div style="text-align: justify; font-family: georgia;"&gt; &lt;/div&gt;&lt;p  style="text-align: justify;font-family:georgia;" class="docText"&gt;&lt;span style="font-size:130%;"&gt;&lt;a name="individual managers"&gt;&lt;/a&gt;Until estimating is on a sounder basis, individual managers will need to stiffen their backbones and defend their estimates with the assurance that their poor hunches are better than wish-derived estimates.&lt;/span&gt;&lt;/p&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-5885522124246248864?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/gxxnLO1wBws" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/5885522124246248864/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=5885522124246248864" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/5885522124246248864?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/5885522124246248864?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/gxxnLO1wBws/gutless-estimating-excerpts-from.html" title="&quot;Gutless Estimating&quot; - Excerpts from &quot;The Mythical Man-Month&quot;" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>2</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/03/gutless-estimating-excerpts-from.html</feedburner:origLink></entry><entry gd:etag="W/&quot;Ck4CRH45eSp7ImA9WBFXFU0.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-491815393465688584</id><published>2007-03-15T17:18:00.000+05:30</published><updated>2007-03-21T23:46:05.021+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2007-03-21T23:46:05.021+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Management" /><title>An universal format for resume</title><content type="html">&lt;div style="text-align: justify;"&gt;My most of the latter half of last week went into scanning resumes for a test automation position. HR in its part had dumped into a MS Outlook folder, quite a few resumes from internet job postings and candidates applied for the job posting on our company website. Given the enormous amount of work it takes to scan through the resumes for the right set of skill set and experience, I'm wondering if its high time the software industry propose an universal format for resumes.&lt;br /&gt;&lt;br /&gt;Automated tools could scan the machine readable formats and save the drudgery of reading through pages text to get simple information like years of experience and skill set.  This had prompted me to looked into wikipedia for a definition of  &lt;a href="http://en.wikipedia.org/wiki/Resume"&gt;resume&lt;/a&gt;. One format that had caught my attention was the &lt;a href="http://en.wikipedia.org/wiki/HResume"&gt;hResume&lt;/a&gt; . Any new initiative requires big names to support it. Its time for the big companies to support a common initiative. The smaller one will follow suit.&lt;br /&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-491815393465688584?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/_4z8rhrISFg" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/491815393465688584/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=491815393465688584" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/491815393465688584?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/491815393465688584?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/_4z8rhrISFg/universal-format-for-resume.html" title="An universal format for resume" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><thr:total>0</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/03/universal-format-for-resume.html</feedburner:origLink></entry><entry gd:etag="W/&quot;D0cGRX88eCp7ImA9WxRVFUs.&quot;"><id>tag:blogger.com,1999:blog-4641151445274490481.post-8704683579710787039</id><published>2007-03-03T08:23:00.000+05:30</published><updated>2008-11-13T14:00:24.170+05:30</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-11-13T14:00:24.170+05:30</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="About blogging" /><category scheme="http://www.blogger.com/atom/ns#" term="Everyday Bugs" /><title>Two Blogger bugs</title><content type="html">After having started blogging, I've started looking at everyday things more critically. I noticed two things with blogger.com that caught my attention.&lt;br /&gt;&lt;br /&gt;I have this habit of creating a blog post and saving it as draft. After many a iterations of writing and rewriting, I finally publish the post. Often times the gap between creating the post for the first time and publishing it takes several days. I have several draft post that I work on at any given point in time.&lt;br /&gt;&lt;br /&gt;I created a post on February 26th, finally published this post on march 4th. The published date on my blog still lists as february 26th instead of march 4th. &lt;img id="BLOGGER_PHOTO_ID_5038043463490528930" style="DISPLAY: block; MARGIN: 0px auto 10px; CURSOR: hand; TEXT-ALIGN: center" alt="" src="http://3.bp.blogspot.com/_0SDfVmPvmlc/Req51lxU5qI/AAAAAAAAAA8/oZHizozhKUo/s400/datepost.JPG" border="0" /&gt; &lt;div&gt;&lt;/div&gt;&lt;div&gt;&lt;/div&gt;The other bug related to my blog title, I'll still drafting.&lt;br /&gt;&lt;br /&gt;&lt;div&gt;&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/4641151445274490481-8704683579710787039?l=elusivebug.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/InPersuitOfTheElusive/~4/HAGxK4KtbAA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://elusivebug.blogspot.com/feeds/8704683579710787039/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=4641151445274490481&amp;postID=8704683579710787039" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8704683579710787039?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/4641151445274490481/posts/default/8704683579710787039?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/InPersuitOfTheElusive/~3/HAGxK4KtbAA/two-blogger-bugs.html" title="Two Blogger bugs" /><author><name>Rajesh Kazhankodath</name><uri>http://www.blogger.com/profile/00776206192461021082</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="32" src="http://3.bp.blogspot.com/-Tmvwc7IyrRE/TirI8UddDHI/AAAAAAAAAQE/Lixf5YpoY7g/s220/Rajeshkz.png" /></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="http://3.bp.blogspot.com/_0SDfVmPvmlc/Req51lxU5qI/AAAAAAAAAA8/oZHizozhKUo/s72-c/datepost.JPG" height="72" width="72" /><thr:total>2</thr:total><feedburner:origLink>http://elusivebug.blogspot.com/2007/03/two-blogger-bugs.html</feedburner:origLink></entry></feed>

