<?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;CEUAQHo7fyp7ImA9WhRUFEQ.&quot;"><id>tag:blogger.com,1999:blog-15045980</id><updated>2012-01-25T03:50:41.407-08:00</updated><category term="test" /><category term="pretotyping" /><category term="Conferences" /><category term="TotT" /><category term="Alberto has gone off the deep end" /><category term="chromeos" /><category term="prototyping" /><category term="testivus" /><category term="test is dead" /><category term="Copeland" /><category term="Coverage" /><category term="alberto savoia" /><category term="pretotype" /><category term="Misko" /><category term="testing" /><category term="GTAC" /><category term="Morena Baccarin" /><category term="Whittaker" /><title type="text">Google Testing Blog</title><subtitle type="html">If it ain't broke, you're not trying hard enough.</subtitle><link rel="http://schemas.google.com/g/2005#feed" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/posts/default" /><link rel="alternate" type="text/html" href="http://googletesting.blogspot.com/" /><link rel="next" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default?start-index=26&amp;max-results=25&amp;redirect=false&amp;v=2" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><generator version="7.00" uri="http://www.blogger.com">Blogger</generator><openSearch:totalResults>260</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/blogspot/RLXA" /><feedburner:info uri="blogspot/rlxa" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><feedburner:emailServiceId>blogspot/RLXA</feedburner:emailServiceId><feedburner:feedburnerHostname>http://feedburner.google.com</feedburner:feedburnerHostname><entry gd:etag="W/&quot;CkQGQHs8eip7ImA9WhRQF0s.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-6708622040196997932</id><published>2011-12-12T23:12:00.000-08:00</published><updated>2011-12-12T23:12:01.572-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-12-12T23:12:01.572-08:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><title>How Google Tests Software</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
By James Whittaker&lt;br /&gt;
&lt;br /&gt;
The publishing industry may be slow, but eventually they deliver. Amazon is now listing &lt;i&gt;How Google Tests Software&lt;/i&gt; that I wrote with Jason Arbon and Jeff Carollo for presale. Find it at: http://goo.gl/Dg3qG&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/15045980-6708622040196997932?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=xhNoXtrdkvg:Y9nUWXPudFA:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=xhNoXtrdkvg:Y9nUWXPudFA:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=xhNoXtrdkvg:Y9nUWXPudFA:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/xhNoXtrdkvg" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/6708622040196997932/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=6708622040196997932" title="7 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/6708622040196997932?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/6708622040196997932?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/xhNoXtrdkvg/how-google-tests-software.html" title="How Google Tests Software" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>7</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/12/how-google-tests-software.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DE8BR308fCp7ImA9WhRSFU4.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-8181824926851031728</id><published>2011-11-17T05:26:00.001-08:00</published><updated>2011-11-17T05:34:16.374-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-11-17T05:34:16.374-08:00</app:edited><title>RPF: Google's Record Playback Framework</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
By Jason Arbon&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;div style="background-color: transparent;"&gt;
&lt;span id="internal-source-marker_0.25297700078226626" style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;At &lt;/span&gt;&lt;a href="http://www.gtac.biz/"&gt;&lt;span style="background-color: transparent; color: #000099; font-family: Arial; font-size: 15px; vertical-align: baseline; white-space: pre-wrap;"&gt;GTAC&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;, folks asked how well the Record/Playback (RPF) works in the Browser Integrated Test Environment (&lt;/span&gt;&lt;a href="http://googletesting.blogspot.com/2011/10/take-bite-out-of-bugs-and-redundant.html"&gt;&lt;span style="background-color: transparent; color: #000099; font-family: Arial; font-size: 15px; vertical-align: baseline; white-space: pre-wrap;"&gt;BITE&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;). We were originally skeptical ourselves, but figured somebody should try. Here is some anecdotal data and some background on how we started measuring the quality of RPF.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;The idea is to just let users use the application in the browser, record their actions, and save them as a javascript to play back as a regression test or repro later. Like most test tools, especially code generating ones, it works most of the time but its not perfect. Po Hu had an early version working, and decided to test this out on a real world product. Po, the developer of RPF, worked with the chrome web store team to see how an early version would work for them. Why &lt;/span&gt;&lt;a href="https://chrome.google.com/webstore/"&gt;&lt;span style="background-color: transparent; color: #000099; font-family: Arial; font-size: 15px; vertical-align: baseline; white-space: pre-wrap;"&gt;chrome web store&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;? It is a website with lots of data-driven UX, authentication, file upload, and it was changing all the time and breaking existing &lt;/span&gt;&lt;a href="http://seleniumhq.org/"&gt;&lt;span style="background-color: transparent; color: #000099; font-family: Arial; font-size: 15px; vertical-align: baseline; white-space: pre-wrap;"&gt;Selenium&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; scripts: a pretty hard web testing problem, only targeted the chrome browser, and most importantly they were sitting 20 feet from us. &lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Before sharing with the chrome web store test developer Wensi Liu, we invested a bit of time in doing something we thought was clever: fuzzy matching and inline updating of the test scripts. Selenium rocks, but after an initial regression suite is created, many teams end up spending a lot of time simply maintaining their Selenium tests as the products constantly change. Rather than simply fail like the existing Selenium automation would do when a certain element isn’t found, and require some manual DOM inspection, updating the Java code and re-deploying, re-running, re-reviewing the test code what if the test script just kept running and updates to the code could be as simple as point and click? We would keep track of all the attributes in the element recorded, and when executing we would calculate the percent match between the recorded attributes and values and those found while running. If the match isn’t exact, but within tolerances (say only its parent node or class attribute had changed), we would log a warning and keep executing the test case. If the next test steps appeared to be working as well, the tests would keep executing during test passes only log warnings, or if in debug mode, they would pause and allow for a quick update of the matching rule with point and click via the BITE UI. We figured this might reduce the number of false-positive test failures and make updating them much quicker.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;We were wrong, but in a good way!&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;We talked to the tester after a few days of leaving him alone with RPF. He’d already re-created most of his Selenium suite of tests in RPF, and the tests were already breaking because of product changes (its a tough life for a tester at google to keep up with the developers rate of change). He seemed happy, so we asked him how this new fuzzy matching fanciness was working, or not. Wensi was like “oh yeah, that? Don’t know. Didn’t really use it...”. We started to think how our update UX could have been confusing or not discoverable, or broken. Instead, Wensi said that when a test broke, it was just far easier to re-record the script. He had to re-test the product anyway, so why not turn recording on when he manually verified things were still working, remove the old test and save this newly recorded script for replay later? &lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;During that first week of trying out RPF, Wensi found:&lt;/span&gt;&lt;ul&gt;
&lt;li style="background-color: transparent; font-family: Arial; font-size: 15px; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;77% of the features in Webstore were testable by RPF&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; font-family: Arial; font-size: 15px; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Generating regression test scripts via this early version of RPF was about 8X faster than building them via Selenium/WebDriver&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; font-family: Arial; font-size: 15px; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;The RPF scripts caught 6 functional regressions and many more intermittent server failures.&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; font-family: Arial; font-size: 15px; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Common setup routines like login should be saved as modules for reuse (a crude version of this was working soon after)&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; font-family: Arial; font-size: 15px; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;RPF worked on Chrome OS, where Selenium by definition could never run as it required client-side binaries. RPF worked because it was a pure cloud solution, running entirely within the browser, communicating with a backend on the web.&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; font-family: Arial; font-size: 15px; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Bugs filed via bite, provided a simple link, which would install BITE on the developers machine and re-execute the repros on their side. No need for manually crafted repro steps. This was cool.&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; font-family: Arial; font-size: 15px; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Wensi wished RPF was cross browser. It only worked in Chrome, but people did occasionally visit the site with a non-Chrome browser.&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;So, we knew we were onto something interesting and continued development. In the near term though, chrome web store testing went back to using Selenium because that final 23% of features required some local Java code to handle file upload and secure checkout scenarios. In hindsight, a little testability work on the server could have solved this with some AJAX calls from the client.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;We performed a check of how RPF faired on some of the top sites of the web. This is shared on the &lt;/span&gt;&lt;a href="https://docs.google.com/spreadsheet/ccc?key=0AsbIZrIYVyF0dEJGQV91WW9McW1fMjItRmhzcWkyanc"&gt;&lt;span style="background-color: transparent; color: #000099; font-family: Arial; font-size: 15px; vertical-align: baseline; white-space: pre-wrap;"&gt;BITE project wiki&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;. This is now a little bit out of date, with lots more fixes, but it gives you a feel for what doesn’t work. Consider it Alpha quality at this point. It works for most scenarios, but there are still some serious corner cases. &lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Joe Muharsky drove a lot of the UX (user experience) design for BITE to turn our original and clunky developer and functional-centric UX into something intuitive. Joe’s key focus was to keep the UX out of the way until it is needed, and make things as self-discoverable and findable as possible. We’ve haven't done formal usability studies yet, but have done several experiments with external crowd testers using these tools, with minimal instructions, as well as internal dogfooders filing bugs against Google Maps with little confusion. Some of the fancier parts of RPF have some hidden easter eggs of awkwardness, but the basic record and playback scenarios seem to be obvious to folks.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;RPF has graduated from the experimental centralized test team to be a formal part of the Chrome team, and used regularly for regression test passes. The team also has an eye on enabling non-coding crowd sourced testers generate regression scripts via BITE/RPF.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Please join us in maintaining &lt;/span&gt;&lt;a href="http://code.google.com/p/bite-project/"&gt;&lt;span style="background-color: transparent; color: #000099; font-family: Arial; font-size: 15px; vertical-align: baseline; white-space: pre-wrap;"&gt;BITE/RPF&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-family: Arial; font-size: 15px; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;, and be nice to Po Hu and Joel Hynoski who are driving this work forward within Google. &lt;/span&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/15045980-8181824926851031728?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=0IyDVwm9R0c:ACT6cBZHgCQ:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=0IyDVwm9R0c:ACT6cBZHgCQ:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=0IyDVwm9R0c:ACT6cBZHgCQ:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/0IyDVwm9R0c" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/8181824926851031728/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=8181824926851031728" title="3 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/8181824926851031728?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/8181824926851031728?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/0IyDVwm9R0c/rpf-googles-record-playback-framework.html" title="RPF: Google's Record Playback Framework" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>3</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/11/rpf-googles-record-playback-framework.html</feedburner:origLink></entry><entry gd:etag="W/&quot;C0YFRXg-fSp7ImA9WhRSE0o.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-2702459051349044892</id><published>2011-11-15T07:30:00.001-08:00</published><updated>2011-11-15T07:31:54.655-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-11-15T07:31:54.655-08:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><category scheme="http://www.blogger.com/atom/ns#" term="GTAC" /><title>GTAC Videos Now Available</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
By James Whittaker&lt;br /&gt;
&lt;br /&gt;
All the GTAC 2011 talks are now available at&amp;nbsp;&lt;a href="http://www.gtac.biz/talks" style="background-color: rgba(255, 255, 255, 0.917969); color: #1155cc; font-family: arial, sans-serif; font-size: 14px; text-align: -webkit-auto;" target="_blank"&gt;http://www.gtac.biz/talks&lt;/a&gt;&lt;span class="Apple-style-span" style="background-color: rgba(255, 255, 255, 0.917969); color: #222222; font-family: arial, sans-serif; font-size: 14px; text-align: -webkit-auto;"&gt;&amp;nbsp;and also up on You Tube. A hearty thanks to all the speakers who helped make this the best GTAC ever.&amp;nbsp;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="background-color: rgba(255, 255, 255, 0.917969); color: #222222; font-family: arial, sans-serif; font-size: 14px; text-align: -webkit-auto;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="background-color: rgba(255, 255, 255, 0.917969); color: #222222; font-family: arial, sans-serif; font-size: 14px; text-align: -webkit-auto;"&gt;Enjoy!&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/15045980-2702459051349044892?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=HsjVMEue-SI:d1bML8x64RI:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=HsjVMEue-SI:d1bML8x64RI:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=HsjVMEue-SI:d1bML8x64RI:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/HsjVMEue-SI" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/2702459051349044892/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=2702459051349044892" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/2702459051349044892?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/2702459051349044892?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/HsjVMEue-SI/gtac-videos-now-available.html" title="GTAC Videos Now Available" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>0</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/11/gtac-videos-now-available.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DkAMSX87eyp7ImA9WhdaFUU.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-2139052876781135390</id><published>2011-10-25T16:02:00.000-07:00</published><updated>2011-10-25T16:19:48.103-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-10-25T16:19:48.103-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Coverage" /><category scheme="http://www.blogger.com/atom/ns#" term="testing" /><title>ScriptCover makes Javascript coverage analysis easy</title><content type="html">&lt;span class="Apple-style-span" style="background-color: white; color: #1e1e1e; font-family: inherit; white-space: pre-wrap;"&gt;By Ekaterina Kamenskaya, Software Engineer in Test, YouTube&lt;/span&gt;&lt;br /&gt;
&lt;div style="background-color: transparent;"&gt;
&lt;div dir="ltr" style="margin-bottom: 0pt; margin-top: 0pt; text-indent: 36pt;"&gt;
&lt;span style="background-color: white; color: #1e1e1e; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Today we introduce the Javascript coverage analysis tool&lt;/span&gt;&lt;span style="background-color: white; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;, &lt;/span&gt;&lt;a href="http://code.google.com/p/script-cover/"&gt;&lt;span style="background-color: white; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;ScriptCover&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;. It is a Chrome extension that provides line-by-line Javascript code coverage statistics for web pages in real time without any user modifications required. The results are collected both when the page loads and as users interact with it. &lt;/span&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;The tool reports details about total web page coverage and for each external/internal script, as well as annotated code sources with individually highlighted executed lines.&lt;/span&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;
&lt;span style="background-color: white; color: #1e1e1e; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: white; color: #1e1e1e; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;img height="454" src="https://lh5.googleusercontent.com/DcR8DadSixxew_FoYULKK0r0AOHVmYVbf6DAhALoPjsqp25Ih5ag77RUjEFJWyRZBKt10Q-0d9i0GFR73d4EENGxZpw-quMVIlxMtRF7P6R2z9wBtMIspajCYCL9GB-H" width="640" /&gt;&lt;/span&gt;&lt;br /&gt;
&lt;div dir="ltr" style="margin-bottom: 0pt; margin-top: 0pt; text-align: center;"&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: white; color: #1e1e1e; font-style: italic; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Short report in Chrome extension’s popup, detailing both overall scores and per-script coverage. &lt;/span&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;
&lt;span style="background-color: white; color: #1e1e1e; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: white; color: #1e1e1e; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: transparent; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Main features:&lt;/span&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;/span&gt;&lt;br /&gt;
&lt;ul&gt;
&lt;li style="background-color: transparent; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Report current and previous total Javascript coverage percentages and total number of instrumented code instructions.&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Report Javascript coverage per individual instruction for each internal and external script.&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Display detailed reports with annotated Javascript source code.&lt;/span&gt;&lt;/li&gt;
&lt;li style="background-color: transparent; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="background-color: transparent; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Recalculate coverage statistics while loading the page and on user actions.&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;span style="background-color: transparent; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;img height="203px;" src="https://lh6.googleusercontent.com/H4CHvDgSI-pldJGsPPQcYgFBsI_VoCkgKYwn_0apcnjbbwLnN8E62xEntd4vNOi_Dwzt5BRema1XLbQG_PgNTrMj5-Afc2hvgJuyXbE-eoUEU4V2Za4E-ldaSDjIwwPq" width="493px;" /&gt;&lt;/span&gt;&lt;br /&gt;
&lt;div dir="ltr" style="margin-bottom: 0pt; margin-top: 0pt; text-align: center;"&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: white; color: #1e1e1e; font-style: italic; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Sample of annotated source code from detailed report. First two columns are line number and number of times each instruction has been executed.&lt;/span&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;
&lt;span style="background-color: white; color: #1e1e1e; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: white; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Here are the benefits of &lt;/span&gt;&lt;a href="https://code.google.com/p/script-cover/"&gt;&lt;span style="background-color: white; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;ScriptCover&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: white; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; over other existing tools:&lt;/span&gt;&lt;/span&gt;&lt;br /&gt;
&lt;ul&gt;
&lt;li style="background-color: white; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Per instructions coverage for external and internal scripts:&lt;/span&gt;&lt;span style="text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; The tool formats original external and internal Javascript code from ‘&amp;lt;script&amp;gt;’ tags to ideally place one instruction per line and then calculates and displays Javascript coverage statistics. &lt;/span&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;It is useful even when the code is compressed to one line.&lt;/span&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;span style="background-color: white; color: #1e1e1e; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;ul&gt;
&lt;li style="background-color: white; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Dynamic:&lt;/span&gt;&lt;span style="text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; Users can get updated Javascript coverage statistics while the web page is loading and while interacting with the page.&lt;/span&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;span style="background-color: white; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;ul&gt;
&lt;li style="background-color: white; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Easy to use:&lt;/span&gt;&lt;span style="text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; Users with different levels of expertise can install and use the tool to analyse coverage. Additionally, there is no need to write tests, modify the web application’s code, save the inspected web page locally, manually change proxy settings, etc. &lt;/span&gt;&lt;span style="color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;When the extension is activated in a Chrome browser, users just navigate through web pages and get coverage statistics on the fly.&lt;/span&gt;&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;span style="background-color: white; color: #1e1e1e; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;ul&gt;
&lt;li style="background-color: white; list-style-type: disc; text-decoration: none; vertical-align: baseline;"&gt;&lt;span style="color: #1e1e1e; font-family: inherit; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;It’s free and open source!&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/span&gt;&lt;span style="background-color: transparent; font-style: italic; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/span&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Want to try it out? &lt;/span&gt;&lt;span style="background-color: white; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Install &lt;/span&gt;&lt;a href="https://code.google.com/p/script-cover/"&gt;&lt;span style="background-color: white; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;ScriptCover&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: white; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; and let us know what you think&lt;/span&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;.&lt;/span&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; font-family: inherit; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: inherit;"&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;We envision many potential features and improvements for &lt;/span&gt;&lt;a href="https://code.google.com/p/script-cover"&gt;&lt;span style="background-color: white; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;ScriptCover.&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; If you are passionate about code coverage, read our &lt;/span&gt;&lt;a href="https://code.google.com/p/script-cover/w/list"&gt;&lt;span style="background-color: white; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;documentation&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: white; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; &lt;/span&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;and &lt;/span&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;participate in &lt;/span&gt;&lt;a href="http://groups.google.com/group/script-cover"&gt;&lt;span style="background-color: transparent; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;discussion group&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;. &lt;/span&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Your contributions to the project’s &lt;/span&gt;&lt;a href="https://code.google.com/p/script-cover/wiki/ScriptCoverDesign"&gt;&lt;span style="background-color: white; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;design&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;, &lt;/span&gt;&lt;a href="https://code.google.com/p/script-cover/source/browse/"&gt;&lt;span style="background-color: white; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;code base &lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;and &lt;/span&gt;&lt;a href="https://code.google.com/p/script-cover/issues/list"&gt;&lt;span style="background-color: white; color: #000099; vertical-align: baseline; white-space: pre-wrap;"&gt;feature requests&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: white; color: #1e1e1e; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; are welcome! &lt;/span&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/15045980-2139052876781135390?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=RKFuR3AXX9Y:l5moaoZB50o:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=RKFuR3AXX9Y:l5moaoZB50o:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=RKFuR3AXX9Y:l5moaoZB50o:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/RKFuR3AXX9Y" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/2139052876781135390/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=2139052876781135390" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/2139052876781135390?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/2139052876781135390?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/RKFuR3AXX9Y/scriptcover-makes-javascript-coverage.html" title="ScriptCover makes Javascript coverage analysis easy" /><author><name>Ibrahim (Google)</name><uri>http://www.blogger.com/profile/10683234753186013667</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="26" height="32" src="http://4.bp.blogspot.com/-73iYTViixSM/Todhxl0cYUI/AAAAAAAAAEY/4zxMA_2-5pM/s220/ibrahimelfar.png" /></author><thr:total>2</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/10/scriptcover-makes-javascript-coverage.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DkEGSXo-eCp7ImA9WhdaEEg.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-2148517028552401960</id><published>2011-10-19T13:03:00.000-07:00</published><updated>2011-10-19T13:03:48.450-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-10-19T13:03:48.450-07:00</app:edited><title>Google Test Analytics - Now in Open Source</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
&lt;br /&gt;
&lt;div style="background-color: transparent;"&gt;
&lt;span id="internal-source-marker_0.7736793777439743" style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;By &lt;/span&gt;&lt;span style="background-color: transparent; font-size: 12pt; vertical-align: baseline; white-space: pre-wrap;"&gt;Jim Reardon&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;The test plan is dead!&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Well, hopefully. &amp;nbsp;At a STAR West session this past week, &lt;/span&gt;&lt;span style="background-color: transparent; color: #000099; font-size: 12pt; vertical-align: baseline; white-space: pre-wrap;"&gt;J&lt;/span&gt;&lt;span style="background-color: transparent; font-size: 12pt; vertical-align: baseline; white-space: pre-wrap;"&gt;ames Whittaker&lt;/span&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; asked a group of test professionals about test plans. &amp;nbsp;His first question: “How many people here write test plans?” &amp;nbsp;About 80 hands shot up instantly, a vast majority of the room. &amp;nbsp;“How many of you get value or refer to them again after a week?” &amp;nbsp;Exactly three people raised their hands.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;That’s a lot of time being spent writing documents that are often long-winded, full of paragraphs of details on a project everyone already knows to get abandoned so quickly.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;A group of us at Google set about creating a methodology that can replace a test plan -- it needed to be comprehensive, quick, actionable, and have sustained value to a project. &amp;nbsp;In the past few weeks, James has posted a few blogs about this methodology, which we’ve called ACC. &amp;nbsp;It's a tool to break down a software product into its constituent parts, and the method by which we created "10 Minute Test Plans" (that only take 30 minutes!)&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Comprehensive&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;The ACC methodology creates a matrix that describes your project completely; several projects that have used it internally at Google have found coverage areas that were missing in their conventional test plans.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Quick&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;The ACC methodology is fast; we’ve created ACC breakdowns for complex projects in under half an hour. &amp;nbsp;Far faster than writing a conventional test plan.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Actionable&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;As part of your ACC breakdown, risk is assessed to the capabilities of your appliciation. &amp;nbsp;Using these values, you get a heat map of your project, showing the areas with the highest risk -- great places to spend some quality time testing.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Sustained Value&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;We’ve built in some experimental features that bring your ACC test plan to life by importing data signals like bugs and test coverage that quantify the risk across your project.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Today, I'm happy to announce we're &lt;/span&gt;&lt;a href="http://code.google.com/p/test-analytics"&gt;&lt;span style="background-color: transparent; color: #000099; font-size: 12pt; vertical-align: baseline; white-space: pre-wrap;"&gt;open sourcing Test Analytics&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;, a tool built at Google to make generating an ACC simple -- and which brings some experimental ideas we had around the field of risk-based testing that work hand-in-hand with the ACC breakdown.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;img height="478px;" src="https://lh6.googleusercontent.com/_MMslemTTsllr8U8zg_VbDXR78XV2YzOxqOLOBUAVz-Tvv9lla_pqHIOWf8xCACApin9df0KM0MyVLWj4jXbOUY51VRmm0Ceu8VpOa3t8-gPfO6kAC0" width="600px;" /&gt;&lt;br /&gt;&lt;div dir="ltr" style="margin-bottom: 0pt; margin-top: 0pt; text-align: center;"&gt;
&lt;span style="background-color: transparent; font-size: 10pt; font-style: italic; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Defining a project’s ACC model.&lt;/span&gt;&lt;/div&gt;
&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Test Analytics has two main parts: first and foremost, it's a step-by-step tool to create an ACC matrix that's faster and much simpler than the Google Spreadsheets we used before the tool existed. &amp;nbsp;It also provides visualizations of the matrix and risks associated with your ACC Capabilities that were difficult or impossible to do in a simple spreadsheet.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;img height="493px;" src="https://lh6.googleusercontent.com/Pbomt34-V08EZFLjZRbCEgzy33xnZod6nIhMqDXs-aOx1tIk37yeg8HOBFnCr_zD36hEGauP2bBrBETat6vsggU80sZa6n0ERXC_13tvAToq6F7_VSE" width="622px;" /&gt;&lt;br /&gt;&lt;div dir="ltr" style="margin-bottom: 0pt; margin-top: 0pt; text-align: center;"&gt;
&lt;span style="background-color: transparent; font-size: 10pt; font-style: italic; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;A project’s Capabilities grid.&lt;/span&gt;&lt;span style="background-color: transparent; font-size: 10pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;/div&gt;
&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;The second part is taking the ACC plan and making it a living, automatic-updating risk matrix. &amp;nbsp;Test Analytics does this by importing quality signals from your project: Bugs, Test Cases, Test Results, and Code Changes. &amp;nbsp;By importing these data, Test Analytics lets you visualize risk that isn't just estimated or guessed, but based on quantitative values. &amp;nbsp;If a Component or Capability in your project has had a lot of code change or many bugs are still open or not verified as working, the risk in that area is higher. &amp;nbsp;Test Results can provide a mitigation to those risks -- if you run tests and import passing results, the risk in an area gets lower as you test.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;img height="489px;" src="https://lh6.googleusercontent.com/DbPgYn0C2r7JhtKZtkF0u4EsXA73FUCTvaB2jDdzUWeEjdqEFG-wKoXc7evm411advDIvDpCpIpPm8vYd9rLpYtJjvOqAywmc_g54NprU6oFt1frUrI" width="611px;" /&gt;&lt;br /&gt;&lt;div dir="ltr" style="margin-bottom: 0pt; margin-top: 0pt; text-align: center;"&gt;
&lt;span style="background-color: transparent; font-size: 10pt; font-style: italic; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;A project’s risk, calculated as a factor of inherent risk as well as imported quality signals.&lt;/span&gt;&lt;/div&gt;
&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;This part's still experimental; we're playing around with how we calculate risk based on these signals to best determine risk. &amp;nbsp;However, we wanted to release this functionality early so we can get feedback from the testing community on how well it works for teams so we can iterate and make the tool even more useful. &amp;nbsp;It'd also be great to import even more quality signals: code complexity, static code analysis, code coverage, external user feedback and more are all ideas we've had that could add an even higher level of dynamic data to your test plan.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;img height="692px;" src="https://lh6.googleusercontent.com/0kW6BxM-HWjtqPBzcK7F2qkllvtCnObL81ONGk-Owjq7s-oipxP3Wu4YGITj2ZHd4LSaSIIakeOStFa3MqRVoETIrGxfWhYltVpFxAtmlm-PcMfi73E" width="642px;" /&gt;&lt;br /&gt;&lt;div dir="ltr" style="margin-bottom: 0pt; margin-top: 0pt; text-align: center;"&gt;
&lt;span style="background-color: transparent; font-size: 10pt; font-style: italic; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;An overview of test results, bugs, and code changes attributed to a project’s capability. &amp;nbsp;The Capability’s total risk is affected by these factors. &lt;/span&gt;&lt;/div&gt;
&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;You can check out a &lt;/span&gt;&lt;a href="https://test-analytics.appspot.com/"&gt;&lt;span style="background-color: transparent; color: #000099; font-size: 12pt; vertical-align: baseline; white-space: pre-wrap;"&gt;live hosted version&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;, browse or check out &lt;/span&gt;&lt;a href="http://code.google.com/p/test-analytics"&gt;&lt;span style="background-color: transparent; color: #000099; font-size: 12pt; vertical-align: baseline; white-space: pre-wrap;"&gt;the code&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; along with &lt;/span&gt;&lt;a href="http://code.google.com/p/test-analytics/wiki/AccExplained"&gt;&lt;span style="background-color: transparent; color: #000099; font-size: 12pt; vertical-align: baseline; white-space: pre-wrap;"&gt;documentation&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;, and of course if you have any feedback let us know - there's a &lt;/span&gt;&lt;a href="http://groups.google.com/group/test-analytics-discuss"&gt;&lt;span style="background-color: transparent; color: #000099; font-size: 12pt; vertical-align: baseline; white-space: pre-wrap;"&gt;Google Group set up for discussion&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;, where we'll be active in responding to questions and sharing our experiences with Test Analytics so far.&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="background-color: transparent; font-size: 12pt; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Long live the test plan!&lt;/span&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/15045980-2148517028552401960?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=UvTN146F2bg:lXlGjWr4GrE:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=UvTN146F2bg:lXlGjWr4GrE:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=UvTN146F2bg:lXlGjWr4GrE:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/UvTN146F2bg" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/2148517028552401960/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=2148517028552401960" title="9 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/2148517028552401960?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/2148517028552401960?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/UvTN146F2bg/google-test-analytics-now-in-open.html" title="Google Test Analytics - Now in Open Source" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>9</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/10/google-test-analytics-now-in-open.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUcNQn48fSp7ImA9WhdbGEo.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-5537504377629238596</id><published>2011-10-17T10:38:00.000-07:00</published><updated>2011-10-17T10:38:13.075-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-10-17T10:38:13.075-07:00</app:edited><title>Google JS Test, now in Open Source</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
&lt;span class="Apple-style-span" style="background-color: white; font-family: Arial, Helvetica, sans-serif; font-size: 12px; line-height: 15px;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;div style="padding-bottom: 0px;"&gt;
By Aaron Jacobs&lt;/div&gt;
&lt;div style="padding-bottom: 0px;"&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div style="padding-bottom: 0px;"&gt;
&lt;a href="http://code.google.com/p/google-js-test/" target="blank"&gt;Google JS Test&lt;/a&gt;&amp;nbsp;is a JavaScript unit testing framework that runs on the&amp;nbsp;&lt;a href="http://code.google.com/p/v8/" target="blank"&gt;V8 JavaScript Engine&lt;/a&gt;, the same open source project that is responsible for Google Chrome’s super-fast JS execution speed. Google JS Test is used internally by several Google projects, and we’re pleased to announce that it has been released as an open source project.&lt;br /&gt;
&lt;br /&gt;
Features of Google JS Test include:&lt;/div&gt;
&lt;ul&gt;
&lt;li&gt;Extremely fast startup and execution time, without needing to run a browser.&lt;/li&gt;
&lt;/ul&gt;
&lt;ul&gt;
&lt;li&gt;Clean, readable output in the case of both passing and failing tests.&lt;/li&gt;
&lt;/ul&gt;
&lt;ul&gt;
&lt;li&gt;An optional browser-based test runner that can simply be refreshed whenever JS is changed.&lt;/li&gt;
&lt;/ul&gt;
&lt;ul&gt;
&lt;li&gt;Style and semantics that resemble&amp;nbsp;&lt;a href="http://code.google.com/p/googletest/" target="blank"&gt;Google Test&lt;/a&gt;&amp;nbsp;for C++.&lt;/li&gt;
&lt;/ul&gt;
&lt;ul&gt;
&lt;li&gt;A built-in mocking framework that requires minimal boilerplate code (e.g. no&amp;nbsp;&lt;span style="font-family: 'courier new';"&gt;$tearDown&lt;/span&gt;&amp;nbsp;or&lt;span style="font-family: 'courier new';"&gt;$verifyAll&lt;/span&gt;&amp;nbsp;calls), with style and semantics based on the&amp;nbsp;&lt;a href="http://code.google.com/p/googletest/" target="blank"&gt;Google C++ Mocking Framework&lt;/a&gt;.&lt;/li&gt;
&lt;/ul&gt;
&lt;ul&gt;
&lt;li&gt;A system of&amp;nbsp;&lt;a href="http://code.google.com/p/google-js-test/wiki/Matchers" target="blank"&gt;matchers&lt;/a&gt;&amp;nbsp;allowing for expressive tests and easy to read failure output, with many built-in matchers and the ability for the user to add their own.&lt;br /&gt;&lt;br /&gt;&lt;a href="http://3.bp.blogspot.com/-k6633PjXL0I/ToSssXafqgI/AAAAAAAAAQI/t5Ux_dHrA6E/s1600/image00.png"&gt;&lt;img alt="" border="0" id="BLOGGER_PHOTO_ID_5657836910083549698" src="http://3.bp.blogspot.com/-k6633PjXL0I/ToSssXafqgI/AAAAAAAAAQI/t5Ux_dHrA6E/s320/image00.png" style="border-bottom-color: rgb(204, 204, 204); border-bottom-style: solid; border-bottom-width: 1px; border-left-color: rgb(204, 204, 204); border-left-style: solid; border-left-width: 1px; border-right-color: rgb(204, 204, 204); border-right-style: solid; border-right-width: 1px; border-top-color: rgb(204, 204, 204); border-top-style: solid; border-top-width: 1px; cursor: pointer; display: block; height: 320px; margin-bottom: 10px; margin-left: auto; margin-right: auto; margin-top: 0px; padding-bottom: 4px; padding-left: 4px; padding-right: 4px; padding-top: 4px; text-align: center; width: 214px;" /&gt;&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
See the Google JS Test&amp;nbsp;&lt;a href="http://code.google.com/p/google-js-test/" target="blank"&gt;project home page&lt;/a&gt;&amp;nbsp;for a quick introduction, and the&amp;nbsp;&lt;a href="http://code.google.com/p/google-js-test/wiki/GettingStarted" target="blank"&gt;getting started&lt;/a&gt;&amp;nbsp;page for a tutorial that will teach you the basics in just a few minutes.&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-5537504377629238596?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=M7_c720yjoA:W7AD-0z6dD0:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=M7_c720yjoA:W7AD-0z6dD0:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=M7_c720yjoA:W7AD-0z6dD0:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/M7_c720yjoA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/5537504377629238596/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=5537504377629238596" title="3 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/5537504377629238596?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/5537504377629238596?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/M7_c720yjoA/google-js-test-now-in-open-source.html" title="Google JS Test, now in Open Source" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="http://3.bp.blogspot.com/-k6633PjXL0I/ToSssXafqgI/AAAAAAAAAQI/t5Ux_dHrA6E/s72-c/image00.png" height="72" width="72" /><thr:total>3</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/10/google-js-test-now-in-open-source.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DU4ARXo5fyp7ImA9WhdbFE4.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-4224168680663407109</id><published>2011-10-12T09:21:00.000-07:00</published><updated>2011-10-12T09:45:44.427-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-10-12T09:45:44.427-07:00</app:edited><title>Take a BITE out of Bugs and Redundant Labor</title><content type="html">&lt;div style="font-family: Times; font-size: medium; background-color: transparent; "&gt;&lt;span id="internal-source-marker_0.5106434298213571" style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; "&gt;In a time when more and more of the web is becoming streamlined, the process of filing bugs for websites remains tedious and manual. Find an issue. Switch to your bug system window. Fill out boilerplate descriptions of the problem. Switch back to the browser, take a screenshot, attach it to the issue. Type some more descriptions.  The whole process is one of context switching; from the tools used to file the bug, to gather information about it, to highlight problematic areas, most of your focus as the tester is pulled away from the very application you’re trying to test.&lt;/span&gt;&lt;br /&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; "&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; "&gt;The Browser Integrated Testing Environment, or BITE, is an open source &lt;a href="http://code.google.com/chrome/extensions/index.html"&gt;Chrome Extension&lt;/a&gt; which aims to fix the manual web testing experience. To use the extension, it must be linked to a server providing information about bugs and tests in your system. BITE then provides the ability to file bugs from the context of a website, using relevant templates.&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; "&gt;&lt;span class="Apple-style-span"&gt;&lt;span class="Apple-style-span" style="font-size: 15px; white-space: pre-wrap;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="Apple-style-span" style="font-family: Times; font-size: medium; "&gt;&lt;img src="https://lh5.googleusercontent.com/ZH7GzUXHsfo1TzxEoVmlmeh8XsXvhWfdiLiQypB7sW-cp81CExw8oOMvEF_GEcwd1tX8NgBJgFvR_8II6PDF1gMpc4ZiksQGP_bzAKyWaJ6t5mo0Z70" width="604px;" height="367px;" /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; "&gt;&lt;span style="color: rgb(0, 0, 0); font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; background-color: transparent; "&gt;&lt;/span&gt;&lt;span style="color: rgb(0, 0, 0); font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; background-color: transparent; "&gt;&lt;/span&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; "&gt;When filing a bug, BITE automatically grabs screenshots, links, and problematic UI elements and attaches them to the bug.  This gives developers charged with investigating and/or fixing the bug a wealth of information to help them determine root causes and factors in the behavior.&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; "&gt;&lt;span class="Apple-style-span"&gt;&lt;span class="Apple-style-span" style="font-size: 15px; white-space: pre-wrap;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/span&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; font-size: 11pt; background-color: transparent;"&gt;&lt;/span&gt;&lt;span class="Apple-style-span"&gt;&lt;img src="https://lh4.googleusercontent.com/Pw0rOhKvFlJ-CzcF0LuI-YkdtoLmwR4eMPHLej2dWbNnluSFLaongBcPR_ObzCgLfX_gV65zUCEdF8Aczz7E3WIhXdnVUwmMWgGt5AZreFXX3kAqfQs" width="616px;" height="375px;" /&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; font-size: 11pt; background-color: transparent;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; "&gt;When it comes to reproducing a bug, testers will often labor to remember and accurately record the exact steps taken.  With BITE, however, every action the tester takes on the page is recorded in JavaScript, and can be played back later.  This enables engineers to quickly determine if the steps of a bug repro in a specific environment, or whether a code change has resolved the issue.&lt;/span&gt;&lt;br /&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; font-size: 11pt; background-color: transparent;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; "&gt;Also included in BITE is a Record/Playback console to automate user actions in a manual test.  Like the BITE recording experience, the RPF console will automatically author javascript that can be used to replay your actions at a later date.  And BITE’s record and playback mechanism is fault tolerant; UI automation tests will fail from time to time, and when they do, it tends to be for test issues, rather than product issues.  To that end, when a BITE playback fails, the tester can fix their recording in real-time, just by repeating the action on the page.  There’s no need to touch code, or report a failing test; if your script can’t find a button to click on, just click on it again, and the script will be fixed!  For those times when you do have to touch the code, we’ve used the Ace &lt;/span&gt;&lt;a href="about:blank" style="font-family: Times; font-size: medium; "&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap; "&gt;(http://ace.ajax.org/)&lt;/span&gt;&lt;/a&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; "&gt; as an inline editor, so you can make changes to your javascript in real-time.&lt;/span&gt;&lt;br /&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; font-size: 11pt; background-color: transparent;"&gt;&lt;/span&gt;&lt;br /&gt;&lt;span style="font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-style: normal; font-variant: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap; "&gt;Check out the BITE project page at &lt;a href="http://code.google.com/p/bite-project"&gt;http://code.google.com/p/bite-project&lt;/a&gt;. Feedback is welcome at bite-feedback@google.com.  Posted by Joe Allan Muharsky from the Web Testing Technologies Team (Jason Stredwick, Julie Ralph, Po Hu and Richard Bustamante are the members of the team that delivered the product).&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/15045980-4224168680663407109?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=uCNiGi0FO_c:eAPRs3s478U:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=uCNiGi0FO_c:eAPRs3s478U:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=uCNiGi0FO_c:eAPRs3s478U:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/uCNiGi0FO_c" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/4224168680663407109/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=4224168680663407109" title="11 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/4224168680663407109?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/4224168680663407109?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/uCNiGi0FO_c/take-bite-out-of-bugs-and-redundant.html" title="Take a BITE out of Bugs and Redundant Labor" /><author><name>Unknown</name><uri>http://www.blogger.com/profile/12530878126039898277</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>11</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/10/take-bite-out-of-bugs-and-redundant.html</feedburner:origLink></entry><entry gd:etag="W/&quot;A04BRHszfSp7ImA9WhdUGU4.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-6623143857469937895</id><published>2011-10-06T13:52:00.000-07:00</published><updated>2011-10-06T15:25:55.585-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-10-06T15:25:55.585-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="test" /><category scheme="http://www.blogger.com/atom/ns#" term="GTAC" /><title>Unleash the QualityBots</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
By Richard Bustamante&lt;br /&gt;
&lt;br /&gt;
Are you a website developer that wants to know if Chrome updates will break 
your website before they reach the stable release channel? Have you ever wished 
there was an easy way to compare how your website appears in all channels of 
Chrome? Now you can!&lt;br /&gt;
&lt;br /&gt;
&lt;a href="http://code.google.com/p/qualitybots/" target="blank"&gt;QualityBots&lt;/a&gt; is a new open source tool for web developers 
created by the Web Testing team at Google. It’s a comparison tool that examines 
web pages across different Chrome channels using pixel-based DOM analysis. As 
new versions of Chrome are pushed, QualityBots serves as an early warning system 
for breakages. Additionally, it helps developers quickly and easily understand 
how their pages appear across Chrome channels.
&lt;br /&gt;
&lt;div&gt;
&lt;br /&gt;
&lt;a href="http://3.bp.blogspot.com/-M0RnzjKe3dU/To3n21D40RI/AAAAAAAAAQ8/tRHGTZ4fFbg/s1600/image01.png"&gt;&lt;img alt="" border="0" height="286" id="BLOGGER_PHOTO_ID_5660435235816919314" src="http://3.bp.blogspot.com/-M0RnzjKe3dU/To3n21D40RI/AAAAAAAAAQ8/tRHGTZ4fFbg/s400/image01.png" style="display: block; margin: 0px auto 10px; text-align: center;" width="400" /&gt;&lt;/a&gt;&lt;br /&gt;
QualityBots 
is built on top of &lt;a href="http://code.google.com/appengine/" target="blank"&gt;Google AppEngine&lt;/a&gt; for the frontend and Amazon EC2 for the 
backend workers that crawl the web pages. Using QualityBots requires an Amazon 
EC2 account to run the virtual machines that will crawl public web pages with 
different versions of Chrome. The tool provides a web frontend where users can 
log on and request URLs that they want to crawl, see the results from the latest 
run on a dashboard, and drill down to get detailed information about what 
elements on the page are causing the trouble.&lt;br /&gt;
&lt;br /&gt;
Developers and testers can 
use these results to identify sites that need attention due to a high amount of 
change and to highlight the pages that can be safely ignored when they render 
identically across Chrome channels. This saves time and the need for tedious 
compatibility testing of sites when nothing has changed.&lt;br /&gt;
&lt;br /&gt;
&lt;img alt="" border="0" height="251" id="BLOGGER_PHOTO_ID_5660227647872301122" src="http://3.bp.blogspot.com/-iteL8ECp8qg/To0rDntF-EI/AAAAAAAAAQw/ak5qIOHvb-o/s400/image00.png" style="display: block; margin: 0px auto 10px; text-align: center;" width="400" /&gt;&lt;br /&gt;
&lt;br /&gt;
We 
hope that interested website developers will take a deeper look and even join 
the project at the QualityBots &lt;a href="http://code.google.com/p/qualitybots/" target="blank"&gt;project page&lt;/a&gt;. Feedback is more than welcome at 
qualitybots-discuss@googlegroups.com.&lt;/div&gt;
&lt;span class="byline-author"&gt;Posted by Ibrahim El Far, Web Testing Technologies&amp;nbsp;Team (Eriel Thomas, Jason Stredwick, Richard Bustamante, and Tejas Shah are the members of the team that delivered this product)&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/15045980-6623143857469937895?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=TNHyD7f3Bm8:bSIiowsYTT8:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=TNHyD7f3Bm8:bSIiowsYTT8:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=TNHyD7f3Bm8:bSIiowsYTT8:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/TNHyD7f3Bm8" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/6623143857469937895/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=6623143857469937895" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/6623143857469937895?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/6623143857469937895?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/TNHyD7f3Bm8/unleash-qualitybots.html" title="Unleash the QualityBots" /><author><name>Ibrahim (Google)</name><uri>http://www.blogger.com/profile/10683234753186013667</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="26" height="32" src="http://4.bp.blogspot.com/-73iYTViixSM/Todhxl0cYUI/AAAAAAAAAEY/4zxMA_2-5pM/s220/ibrahimelfar.png" /></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="http://3.bp.blogspot.com/-M0RnzjKe3dU/To3n21D40RI/AAAAAAAAAQ8/tRHGTZ4fFbg/s72-c/image01.png" height="72" width="72" /><thr:total>2</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/10/unleash-qualitybots.html</feedburner:origLink></entry><entry gd:etag="W/&quot;D0UMQn0_eSp7ImA9WhdUEEg.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-5666384732399561218</id><published>2011-09-26T09:41:00.000-07:00</published><updated>2011-09-26T09:41:23.341-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-09-26T09:41:23.341-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><title>From Google Dev Day to STAR West</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
By James Whittaker&lt;br /&gt;
&lt;br /&gt;
Google Dev Days in Brazil and Argentina are over (sigh) and now I turn my attention to STAR West in Anaheim. Unfortunately, it is too late to register for my tutorials as I was informed both are sold out.&lt;br /&gt;
&lt;br /&gt;
If you attend STAR, please take the time to say hello.&lt;/div&gt;
&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-5666384732399561218?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=rtUqGSROdao:4Rgk5C0AxQI:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=rtUqGSROdao:4Rgk5C0AxQI:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=rtUqGSROdao:4Rgk5C0AxQI:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/rtUqGSROdao" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/5666384732399561218/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=5666384732399561218" title="1 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/5666384732399561218?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/5666384732399561218?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/rtUqGSROdao/from-google-dev-day-to-star-west.html" title="From Google Dev Day to STAR West" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>1</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/09/from-google-dev-day-to-star-west.html</feedburner:origLink></entry><entry gd:etag="W/&quot;AkACRXo6fCp7ImA9WhdWGE4.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-7097248018576480169</id><published>2011-09-12T07:46:00.000-07:00</published><updated>2011-09-12T07:46:04.414-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-09-12T07:46:04.414-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="GTAC" /><title>Announcing the Final GTAC Agenda</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
By James Whittaker&lt;br /&gt;
&lt;br /&gt;
The GTAC agenda is now finalized and available at:&amp;nbsp;&lt;a href="http://www.gtac.biz/agenda"&gt;http://www.gtac.biz/agenda&lt;/a&gt;. Looking forward to seeing everyone there. Stay tuned to this blog for updates to any pre- and post- events.&lt;/div&gt;
&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-7097248018576480169?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=8Dd_stQhA58:WV7ON23D2iM:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=8Dd_stQhA58:WV7ON23D2iM:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=8Dd_stQhA58:WV7ON23D2iM:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/8Dd_stQhA58" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/7097248018576480169/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=7097248018576480169" title="1 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/7097248018576480169?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/7097248018576480169?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/8Dd_stQhA58/announcing-final-gtac-agenda.html" title="Announcing the Final GTAC Agenda" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>1</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/09/announcing-final-gtac-agenda.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CEIFR3o8cCp7ImA9WhdXGUw.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-2224703301408820158</id><published>2011-09-01T14:28:00.000-07:00</published><updated>2011-09-01T14:28:36.478-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-09-01T14:28:36.478-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><title>The 10 Minute Test Plan</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;
&lt;br /&gt;
By James Whittaker&lt;br /&gt;
&lt;br /&gt;
Anything in software development that takes ten minutes or less to perform is either trivial or is not worth doing in the first place. If you take this rule of thumb at face value, where do you place test planning? Certainly it takes more than 10 minutes. In my capacity as Test Director at Google I presided over teams that wrote a large number of test plans and every time I asked how long one would take I was told “tomorrow” or “the end of the week” and a few times, early in the day, I was promised one “by the end of the day.” So I’ll establish the task of test planning to be of the hours-to-days duration.&lt;br /&gt;
&lt;br /&gt;
As to whether it is worth doing, well, that is another story entirely. Every time I look at any of the dozens of test plans my teams have written, I see dead test plans. Plans written, reviewed, referred to a few times and then cast aside as the project moves in directions not documented in the plan. This begs the question: if a plan isn’t worth bothering to update, is it worth creating in the first place?&lt;br /&gt;
&lt;br /&gt;
Other times a plan is discarded because it went into too much detail or too little; still others because it provided value only in starting a test effort and not in the ongoing work. Again, if this is the case, was the plan worth the cost of creating it given its limited and diminishing value?&lt;br /&gt;
&lt;br /&gt;
Some test plans document simple truths that likely didn’t really need documenting at all or provide detailed information that isn’t relevant to the day to day job of a software tester. In all these cases we are wasting effort. Let’s face facts here: there is a problem with the process and content of test plans.&lt;br /&gt;
&lt;br /&gt;
To combat this, I came up with a simple task for my teams: write a test plan in 10 minutes. The idea is simple, if test plans have any value at all then let’s get to that value as quickly as possible.&lt;br /&gt;
&lt;br /&gt;
Given ten minutes, there is clearly no room for fluff. It is a time period so compressed that every second must be spent doing something useful or any hope you have of actually finishing the task is gone. This was the entire intent behind the exercise from my point of view: boil test planning down to only the essentials and cut all fat and fluff. Do only what is absolutely necessary and leave the details to the test executors as opposed to the test planners. If I wanted to end the practice of writing test plans that don’t stand the test of time, this seemed a worthwhile exercise.&lt;br /&gt;
&lt;br /&gt;
However, I didn’t tell the people in the experiment any of this. I told them only: here is an app, create a test plan in 10 minutes or less. Remember that these people work for me and, technically, are paid to do as I tell them. And, again&amp;nbsp;&lt;i&gt;technically&lt;/i&gt;&amp;nbsp;I am uniquely positioned to begin termination procedures with respect to their Google employment. On top of that I am presuming they have some measure of respect for me, which means they were likely convinced I actually thought they could do it. This was important to me. I wanted them to expect to succeed!&lt;br /&gt;
&lt;br /&gt;
As preparation they could spend some time with the app in question and familiarize themselves with it. However, since many of the apps we used (Google Docs, App Engine, Talk Video, etc.) were tools they used every week, this time was short.&lt;br /&gt;
&lt;br /&gt;
So here's how the task progressed:&lt;br /&gt;
&lt;br /&gt;
They started, did some work and when ten minutes passed I interrupted them. They stated they weren't done yet. I responded by telling them they were out of time, nice try, here's a different problem to work on. 10 minutes later, the same thing happened and I changed the problem again. They began working faster and trying different angles, things that were too time consuming or not worth the effort got jettisoned really quick!&lt;br /&gt;
&lt;br /&gt;
In each case, the teams came up with techniques that helped speed things along. They chose to jot down lists and create grids over writing long paragraphs of prose. Sentences … yes, paragraphs … no. They wasted little time on formatting and explanations and chose instead to document capabilities. Indeed, capabilities or&amp;nbsp;&lt;i&gt;what the software actually does&lt;/i&gt;, were the one commonality of all the plans. Capabilities were the one thing that all the teams gravitated toward as the most useful way to spend the little time they were given.&lt;br /&gt;
&lt;br /&gt;
The three things that emerged as most important:&lt;br /&gt;
&lt;br /&gt;
1.&amp;nbsp;&lt;b&gt;Attributes&lt;/b&gt;&amp;nbsp;the adverbs and adjectives that describe the high level concepts testing is meant to ensure. Attributes such as fast, usable, secure, accessible and so forth.&lt;br /&gt;
&lt;br /&gt;
2.&amp;nbsp;&lt;b&gt;Components&lt;/b&gt;&amp;nbsp;the nouns that define the major code chunks that comprise the product. These are classes, module names and features of the application.&lt;br /&gt;
&lt;br /&gt;
3.&amp;nbsp;&lt;b&gt;Capabilities&lt;/b&gt;&amp;nbsp;the verbs that describe user actions and activities.&lt;br /&gt;
&lt;br /&gt;
None of the teams finished the experiment in the 10 minutes allotted. However, in 10 minutes they were all able to get through both the Attributes and Components (or things that served a similar purpose) and begin documenting Capabilities. At the end of an additional 20 minutes most of the experiments had a large enough set of Capabilities that it would have been a useful starting point for creating user stories or test cases.&lt;br /&gt;
&lt;br /&gt;
Which, at least to me, made the experiment a success. I gave them 10 minutes and hoped for an hour. They had 80% of the work complete in 30 minutes. And really isn’t 80% enough? We know full well that we are not going to test everything so why document everything? We know full well that as we start testing, things (schedules, requirements, architecture, etc.) are going to change so insisting on planning precision when nothing else obeys such a calling for completeness seems out of touch with reality.&lt;br /&gt;
&lt;br /&gt;
80% complete in 30 minutes or less. Now that’s what I call a 10 minute test plan!&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/15045980-2224703301408820158?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=sVIqZIfQC3s:SushnocUZ2I:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=sVIqZIfQC3s:SushnocUZ2I:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=sVIqZIfQC3s:SushnocUZ2I:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/sVIqZIfQC3s" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/2224703301408820158/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=2224703301408820158" title="22 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/2224703301408820158?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/2224703301408820158?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/sVIqZIfQC3s/10-minute-test-plan.html" title="The 10 Minute Test Plan" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>22</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/09/10-minute-test-plan.html</feedburner:origLink></entry><entry gd:etag="W/&quot;D0EESXg9eyp7ImA9WhdQF0U.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-5167430069525587592</id><published>2011-08-19T13:26:00.000-07:00</published><updated>2011-08-19T13:26:48.663-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-08-19T13:26:48.663-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><title>Google Developer Day 2011</title><content type="html">By James Whittaker&lt;br /&gt;
&lt;br /&gt;
Google Developer Day is gearing up for a fantastic fall season of tours that crawl the continents. And a surprise this year ... &lt;i&gt;yours truly&lt;/i&gt; will be the keynote for the Developer Day in Sao Paulo Brazil and Buenos Aires Argentina in September. &lt;br /&gt;
&lt;br /&gt;
Google Developer Day is a deep dive into the future of Web, Mobile and Cloud technologies crafted specifically for software engineering professionals. And this year we are adding the element of Social to tie it all together. Google+ is only the start. &lt;br /&gt;
&lt;br /&gt;
If you are attending, please stop by and say hello!&lt;br /&gt;
&lt;br /&gt;
Click &lt;a href="http://www.google.com/events/developerday/2011/"&gt;here&lt;/a&gt; for more information about dates and agenda.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-5167430069525587592?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=JNhLiQSQzsQ:BO2Ql7_qfDw:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=JNhLiQSQzsQ:BO2Ql7_qfDw:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=JNhLiQSQzsQ:BO2Ql7_qfDw:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/JNhLiQSQzsQ" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/5167430069525587592/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=5167430069525587592" title="1 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/5167430069525587592?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/5167430069525587592?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/JNhLiQSQzsQ/google-developer-day-2011.html" title="Google Developer Day 2011" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>1</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/08/google-developer-day-2011.html</feedburner:origLink></entry><entry gd:etag="W/&quot;A0QBSH89eSp7ImA9WhdQFkQ.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-8283774690424929138</id><published>2011-08-18T13:29:00.000-07:00</published><updated>2011-08-18T13:29:19.161-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-08-18T13:29:19.161-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="GTAC" /><title>GTAC Speakers and Attendees Finalized</title><content type="html">We've completed the agenda for GTAC 2011 and are in the process of notifying accepted speakers and attendees. Once we have firm accepts we'll be publicizing the agenda.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-8283774690424929138?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=DKf6eOzDTsA:3IdiiNPrFIA:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=DKf6eOzDTsA:3IdiiNPrFIA:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=DKf6eOzDTsA:3IdiiNPrFIA:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/DKf6eOzDTsA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/8283774690424929138/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=8283774690424929138" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/8283774690424929138?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/8283774690424929138?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/DKf6eOzDTsA/gtac-speakers-and-attendees-finalized.html" title="GTAC Speakers and Attendees Finalized" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>2</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/08/gtac-speakers-and-attendees-finalized.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DU8GQXg5cCp7ImA9WhdQFUw.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-4968060280903259424</id><published>2011-08-16T09:34:00.000-07:00</published><updated>2011-08-16T11:03:40.628-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-08-16T11:03:40.628-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="alberto savoia" /><category scheme="http://www.blogger.com/atom/ns#" term="testing" /><category scheme="http://www.blogger.com/atom/ns#" term="test" /><category scheme="http://www.blogger.com/atom/ns#" term="prototyping" /><category scheme="http://www.blogger.com/atom/ns#" term="pretotyping" /><category scheme="http://www.blogger.com/atom/ns#" term="pretotype" /><title>Pretotyping: A Different Type of Testing</title><content type="html">&lt;span style="font-weight:bold;"&gt;Have you ever poured your heart and soul and blood, sweat and tears to help test and perfect a product that, after launch, flopped miserably?  Not because it was not working right (you tested &lt;span style="font-style:italic;"&gt;the snot out of it&lt;/span&gt;), but because it was not the right product.
&lt;br /&gt;
&lt;br /&gt;Are you currently wasting your time testing a new product or feature that, in the end, nobody will use?&lt;/span&gt;
&lt;br /&gt;
&lt;br /&gt;Testing typically revolves around making sure that we have built something right.  Testing activities can be roughly described as “verifying that something works as intended, or as specified.”  This is critical.  However, before we take steps and invest time and effort to make sure that something built right, we should make sure that the thing we are testing, whether its a new feature or a whole new product, is the right thing to build in the first place.
&lt;br /&gt;
&lt;br /&gt;Spending time, money and effort to test something that nobody ends up using is a waste of time.
&lt;br /&gt;
&lt;br /&gt;For the past couple of years, I’ve been thinking about, and working on, a concept called pretotyping.
&lt;br /&gt;
&lt;br /&gt;What is pretotyping?  Here’s a somewhat formal definition – the dry and boring kind you’d find in a dictionary:
&lt;br /&gt;
&lt;br /&gt;&lt;span style="font-style:italic;"&gt;Pretotyping [pree-tuh-tahy-ping], verb: Testing the initial appeal and actual usage of a potential new product by simulating its core experience with the smallest possible investment of time and money.&lt;/span&gt;
&lt;br /&gt;
&lt;br /&gt;Here’s a less formal definition: 
&lt;br /&gt;
&lt;br /&gt;&lt;span style="font-style:italic;"&gt;Pretotyping is a way to test an idea quickly and inexpensively by creating extremely simplified, mocked or virtual versions of that product to help validate the premise that "If we build it, they will use it."&lt;/span&gt;
&lt;br /&gt;
&lt;br /&gt;My favorite definition of pretotyping, however, is this:
&lt;br /&gt;
&lt;br /&gt;&lt;span style="font-style:italic;"&gt;Make sure – as quickly and as cheaply as you can – that you are building the right it before you build it right.
&lt;br /&gt;&lt;/span&gt;
&lt;br /&gt;My thinking on pretotyping evolved from my positive experiences with Agile and Test Driven Development.  Pretotyping applies some of the core ideas from these two models and applies them further &lt;span style="font-style:italic;"&gt;upstream&lt;/span&gt; in the development cycle.
&lt;br /&gt;
&lt;br /&gt;I’ve just finished writing the first draft of a booklet on pretotyping called “Pretotype It”:
&lt;br /&gt;
&lt;br /&gt;&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://2.bp.blogspot.com/-SRz8AOFeKG8/TkqcaE0NcfI/AAAAAAAABE4/RHMP-E5MxXw/s1600/PretotypeItBookCover.png"&gt;&lt;img style="display:block; margin:0px auto 10px; text-align:center;cursor:pointer; cursor:hand;width: 230px; height: 320px;" src="http://2.bp.blogspot.com/-SRz8AOFeKG8/TkqcaE0NcfI/AAAAAAAABE4/RHMP-E5MxXw/s320/PretotypeItBookCover.png" border="0" alt=""id="BLOGGER_PHOTO_ID_5641493455018226162" /&gt;&lt;/a&gt;
&lt;br /&gt;
&lt;br /&gt;You can download a PDF of the booklet from &lt;a href="https://docs.google.com/viewer?a=v&amp;pid=explorer&amp;chrome=true&amp;srcid=0B0QztbuDlKs_NzBjYWNiOGQtNmQyNi00OWE2LWI2YzktN2Y3YTEzM2VjYTNj&amp;hl=en_US"&gt;Google Docs&lt;/a&gt; or &lt;a href="http://www.scribd.com/doc/62418833/Pretotype-It-First-Pretotype-Edition"&gt;Scribd&lt;/a&gt;.
&lt;br /&gt;
&lt;br /&gt;The "Pretotype It" booklet is itself a pretotype and test.  I wrote this first-draft to test my (possibly optimistic) assumption that people would be interested in it, so please let me know what you think of it.
&lt;br /&gt;
&lt;br /&gt;You can follow my pretotyping work on &lt;a href="http://pretotyping.blogspot.com"&gt;my pretotyping blog&lt;/a&gt;.
&lt;br /&gt;
&lt;br /&gt;Post content&lt;span class="byline-author"&gt;Posted by Alberto Savoia&lt;/span&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-4968060280903259424?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=7biIxdRajJQ:KZyKldDi8_A:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=7biIxdRajJQ:KZyKldDi8_A:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=7biIxdRajJQ:KZyKldDi8_A:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/7biIxdRajJQ" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/4968060280903259424/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=4968060280903259424" title="11 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/4968060280903259424?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/4968060280903259424?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/7biIxdRajJQ/pretotyping-different-type-of-testing.html" title="Pretotyping: A Different Type of Testing" /><author><name>Alberto Savoia</name><uri>http://www.blogger.com/profile/14622398185391305870</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="http://2.bp.blogspot.com/-SRz8AOFeKG8/TkqcaE0NcfI/AAAAAAAABE4/RHMP-E5MxXw/s72-c/PretotypeItBookCover.png" height="72" width="72" /><thr:total>11</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/08/pretotyping-different-type-of-testing.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CU4AR30-fSp7ImA9WhdREk8.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-3742772058603210030</id><published>2011-08-01T11:39:00.000-07:00</published><updated>2011-08-01T11:39:06.355-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-08-01T11:39:06.355-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><category scheme="http://www.blogger.com/atom/ns#" term="GTAC" /><title>Keynote Lineup for GTAC 2011</title><content type="html">By James Whittaker&lt;br /&gt;
&lt;br /&gt;
The call for proposals and participation is now closed. Over the next few weeks we will be announcing the full agenda and notifying accepted participants. In the meantime, the keynote lineup is now locked. It consists of two famous Googlers and two famous external speakers that I am very pleased to have join us.&lt;br /&gt;
&lt;br /&gt;
Opening Keynote: &lt;b&gt;Test is Dead&lt;/b&gt; by &lt;b&gt;Alberto Savoia&lt;/b&gt;&lt;br /&gt;
&lt;br /&gt;
The way most software is designed, developed and launched has changed dramatically over the last decade – but what about testing?  Alberto Savoia believes that software testing as we knew it is dead – or at least moribund – in which case we should stick a fork in it and proactively take it out of its misery for good.  In this opening keynote of biblical scope, Alberto will cast stones at the old test-mentality and will try his darnedest to agitate you and convince you that these days most testers should follow a new test-mentality, one which includes shifting their focus and priority from “Are we building it right?” to “Are we building the right it?”  The subtitle of this year’s GTAC is “cloudy with a chance of tests,” and if anyone can gather the clouds into a hurricane, it's Alberto – it might be wise to bring your umbrella.&lt;br /&gt;
&lt;br /&gt;
&lt;i&gt;Alberto Savoia is Director of Engineering and Innovation Agitator at Google. In addition to leading several major product development efforts (including the launch of Google AdWords), Alberto has been a lifelong believer, champion, innovator and entrepreneur in the area of developer testing and test automation tools.  He is a frequent keynote speaker and the author of many articles on testing, including the classic booklet “The Way of Testivus” and “Beautiful Tests” in O’Reilly’s Beautiful Code.  His work in software development tools has won him several awards including the 2005 Wall Street Journal Technical Innovator Award, InfoWorld’s Technology of the Year award, and no less than four Software Development Magazine Jolt Awards.&lt;br /&gt;
&lt;/i&gt;&lt;br /&gt;
Day 1 Closer: &lt;b&gt;Redefining Security Vulnerabilities: How Attackers See Bugs&lt;/b&gt; by &lt;b&gt;Herbert H. Thompson&lt;/b&gt;&lt;br /&gt;
&lt;br /&gt;
Developers see features, testers see bugs, and attackers see “opportunities.” Those opportunities are expanding beyond buffer overflows, cross site scripting, etc. into logical bugs (and features) that allow attackers to use the information they find to exploit trusting users. For example, attackers can leverage a small information disclosure issue in an elaborate phishing attempt. When you add people in the mix, we need to reevaluate which “bugs” are actual security vulnerabilities. This talk is loaded with real world examples of how attackers are using software “features” and information tidbits (many of which come from bugs) to exploit the biggest weakness of all: trusting users.&lt;br /&gt;
&lt;br /&gt;
&lt;i&gt;Dr. Herbert H. Thompson is Chief Security Strategist at People Security and a world-renown expert in application security. He has co-authored four books on the topic including, How to Break Software Security: Effective Techniques for Security Testing (with Dr. James Whittaker) and The Software Vulnerability Guide (with Scott Chase). In 2006 he was named one of the “Top 5 Most Influential Thinkers in IT Security” by SC Magazine. Thompson continually lends his perspective and expertise on secure software development and has been interviewed by top news organizations including CNN, MSNBC, BusinessWeek, Forbes, Associated Press, and the Washington Post.  He is also Program Committee Chair for RSA Conference, the world’s leading information security gathering. He holds a Ph.D. in Applied Mathematics from Florida Institute of Technology, and is an adjunct professor in the Computer Science department at Columbia University in New York.&lt;br /&gt;
&lt;/i&gt;&lt;br /&gt;
Day 2 Opener: &lt;b&gt;Engineering Productivity: Accelerating Google Since 2006&lt;/b&gt; by &lt;b&gt;Patrick Copeland&lt;/b&gt;&lt;br /&gt;
&lt;br /&gt;
Patrick Copeland is the founder and architect of Google's testing and productivity strategy and in this "mini keynote" he tells the story and relates the pain of taking a company from ad hoc testing practices to the pinnacle of what can be accomplished with a well oiled test engineering discipline. &lt;br /&gt;
&lt;br /&gt;
Conference Closer: &lt;b&gt;Secrets of World-Class Software Organizations&lt;/b&gt; by &lt;b&gt;Steve McConnell&lt;/b&gt;&lt;br /&gt;
&lt;br /&gt;
Construx consultants work with literally hundreds of software organizations each year. Among these organizations a few stand out as being truly world class. They are exceptional in their ability to meet their software development goals and exceptional in the contribution they make to their companies' overall business success. Do world class software organizations operate differently than average organizations? In Construx's experience, the answer is a resounding "YES." In this talk, award-winning author Steve McConnell reveals the technical, management, business, and cultural secrets that make a software organization world class.&lt;br /&gt;
&lt;br /&gt;
&lt;i&gt;Steve McConnell is CEO and Chief Software Engineer at Construx Software where he consults to a broad range of industries, teaches seminars, and oversees Construx’s software engineering practices. Steve is the author of Software Estimation: Demystifying the Black Art (2006), Code Complete (1993, 2004), Rapid Development (1996), Software Project Survival Guide (1998), and Professional Software Development (2004), as well as numerous technical articles. His books have won numerous awards for "Best Book of the Year," and readers of Software Development magazine named him one of the three most influential people in the software industry along with Bill Gates and Linus Torvalds.&lt;br /&gt;
&lt;/i&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-3742772058603210030?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=3fZKYyyN8kU:mwL8L_j6sug:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=3fZKYyyN8kU:mwL8L_j6sug:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=3fZKYyyN8kU:mwL8L_j6sug:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/3fZKYyyN8kU" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/3742772058603210030/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=3742772058603210030" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/3742772058603210030?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/3742772058603210030?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/3fZKYyyN8kU/keynote-lineup-for-gtac-2011.html" title="Keynote Lineup for GTAC 2011" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>0</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/08/keynote-lineup-for-gtac-2011.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DEYGRHY6cSp7ImA9WhdSGE0.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-5950025234592171231</id><published>2011-07-27T15:34:00.000-07:00</published><updated>2011-07-27T15:35:25.819-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-07-27T15:35:25.819-07:00</app:edited><title>How We Tested Google Instant Pages</title><content type="html">By Jason Arbon and Tejas Shah&lt;br /&gt;
&lt;br /&gt;
&lt;a href="http://googlewebmastercentral.blogspot.com/2011/06/announcing-instant-pages.html"&gt;Google Instant Pages&lt;/a&gt; are a cool new way that Google speeds up your search experience.  When Google thinks it knows which result you are likely to click, it preloads that page in the background, so when you click the page it renders instantly, saving the user about 5 seconds.  5 seconds is significant when you think of how many searches are performed each day--and especially when you consider that the rest of the search experience is optimized for sub-second performance.&lt;br /&gt;
&lt;br /&gt;
The testing problem here is interesting. This feature requires client and server coordination, and since we are pre-loading and rendering the pages in an invisible background page, we wanted to make sure that nothing major was broken with the page rendering.&lt;br /&gt;
&lt;br /&gt;
The original idea was for developers to test out a few pages as they went.But, this doesn’t scale to a large number of sites and is very expensive to repeat. Also, how do you know what the pages should look like? To write Selenium tests to functionally validate thousands of sites would take forever--the product would ship first. The solution was to perform automated test runs that load these pages from search results with Instant Pages turned on, and another run with Instant Pages turned off. The page renderings from each run were then compared.&lt;br /&gt;
&lt;br /&gt;
How did we compare the two runs? How to compare pages when content and ads on web pages are constantly changing and we don't know what the expected behavior is? We could have used cached versions of these pages, but that wouldn’t be the realworld experience we were testing and would take time setting up, and the timing would have been different. We opted to leverage some other work that compares pages using the Document Object Model (DOM). We automatically scan each page, pixel by pixel, but look at what element is visible at the point on the page, not the color/RGB values. We then do a simple measure of how closely these pixel measurements match. These so-called "quality bots" generate a score of 0-100%, where 100% means all measurements were identical.&lt;br /&gt;
&lt;br /&gt;
When we performed the runs, the vast majority (~95%) of all comparisons were almost identical, like we hoped. Where the pages where different we built a web page that showed the differences between the two pages by rendering both images and highlighting the difference. It was quick and easy for the developers to visually verify that the differences were only due to content or other non-structural differences in the rendering.  Anytime test automation scales, is repeatable, quantified, and developers can validate the results without us is a good thing!&lt;br /&gt;
&lt;br /&gt;
How did this testing get organized? As with many things in testing at Google, it came down to people chatting and realizing their work can be helpful for other engineers.  This was bottom up, not top down. Tejas Shah was working on a general quality bot solution for compatibility (more on that in later posts) between Chrome and other browsers. He chatted with the Instant Pages developers when he was visiting their building and they agreed his bot might be able to help. He then spend the next couple of weeks pulling it all together and sharing the results with the team. &lt;br /&gt;
&lt;br /&gt;
And now more applications of the quality bot are surfacing. What if we kept the browser version fixed, and only varied the version of the application? Could this help validate web applications independent of a functional spec and without custom validation script development and maintenance?  Stay tuned...&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-5950025234592171231?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=t70fL4JrDK0:Ao_o2oGH5xc:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=t70fL4JrDK0:Ao_o2oGH5xc:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=t70fL4JrDK0:Ao_o2oGH5xc:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/t70fL4JrDK0" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/5950025234592171231/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=5950025234592171231" title="13 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/5950025234592171231?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/5950025234592171231?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/t70fL4JrDK0/how-we-tested-google-instant-pages.html" title="How We Tested Google Instant Pages" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>13</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/07/how-we-tested-google-instant-pages.html</feedburner:origLink></entry><entry gd:etag="W/&quot;AkMCRnc8cCp7ImA9WhdTEEs.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-7880166314041083040</id><published>2011-07-07T12:54:00.000-07:00</published><updated>2011-07-07T12:54:27.978-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-07-07T12:54:27.978-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="GTAC" /><title>GTAC: Call for Team Attendance</title><content type="html">Attending conferences can be a great way to network and learn new concepts. However, taking those concepts back to your office and trying to convince your team apply them can be daunting. In order to make GTAC attendees more successful at implementing what they learn at this conference we are going to give preference to teammates from the same company applying for attendance. Bring another developer or tester (or two or three) and attend as a team so you can discuss what you learn and experience, hopefully increasing your chances of putting it into practice when you return to work.&lt;br /&gt;
&lt;br /&gt;
We're extending the deadline for attendees until the end of July to give you a chance to round up some teammates.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-7880166314041083040?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=ub2OOOLnmiE:SYGq4MQJOsY:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=ub2OOOLnmiE:SYGq4MQJOsY:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=ub2OOOLnmiE:SYGq4MQJOsY:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/ub2OOOLnmiE" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/7880166314041083040/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=7880166314041083040" title="8 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/7880166314041083040?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/7880166314041083040?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/ub2OOOLnmiE/gtac-call-for-team-attendance.html" title="GTAC: Call for Team Attendance" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>8</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/07/gtac-call-for-team-attendance.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DEIDRnw8fyp7ImA9WhZaEkQ.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-6544260587721157512</id><published>2011-06-28T14:29:00.000-07:00</published><updated>2011-06-28T14:29:37.277-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-28T14:29:37.277-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><category scheme="http://www.blogger.com/atom/ns#" term="Conferences" /><title>Google at STAR West 2011</title><content type="html">By James Whittaker&lt;br /&gt;
&lt;br /&gt;
STAR West will feature something unprecedented this year: back-to-back tutorials by Googlers plus a keynote and track session.&lt;br /&gt;
&lt;br /&gt;
The tutorials will be Monday October 3. I have the morning session on "How Google Tests Software" and my colleague Ankit Mehta has the afternoon session on "Testing Rich Internet AJAX-based Applications." You can spend the whole day in Google Test Land.&lt;br /&gt;
&lt;br /&gt;
I highly recommend Ankit's tutorial. He is one of our top test managers and has spent years minding Gmail as it grew up from a simple cloud-based email system into the mass-scale, ubiquitous rich web app that it is today. Ankit now leads all testing efforts around our social offerings (which are already starting to appear). Anyone struggling to automate the testing of rich web apps will have plenty to absorb in his session. He's not spouting conjecture and generalities; he's speaking from the position of actual accomplishment. Bring a laptop. &lt;br /&gt;
&lt;br /&gt;
Jason Arbon and Sebastian Schiavone are presenting a track talk on "Google's New Methodology for Risk Driven Testing" and will be demonstrating some of the latest tools coming out of Google Test Labs. Tools that were born of real need built to serve that need. I am expecting free samples! Jason was test lead for Chrome and Chrome OS before taking over Google Test Labs where incredibly clever code is woven into useful test tools. Sebastian is none other than my TPM (technical program manager) who is well known for taking my vague ideas about how things should be done and making them real. &lt;br /&gt;
&lt;br /&gt;
Oh and the keynote, well that's me again, something about testing getting in the way of quality. I wrote this talk while I was in an especially melancholy mood about my place in the universe. It's a wake-up call to testers: the world is changing and your relevance is calling ... will you answer the call or ignore it and pretend that yesterday is still today?&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-6544260587721157512?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=ewL5tyzqaok:7YOXZ-s-uWc:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=ewL5tyzqaok:7YOXZ-s-uWc:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=ewL5tyzqaok:7YOXZ-s-uWc:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/ewL5tyzqaok" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/6544260587721157512/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=6544260587721157512" title="6 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/6544260587721157512?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/6544260587721157512?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/ewL5tyzqaok/google-at-star-west-2011.html" title="Google at STAR West 2011" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>6</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/06/google-at-star-west-2011.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUYGQX07cCp7ImA9WhZbGEs.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-9007507255851290164</id><published>2011-06-23T14:05:00.000-07:00</published><updated>2011-06-23T14:05:20.308-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-23T14:05:20.308-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><title>Lessons in a 21st Century Tech Career: Failing Fast, 20% Time and Project Mobility</title><content type="html">By James Whittaker&lt;br /&gt;
&lt;br /&gt;
If your name is Larry Page, stop reading this now. &lt;br /&gt;
&lt;br /&gt;
Let me first admit that as I write this I am sitting in a company lounge reminiscent of a gathering room in a luxury hotel with my belly full of free gourmet food waiting for a meeting with the lighthearted title "Beer and Demos" to start. &lt;br /&gt;
&lt;br /&gt;
Let me secondly admit that none of this matters. It's all very nice, and I hope it continues in perpetuity, but it doesn't matter. Engineers don't need to be spoiled rotten to be happy. The spoiling of engineers has little to do with the essence of a 21st century tech career. &lt;br /&gt;
&lt;br /&gt;
Now, what exactly does matter? What is the essence of a 21st century tech career that keeps employees loyal and engaged with productivity that would shame the most seasoned agile-ist? I don't yet have the complete story, but here are three important ingredients:&lt;br /&gt;
&lt;br /&gt;
&lt;b&gt;Failing Fast&lt;/b&gt;. Nothing destroys morale more than a death march. Projects going nowhere &lt;i&gt;should do so with the utmost haste&lt;/i&gt;. The ability of a company to implode pet projects quickly correlates directly to a great place to work. Engineers working on these project gain not only valuable engineering experience, they experience first-hand the company's perception of what is important (and, in the case of their project, what is not important). It's a built-in lesson on company priorities and it ensures good engineers don't get monopolized by purposeless projects. You gotta like a company willing to experiment. You have to love a company willing to laugh at itself when the experiments don't pan out.&lt;br /&gt;
&lt;br /&gt;
&lt;b&gt;20% Time&lt;/b&gt;. Any company worth working for has any number of projects that are worth working on. It's frustrating for many super-sharding engineers to see cool work going on down the hall or in the next building and not being part of it. A day job that takes all day is tiresome. Enter 20% time, a concept meant to send a strong message to all engineers: &lt;i&gt;you always have a spare day&lt;/i&gt;. Use it wisely.&lt;br /&gt;
&lt;br /&gt;
&lt;b&gt;Project Mobility&lt;/b&gt;. Staying fresh by changing projects is part of mobility. Continuous cycling of fresh ideas from new project members to existing projects is another part. The downside here is obviously projects with a steep learning curve but I scoff in the general direction of this idea. Whose fault is it when a wicked smart engineer can't learn the system fast enough to be useful in some (even a small) context? Only the weakest organization with the poorest documentation can use that excuse. The only good reason for keeping people on a project is because they have no desire to leave. &lt;br /&gt;
&lt;br /&gt;
These three concepts are better than all the lounges and free food any company can provide. Here's an example, a real example, of how it worked recently for an employee I'll call Paul (because that happens to be his name!). &lt;br /&gt;
&lt;br /&gt;
Paul joined Google a little over a year ago and spent two months on a project that was then cancelled. He learned enough to be useful anywhere but was new enough that he really didn't have great context on what project he wanted next. Solution: I assigned him to a project that was a good skill set match.&lt;br /&gt;
&lt;br /&gt;
Less than a year later, his new project ships. He played an important role in making this happen but in that time he also realized that the role was leaning toward feature development and he was more interested in a pure test development role. However, he was steeped in post-ship duties and working on the next release. A cycle that, happily, can be broken pretty easily here. &lt;br /&gt;
&lt;br /&gt;
Another project had a test developer opening that suited Paul perfectly. He immediately signed up for 20% on this new project and spent his 80% ramping down in his old project. At some point these percentages will trade places and he'll spend 20% of his time training his replacement on the old project. This is a friction-less process. His manager cannot deny him &lt;i&gt;his day&lt;/i&gt; to do as he pleases and now he can spend his time getting off the critical path of his old project and onto the critical path of his new project. &lt;br /&gt;
&lt;br /&gt;
Mobility means a constant stream of openings on projects inside Google. It also creates a population of engineering talent with an array of project experiences and a breadth of expertise to fill those positions. 20% time is a mechanism for moving onto and off of projects without formal permissions, interviews and other make-work processes engineers deplore. &lt;br /&gt;
&lt;br /&gt;
Let's face it, most benefits are transient. I enjoy a good meal for the time it is in front of me. I enjoy great medical when I am sick. I appreciate luxury when I have time for it. Even my paycheck comes with such monotonous regularity that it is an expectation that brings little joy apart from the brief moment my bank balance takes that joyful upward tick. But if I am unhappy the rest of the day, none of those islands of pampering mean squat. Empower me as an engineer during the much larger blocks of my time when I am doing engineering. Feed my creativity. Remove the barriers that prevent me from working on the things I want to work on. &lt;br /&gt;
&lt;br /&gt;
Do these things and you have me. Do these things and you make my entire work day better. This is the essence of a 21st century tech career: &lt;b&gt;make the hours I spend working better&lt;/b&gt;. Anything more is so dot com. &lt;br /&gt;
&lt;br /&gt;
Ok, Larry you can start reading again.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-9007507255851290164?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=rwpd1_1iR-Q:TZ6TtH2vbuI:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=rwpd1_1iR-Q:TZ6TtH2vbuI:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=rwpd1_1iR-Q:TZ6TtH2vbuI:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/rwpd1_1iR-Q" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/9007507255851290164/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=9007507255851290164" title="10 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/9007507255851290164?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/9007507255851290164?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/rwpd1_1iR-Q/lessons-in-21st-century-tech-career.html" title="Lessons in a 21st Century Tech Career: Failing Fast, 20% Time and Project Mobility" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>10</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/06/lessons-in-21st-century-tech-career.html</feedburner:origLink></entry><entry gd:etag="W/&quot;D0cNQH89eyp7ImA9WhZbFko.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-4073751004587571939</id><published>2011-06-21T09:21:00.000-07:00</published><updated>2011-06-21T09:51:31.163-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-21T09:51:31.163-07:00</app:edited><title>Introducing DOM Snitch, our passive in-the-browser reconnaissance tool</title><content type="html">By Radoslav Vasilev from Google Zurich&lt;br /&gt;&lt;br /&gt;Every day modern web applications are becoming increasingly sophisticated, and as their complexity grows so does their attack surface. Previously we introduced open source tools such as &lt;a href="https://code.google.com/p/skipfish/" target="_blank"&gt;Skipfish&lt;/a&gt; and &lt;a href="https://code.google.com/p/ratproxy/" target="_blank"&gt;Ratproxy&lt;/a&gt; to assist developers in understanding and securing these applications.&lt;br /&gt;&lt;br /&gt;As existing tools focus mostly on testing server-side code, today we are happy to introduce &lt;a href="https://code.google.com/p/domsnitch/" target="_blank"&gt;DOM Snitch&lt;/a&gt; — an experimental* Chrome extension that enables developers and testers to identify insecure practices commonly found in client-side code. To do this, we have adopted &lt;a href="https://code.google.com/p/domsnitch/wiki/DOMSnitchDoc#How_does_DOM_Snitch_work_under_the_hood?" target="_blank"&gt;several approaches&lt;/a&gt; to intercepting JavaScript calls to key and potentially dangerous browser infrastructure such as document.write or HTMLElement.innerHTML (among &lt;a href="https://code.google.com/p/domsnitch/wiki/DOMSnitchDoc#What_can_DOM_Snitch_intercept?" target="_blank"&gt;others&lt;/a&gt;). Once a JavaScript call has been intercepted, DOM Snitch records the document URL and a complete stack trace that will help assess if the intercepted call can lead to cross-site scripting, mixed content, insecure modifications to the &lt;a href="https://code.google.com/p/browsersec/wiki/Part2#Same-origin_policy_for_DOM_access" target="_blank"&gt;same-origin policy for DOM access&lt;/a&gt;, or other client-side issues.&lt;br /&gt;&lt;br /&gt;&lt;center&gt;&lt;img src="https://lh4.googleusercontent.com/xLmWOpBeNyIvZd7iD9B_EjWYjDZcC8prV8ApY2gQCXq6Jc0JwqBfFZbcVC_MTDEiUvYOvgMOEjo6KyjOWTjO53mmZILHXACZ88XtJ0Lsc10MbROQYzsUJWKdUnVovUpM" width="500px;" height="263px;" id="internal-source-marker_0.24736820021644235" /&gt;&lt;/center&gt;&lt;br /&gt;&lt;br /&gt;Here are the benefits of DOM Snitch:&lt;br /&gt;&lt;ul&gt;&lt;li&gt;&lt;b&gt;Real-time:&lt;/b&gt; Developers can observe DOM modifications as they happen inside the browser without the need to step through JavaScript code with a debugger or pause the execution of their application.&lt;/li&gt;&lt;br /&gt;&lt;li&gt;&lt;b&gt;Easy to use:&lt;/b&gt; With built-in &lt;a href="https://code.google.com/p/domsnitch/wiki/QuickIntro#Current_capabilities" target="_blank"&gt;security heuristics&lt;/a&gt; and nested views, both advanced and less experienced developers and testers can quickly spot areas of the application being tested that need more attention.&lt;/li&gt;&lt;br /&gt;&lt;li&gt;&lt;b&gt;Easier collaboration:&lt;/b&gt; Enables developers to easily export and share captured DOM modifications while troubleshooting an issue with their peers.&lt;/li&gt;&lt;/ul&gt;&lt;br /&gt;&lt;br /&gt;DOM Snitch is intended for use by developers, testers, and security researchers alike. &lt;a href="https://code.google.com/p/domsnitch/downloads/list" target="_blank"&gt;Click here&lt;/a&gt; to download DOM Snitch. To read the documentation, please visit &lt;a href="https://code.google.com/p/domsnitch/wiki/DOMSnitchDoc" target="_blank"&gt;this page&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;*Developers and testers should be aware that DOM Snitch is currently experimental. We do not guarantee that it will work flawlessly for all web applications. More details on known issues can be found &lt;a href="https://code.google.com/p/domsnitch/wiki/KnownIssues" target="_blank"&gt;here&lt;/a&gt; or in the project’s &lt;a href="https://code.google.com/p/domsnitch/issues/list" target="_blank"&gt;issues tracker&lt;/a&gt;.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-4073751004587571939?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=48B6mbUg7zw:ExZ7zqskSXc:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=48B6mbUg7zw:ExZ7zqskSXc:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=48B6mbUg7zw:ExZ7zqskSXc:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/48B6mbUg7zw" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/4073751004587571939/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=4073751004587571939" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/4073751004587571939?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/4073751004587571939?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/48B6mbUg7zw/introducing-dom-snitch-our-passive-in.html" title="Introducing DOM Snitch, our passive in-the-browser reconnaissance tool" /><author><name>Radoslav</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/06/introducing-dom-snitch-our-passive-in.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUQASHk8fCp7ImA9WhZbE04.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-9082453328530007351</id><published>2011-06-17T10:06:00.001-07:00</published><updated>2011-06-17T10:55:49.774-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-17T10:55:49.774-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="testivus" /><category scheme="http://www.blogger.com/atom/ns#" term="Alberto has gone off the deep end" /><category scheme="http://www.blogger.com/atom/ns#" term="test is dead" /><category scheme="http://www.blogger.com/atom/ns#" term="Morena Baccarin" /><title>Test Is Dead</title><content type="html">&lt;a onblur="try {parent.deselectBloggerImageGracefully();} catch(e) {}" href="http://4.bp.blogspot.com/-tVFd6_j3GM8/TfuJwyqf2GI/AAAAAAAAA_E/dZFqxO9HVK8/s1600/AlbertoFloating.jpg"&gt;&lt;img style="display:block; margin:0px auto 10px; text-align:center;cursor:pointer; cursor:hand;width: 238px; height: 320px;" src="http://4.bp.blogspot.com/-tVFd6_j3GM8/TfuJwyqf2GI/AAAAAAAAA_E/dZFqxO9HVK8/s320/AlbertoFloating.jpg" border="0" alt=""id="BLOGGER_PHOTO_ID_5619236431401572450" /&gt;&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;span style="font-style:italic;"&gt;My earthly body casts no shadows&lt;br /&gt;'Tis my thoughts and words that bring umbrage &lt;br /&gt;  that is shade to some &lt;br /&gt;  and darkness to others &lt;br /&gt;&lt;br /&gt;Testivus was but a bit of child play&lt;br /&gt;  to appetize&lt;br /&gt;&lt;br /&gt;At GTAC 2011 &lt;br /&gt;  the greater truth &lt;br /&gt;  shall be revealed&lt;br /&gt;&lt;br /&gt;Test is dead&lt;br /&gt;&lt;br /&gt;And I the executioner&lt;/span&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Alberto Savoia&lt;br /&gt;VI.XVII.MMXI&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;a href="http://www.agitar.com/downloads/TheWayOfTestivus.pdf"&gt;The Way of Testivus&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;"Floating Alberto" photograph courtesy of Patrick Copeland&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-9082453328530007351?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=vw9DcqnJ834:B8giroShP_g:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=vw9DcqnJ834:B8giroShP_g:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=vw9DcqnJ834:B8giroShP_g:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/vw9DcqnJ834" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/9082453328530007351/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=9082453328530007351" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/9082453328530007351?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/9082453328530007351?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/vw9DcqnJ834/test-is-dead.html" title="Test Is Dead" /><author><name>Alberto Savoia</name><uri>http://www.blogger.com/profile/14622398185391305870</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="http://4.bp.blogspot.com/-tVFd6_j3GM8/TfuJwyqf2GI/AAAAAAAAA_E/dZFqxO9HVK8/s72-c/AlbertoFloating.jpg" height="72" width="72" /><thr:total>2</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/06/test-is-dead.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CkINRno_fyp7ImA9WhZbEkg.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-799441657065972719</id><published>2011-06-16T11:56:00.000-07:00</published><updated>2011-06-16T11:56:37.447-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-16T11:56:37.447-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><category scheme="http://www.blogger.com/atom/ns#" term="GTAC" /><title>GTAC 2011 Keynotes</title><content type="html">By James Whittaker&lt;br /&gt;
&lt;br /&gt;
I am pleased to confirm 3 of our keynote speakers for GTAC 2011 at the Computer History Museum in Mountain View CA.&lt;br /&gt;
&lt;br /&gt;
Google's own &lt;b&gt;Alberto Savoia&lt;/b&gt;, aka Testivus.&lt;br /&gt;
&lt;br /&gt;
&lt;b&gt;Steve McConnell&lt;/b&gt; the best selling author of &lt;i&gt;Code Complete&lt;/i&gt; and CEO of Construx Software.&lt;br /&gt;
&lt;br /&gt;
Award winning speaker ("the Jon Stewart of Software Security") &lt;b&gt;Hugh Thompson&lt;/b&gt;.&lt;br /&gt;
&lt;br /&gt;
This is the start of an incredible lineup. Stay tuned for updates concerning their talks and continue to nominate additional speakers and keynotes. We're not done yet and we're taking nominations through mid July.&lt;br /&gt;
&lt;br /&gt;
In addition to the keynotes, we're going to be giving updates on How Google Tests Software from teams across the company including Android, Chrome, Gmail, You Tube and many more.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-799441657065972719?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=8_FMzDjaK7Y:BguEal-mnBw:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=8_FMzDjaK7Y:BguEal-mnBw:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=8_FMzDjaK7Y:BguEal-mnBw:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/8_FMzDjaK7Y" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/799441657065972719/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=799441657065972719" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/799441657065972719?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/799441657065972719?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/8_FMzDjaK7Y/gtac-2011-keynotes.html" title="GTAC 2011 Keynotes" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>2</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/06/gtac-2011-keynotes.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DEcCQno8cCp7ImA9WhZbEEo.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-7130616933669825923</id><published>2011-06-14T11:25:00.000-07:00</published><updated>2011-06-14T11:27:43.478-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-06-14T11:27:43.478-07:00</app:edited><title>Testing at the speed and scale of Google</title><content type="html">&lt;div dir="ltr" style="text-align: left;" trbidi="on"&gt;&lt;span class="Apple-style-span" style="font-family: Arial; font-size: 15px; white-space: pre-wrap;"&gt;(Cross-posted from the &lt;a href="http://google-engtools.blogspot.com/2011/06/testing-at-speed-and-scale-of-google.html"&gt;Google Engineering Tools blog&lt;/a&gt;)&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: Arial;"&gt;&lt;span class="Apple-style-span" style="font-size: 15px; white-space: pre-wrap;"&gt; &lt;/span&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: Arial; font-size: 15px; white-space: pre-wrap;"&gt;By Pooja Gupta, Mark Ivey and John Penix&lt;/span&gt;&lt;br /&gt;
&lt;div style="background-color: transparent; clear: left; float: left; margin-bottom: 1em; margin-right: 1em; margin-top: 0px;"&gt;&lt;span class="Apple-style-span" style="font-family: Arial; font-size: 15px; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: Arial; font-size: 15px; white-space: pre-wrap;"&gt;Continuous integration systems play a crucial role in keeping software working while it is being developed. The basic steps most continuous integration systems follow are:&lt;/span&gt;&lt;/div&gt;&lt;br /&gt;
&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;div style="margin-bottom: 0pt; margin-top: 0pt; text-indent: 36pt;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;1. Get the latest copy of the code.&lt;/span&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0pt; margin-top: 0pt; text-indent: 36pt;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;2. Run all tests.&lt;/span&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0pt; margin-top: 0pt; text-indent: 36pt;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;3. Report results.&lt;/span&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0pt; margin-top: 0pt; text-indent: 36pt;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;4. Repeat 1-3.&lt;/span&gt;&lt;/div&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;This works great while the codebase is small, code flux is reasonable and tests are fast. As a codebase grows over time, the effectiveness of such a system decreases. As more code is added, each clean run takes much longer and more changes gets crammed into a single run. If something breaks, finding and backing out the bad change is a tedious and error prone task for development teams.&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Software development at &lt;/span&gt;&lt;a href="http://google-engtools.blogspot.com/2011/05/welcome-to-google-engineering-tools.html"&gt;&lt;span style="background-color: transparent; color: #000099; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;"&gt;Google is big and fast&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;. The code base receives &lt;/span&gt;&lt;a href="http://www.infoq.com/presentations/Development-at-Google"&gt;&lt;span style="background-color: transparent; color: #000099; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;"&gt;20+ code changes per minute and 50% of the files change every month&lt;/span&gt;&lt;/a&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;! Each product is developed and released from ‘head’ relying on automated tests verifying the product behavior. Release frequency varies from multiple times per day to once every few weeks, depending on the product team. &lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;With such a huge, fast-moving codebase, it is possible for teams to get stuck spending a lot of time just keeping their build ‘green’. A continuous integration system should help by providing the &lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: italic; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;exact &lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;change at which a test started failing, instead of a range of suspect changes or doing a lengthy binary-search for the offending change. To find the exact change that broke a test, we could run every test at every change, but that would be very expensive.&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;To solve this problem, we built a continuous integration system that uses dependency analysis to determine all the tests a change transitively affects and then runs only those tests for every change. The system is built on top of Google’s cloud computing infrastructure enabling many builds to be executed concurrently, allowing the system to run affected tests as soon as a change is submitted.&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Here is an example where our system can provide faster and more precise feedback than a traditional continuous build. In this scenario, there are two tests and three changes that affect these tests. The gmail_server_tests are broken by the second change, however a typical continuous integration system will only be able to tell that either change #2 or change #3 caused this test to fail. By using concurrent builds, we can launch tests without waiting for the current build/test cycle to finish. Dependency analysis limits the number of tests executed for each change, so that in this example, the total number of test executions is the same as before.&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="http://2.bp.blogspot.com/-GjJBCofxF3I/Te5d0IlAEoI/AAAAAAAAAUM/GebfyV9aazg/s1600/image06.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="400" src="http://2.bp.blogspot.com/-GjJBCofxF3I/Te5d0IlAEoI/AAAAAAAAAUM/GebfyV9aazg/s400/image06.png" width="396" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span class="Apple-style-span" style="font-family: Arial;"&gt;&lt;span class="Apple-style-span" style="font-size: 15px; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Let’s look deeper into how we perform the dependency analysis. &lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;We maintain an in-memory graph of coarse-grained dependencies between various tests and build rules across the entire codebase. This graph, several GBs in-memory, is kept up-to-date with each change that gets checked in. This allows us to transitively determine all tests that depend on the code modified in a given change and hence need to be re-run to know the current state of the build. Let’s walk through an example.&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Consider two sample projects, each containing a different set of tests:&amp;nbsp;&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="http://4.bp.blogspot.com/-aSZlZXVSfac/Te5dySTdrGI/AAAAAAAAAUA/5s8faMPVr0g/s1600/image03.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="58" src="http://4.bp.blogspot.com/-aSZlZXVSfac/Te5dySTdrGI/AAAAAAAAAUA/5s8faMPVr0g/s400/image03.png" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;where the build dependency graph looks like this:&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="http://2.bp.blogspot.com/-cs6tWNIqyUU/Te5dyJlVE3I/AAAAAAAAAT8/L-aWQkRq_Bw/s1600/image02.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="136" src="http://2.bp.blogspot.com/-cs6tWNIqyUU/Te5dyJlVE3I/AAAAAAAAAT8/L-aWQkRq_Bw/s400/image02.png" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;We will see how two isolated code changes, at different depths of the dependency tree, are analyzed to determine affected tests, that is the minimal set of tests that needs to be run to ensure that both Gmail and Buzz projects are “green”.&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Case1: Change in common library&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;span class="Apple-style-span" style="font-family: 'Times New Roman'; font-size: small; font-weight: normal; white-space: normal;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;For first scenario, consider a change that modifies files in &lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: 'Courier New'; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;common_collections_util&lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;.&lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;span class="Apple-style-span" style="font-family: 'Times New Roman'; font-size: small; font-weight: normal; white-space: normal;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="https://lh6.googleusercontent.com/8uSH947j9AhbQrT0Fwh4j5TPbtUnBpKjSUk9BW7Ecp7Hp-f5pBXXPojM0HknZ_vHIg_8vRxjToV8_YsKUjvsCb7D5BjN-wbOx0VzrrIUr3MD0goYVaI" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="167" src="https://lh6.googleusercontent.com/8uSH947j9AhbQrT0Fwh4j5TPbtUnBpKjSUk9BW7Ecp7Hp-f5pBXXPojM0HknZ_vHIg_8vRxjToV8_YsKUjvsCb7D5BjN-wbOx0VzrrIUr3MD0goYVaI" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span class="Apple-style-span" style="font-family: Arial;"&gt;&lt;b&gt;&lt;br /&gt;
&lt;/b&gt;&lt;span class="Apple-style-span" style="font-size: 15px; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br class="kix-line-break" /&gt;&lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;As soon as this change is submitted, we start a breadth-first search to find all tests that depend on it.&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="http://4.bp.blogspot.com/-Dz87R9ZduFA/Te53QrdTl7I/AAAAAAAAAU4/k4pNAuHXplc/s1600/image05.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="162" src="http://4.bp.blogspot.com/-Dz87R9ZduFA/Te53QrdTl7I/AAAAAAAAAU4/k4pNAuHXplc/s400/image05.png" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;div style="background-color: transparent; font-family: 'Times New Roman'; font-size: medium; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; white-space: normal;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;span id="internal-source-marker_0.11855968087911606" style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Once all the direct dependencies are found, continue BFS to collect all transitive dependencies till we reach all the leaf nodes.&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="http://4.bp.blogspot.com/-cvfCFYyjfeo/Te53TXbxQJI/AAAAAAAAAVU/1JJQCJZYdME/s1600/image12.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="166" src="http://4.bp.blogspot.com/-cvfCFYyjfeo/Te53TXbxQJI/AAAAAAAAAVU/1JJQCJZYdME/s400/image12.png" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;div style="background-color: transparent; font-family: 'Times New Roman'; font-size: medium; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; white-space: normal;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;span id="internal-source-marker_0.11855968087911606" style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;When done, we have all the tests that need to be run, and can calculate the projects that will need to update their overall status based on results from these tests.&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="http://3.bp.blogspot.com/-GCPftvqhMPM/Te53RSqd6PI/AAAAAAAAAVA/YJKp7exzskQ/s1600/image07.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="183" src="http://3.bp.blogspot.com/-GCPftvqhMPM/Te53RSqd6PI/AAAAAAAAAVA/YJKp7exzskQ/s400/image07.png" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span id="internal-source-marker_0.11855968087911606" style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: bold; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Case2: Change in a dependent project:&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;When a change modifying files in &lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: 'Courier New'; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;youtube_client&lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; is submitted.&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;a href="http://1.bp.blogspot.com/-qBefF5zIZPQ/Te53QaFQ7cI/AAAAAAAAAU0/MeQp88kWGCs/s1600/image04.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="165" src="http://1.bp.blogspot.com/-qBefF5zIZPQ/Te53QaFQ7cI/AAAAAAAAAU0/MeQp88kWGCs/s400/image04.png" width="400" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;div style="background-color: transparent; font-family: 'Times New Roman'; font-size: medium; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; white-space: normal;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;span id="internal-source-marker_0.11855968087911606" style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;We perform the same analysis to conclude that only &lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: 'Courier New'; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;buzz_client_tests&lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; is affected and status of Buzz project needs to be updated:&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; font-family: 'Times New Roman'; font-size: medium; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; white-space: normal;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="separator" style="clear: both; text-align: center;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;a href="http://2.bp.blogspot.com/-RC-r1bQR3oA/Te53Si8EcNI/AAAAAAAAAVM/nN8c3hUOk6E/s1600/image10.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"&gt;&lt;img border="0" height="182" src="http://2.bp.blogspot.com/-RC-r1bQR3oA/Te53Si8EcNI/AAAAAAAAAVM/nN8c3hUOk6E/s400/image10.png" width="400" /&gt;&lt;/a&gt;&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; font-family: 'Times New Roman'; font-size: medium; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; white-space: normal;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; font-family: 'Times New Roman'; font-size: medium; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; white-space: normal;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;/div&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;The example above illustrates how we optimize the number of tests run per change without sacrificing the accuracy of end results for a project. A lesser number of tests run per change allows us to run all &lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: italic; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;affected&lt;/span&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt; tests for every change that gets checked in, making it easier for a developer to detect and deal with an offending change.&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;Use of smart tools and cloud computing infrastructure in the continuous integration system makes it fast and reliable. While we are constantly working on making improvements to this system, thousands of Google projects are already using it to launch-and-iterate quickly and hence making faster user-visible progress.&lt;/span&gt;&lt;/div&gt;&lt;div style="background-color: transparent; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span style="background-color: transparent; color: black; font-family: Arial; font-size: 11pt; font-style: normal; font-weight: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;"&gt;&lt;br /&gt;
&lt;/span&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/15045980-7130616933669825923?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=zHAaafARWwk:Tqfn5khhHLg:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=zHAaafARWwk:Tqfn5khhHLg:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=zHAaafARWwk:Tqfn5khhHLg:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/zHAaafARWwk" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/7130616933669825923/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=7130616933669825923" title="12 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/7130616933669825923?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/7130616933669825923?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/zHAaafARWwk/testing-at-speed-and-scale-of-google.html" title="Testing at the speed and scale of Google" /><author><name>jthomas</name><uri>http://www.blogger.com/profile/07741955124510745020</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><media:thumbnail xmlns:media="http://search.yahoo.com/mrss/" url="http://2.bp.blogspot.com/-GjJBCofxF3I/Te5d0IlAEoI/AAAAAAAAAUM/GebfyV9aazg/s72-c/image06.png" height="72" width="72" /><thr:total>12</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/06/testing-at-speed-and-scale-of-google.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUQMQHg8eSp7ImA9WhZVFEk.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-8835282394141014874</id><published>2011-05-26T13:48:00.000-07:00</published><updated>2011-05-26T13:56:21.671-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-05-26T13:56:21.671-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><title>How Google Tests Software - Part Seven</title><content type="html">By James Whittaker&lt;br /&gt;&lt;br /&gt;&lt;span style="font-weight:bold;"&gt;The Life of a TE&lt;/span&gt;&lt;br /&gt;&lt;br /&gt;The Test Engineer is a newer role within Google than either SWEs or SETs. As such, it is a role still in the process of being defined. The current generation of Google TEs are blazing a trail which will guide the next generation of new hires for this role. It is the process that is emerging as the best within Google that we present here.&lt;br /&gt;&lt;br /&gt;Not all products require the services of a TE. Experimental efforts and early stage products without a well-defined mission or user story are certainly projects that won’t get a lot of TE attention. If the product stands a good chance of being cancelled (in the sense that as a proof of concept it fails to pass muster) or has yet to engage users or have a well defined set of features, testing it is largely something that should be done by the people developing it.&lt;br /&gt;&lt;br /&gt;Even if it is clear that a product is going to get shipped, Test Engineers have little to do early in the development cycle when features are still in flux and the final feature list and scope is undetermined. Overinvesting in testing too early can mean a lot of things get thrown away. Likewise, early testing planning requires fewer test engineers than later cycle exploratory testing when the product is close to final form and the hunt for missed bugs has a greater urgency.&lt;br /&gt;&lt;br /&gt;The trick in staffing a project with Test Engineers has to do with risk and return on investment. Risk to the customer and to the enterprise means more testing effort and requires more TEs. But that effort needs to be in proportion to the potential return. We need the right number of TEs and we need them to engage at the right time and with the right impact.&lt;br /&gt;&lt;br /&gt;Once engaged, TEs do not have to start from scratch. There is a great deal of test engineering and quality-oriented work performed by SWEs and SETs which is the starting point for additional TE work. The initial engagement of the TE is to decide things such as:&lt;br /&gt;&lt;br /&gt;·       Where are the weak points in the software?&lt;br /&gt;&lt;br /&gt;·       What are the security, privacy, performance and reliability concerns?&lt;br /&gt;&lt;br /&gt;·       Do all the primary user scenarios work as expected? For all international audiences?&lt;br /&gt;&lt;br /&gt;·       Does the product interoperate with other products (hardware and software)?&lt;br /&gt;&lt;br /&gt;·       In the event of a problem, how good are the diagnostics?&lt;br /&gt;&lt;br /&gt;All of this combines to speak to the risk profile of releasing the software in question. TEs don’t necessarily do all of this work, but they ensure that it gets done and they leverage the work of others is assessing where additional work is required. Ultimately, test engineers are paid to protect users and the business from bad design, confusing UX, functional bugs, security and privacy issues and so forth. At Google, TEs are the only people on a team whose full-time job is to look at the product or service holistically for weak points. As such, the life of a Test Engineer is much less prescriptive and formalized than that of an SET. TE’s are asked to help on projects in all stages of readiness: everything from the idea stage to version 8, or even watching over a deprecated or “mothballed” project. Often, a single TE will even span multiple projects particularly those with specialty type skills like security.&lt;br /&gt;&lt;br /&gt;Obviously, the work of a TE varies greatly depending on the project. Some TE’s spend much of their time programming, much like an SET, but with more of a focus on end-to-end user scenarios. Other TE's take existing code and designs determine failure modes and look for errors that will cause those failures. In such a role a TE might modify code but not create it from scratch. TE's must be more systematic and thorough in their test planning and completeness with a focus on the actual usage and system experience. TE's excel at dealing with ambiguity in requirements and at reasoning and communicating about fuzzy problems.&lt;br /&gt;&lt;br /&gt;Successful TEs accomplish all this while navigating the sensitivities and sometimes strong personalities of the development and product team members. When weak points are found, test engineers happily break the software, and drive to get these issues resolved with the SWEs, PMs, and SETs.&lt;br /&gt;&lt;br /&gt;Such a job description is a frightening prospect given the mix of technical skill, leadership, and deep product understanding and without proper guidance it is a role in which many would expect to fail. But at Google a strong community of test engineers has emerged to counter this. Of all job functions, the TE role is perhaps the best peer supported role in the company and the insight and leadership required to perform it successfully means that many of the top test managers in the company come from the TE ranks.&lt;br /&gt;&lt;br /&gt;There is a fluidity to the work of a Google Test Engineer that belies any prescriptive process for engagement. TE’s can enter a project at any point and must assess the state of the project, code, design, and users quickly and decide what to focus on first. If the project is just getting started, test planning is often the first order of business. Sometimes TEs are pulled in late in the cycle to evaluate whether a project is ready for ship or if there are any major issues before an early ‘beta’ goes out. If they are brought into a newly acquired application or one in which they have little prior experience, they will often start doing some exploratory testing with little to no planning. Sometimes projects haven’t been released for quite a while and just need some touchups/security fixes, or UX updates—calling for an even different approach. One size rarely fits all for TEs at Google.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-8835282394141014874?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=ak2vJUIo6bA:Qco9k8RpSSU:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=ak2vJUIo6bA:Qco9k8RpSSU:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=ak2vJUIo6bA:Qco9k8RpSSU:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/ak2vJUIo6bA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/8835282394141014874/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=8835282394141014874" title="16 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/8835282394141014874?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/8835282394141014874?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/ak2vJUIo6bA/how-google-tests-software-part-seven.html" title="How Google Tests Software - Part Seven" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>16</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/05/how-google-tests-software-part-seven.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUAGR3g8eyp7ImA9WhZVEUU.&quot;"><id>tag:blogger.com,1999:blog-15045980.post-3376970712867282598</id><published>2011-05-20T14:58:00.000-07:00</published><updated>2011-05-23T13:48:46.673-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-05-23T13:48:46.673-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="Whittaker" /><category scheme="http://www.blogger.com/atom/ns#" term="GTAC" /><title>GTAC 2011 Open for Submission</title><content type="html">By James Whittaker&lt;br /&gt;&lt;br /&gt;I am happy to announce that &lt;a href="http://www.gtac.biz"&gt;GTAC 2011&lt;/a&gt; is now &lt;a href="https://spreadsheets0.google.com/a/google.com/spreadsheet/viewform?formkey=dGYzU3V6d25LamhNeU5NYjdxMTVfOUE6MA"&gt;open for nominations&lt;/a&gt;. We're going to try and have an executive session, depending on interest, the afternoon/evening of October 25th at the Googleplex in Mountain View. This session is intended for top testing decision makers at top web, technology and software companies worldwide. It will be a chance for frank and open discussion about ours and the industry's collective challenges. It's intended to be a meeting of key decision makers and budget owners to share information, ideas and with a little luck spur some collaborations that will be good for the testing industry overall. Nominate your executive &lt;a href="https://spreadsheets.google.com/a/google.com/spreadsheet/viewform?formkey=dFp0Q3hnR1BweUpkTkJqbGltN25TMFE6MQ"&gt;here&lt;/a&gt;. &lt;br /&gt;&lt;br /&gt;The general session is by invitation only and prospective attendees and speakers must register and be selected. Speaker nominees are encouraged to point us to videos of prior presentations and any other material to help make our decision easier. &lt;br /&gt;&lt;br /&gt;Please leave comments if there is some technology, tool or product you want to hear about so we end up with the best possible agenda. &lt;br /&gt;&lt;br /&gt;I hope to see a lot of our readers in Mountain View in October!&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/15045980-3376970712867282598?l=googletesting.blogspot.com' alt='' /&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=VJW3q_o1dZM:clFFotOntfQ:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt; &lt;a href="http://feeds.feedburner.com/~ff/blogspot/RLXA?a=VJW3q_o1dZM:clFFotOntfQ:V_sGLiPBpWU"&gt;&lt;img src="http://feeds.feedburner.com/~ff/blogspot/RLXA?i=VJW3q_o1dZM:clFFotOntfQ:V_sGLiPBpWU" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/blogspot/RLXA/~4/VJW3q_o1dZM" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://googletesting.blogspot.com/feeds/3376970712867282598/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=15045980&amp;postID=3376970712867282598" title="3 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/3376970712867282598?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/15045980/posts/default/3376970712867282598?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/blogspot/RLXA/~3/VJW3q_o1dZM/gtac-2011-open-for-submission.html" title="GTAC 2011 Open for Submission" /><author><name>James Whittaker</name><uri>http://www.blogger.com/profile/16554467015823464445</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="32" height="24" src="http://4.bp.blogspot.com/_9ywu5aylLpo/Si2Q6zzZexI/AAAAAAAAAAM/AEIWjunK8uE/S220/PA030048.JPG" /></author><thr:total>3</thr:total><feedburner:origLink>http://googletesting.blogspot.com/2011/05/gtac-2011-open-for-submission.html</feedburner:origLink></entry></feed>

