<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>HCoder.org &#187; unit</title>
	<atom:link href="http://hcoder.org/tag/unit/feed/" rel="self" type="application/rss+xml" />
	<link>http://hcoder.org</link>
	<description>Just another WordPress weblog</description>
	<lastBuildDate>Sun, 15 Apr 2012 21:43:44 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.2</generator>
		<item>
		<title>Unit testing advice for seasoned hackers (2/2)</title>
		<link>http://hcoder.org/2012/02/15/unit-testing-advice-for-seasoned-hackers-22/</link>
		<comments>http://hcoder.org/2012/02/15/unit-testing-advice-for-seasoned-hackers-22/#comments</comments>
		<pubDate>Wed, 15 Feb 2012 22:24:42 +0000</pubDate>
		<dc:creator>emanchado</dc:creator>
				<category><![CDATA[Computers]]></category>
		<category><![CDATA[Work]]></category>
		<category><![CDATA[automated tests]]></category>
		<category><![CDATA[free software]]></category>
		<category><![CDATA[open source]]></category>
		<category><![CDATA[projects]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[testing]]></category>
		<category><![CDATA[tests]]></category>
		<category><![CDATA[tips]]></category>
		<category><![CDATA[tor]]></category>
		<category><![CDATA[unit]]></category>

		<guid isPermaLink="false">http://hcoder.org/?p=1322</guid>
		<description><![CDATA[This is the second part of my unit testing advice. See the first part on this blog. If you need any introduction you should really read the first part. I&#8217;ll just present the other three ideas I wanted to cover. Focusing on common cases This consists of testing only/mostly common cases. These tests rarely fail [...]]]></description>
			<content:encoded><![CDATA[<p><em>This is the second part of my unit testing advice. See the <a href="http://hcoder.org/2012/02/13/unit-testing-advice-for-seasoned-hackers-12/">first part</a> on this blog.</em></p>
<p>If you need any introduction you should really read the first part. I&#8217;ll just present the other three ideas I wanted to cover.</p>
<h2>Focusing on common cases</h2>
<p>This consists of testing only/mostly common cases. These tests rarely fail and give a false sense of security. Thus, tests are better when they also include less common cases, as they&#8217;re much more likely to break inadvertently. Common cases not only break far less often, but will probably be caught reasonably fast once someone tries to use the buggy code, so testing them has comparatively <em>less value</em> than testing less common cases.</p>
<p>The best example I found was in the <a href="https://github.com/emanchado/tor/commit/46bbf6c015fac412b47ca56279002129a1c2b278#L0L720"><code class="syntax c">wrap_string</code> tests</a>. The relevant example was adding the string &#8220;A test of string wrapping&#8230;&#8221;, which wraps not to two lines, but three (the wrapping is done only on spaces, so &#8220;wrapping&#8230;&#8221; is taken as a single unit; in this sense, my test case could have been clearer and use a very long word, instead of a word followed by ellipsis). Most of the cases we&#8217;ll deal with will simply wrap a given word in two lines, but wrapping in three must work, too, and it&#8217;s much more likely to break if we decide to refactor or rewrite the code in that function, with the intention to keep the functionality intact.</p>
<p>See other examples of this in <a href="https://github.com/emanchado/tor/commit/aa20bce8006c9dccd8213db789855b59aee33ef4#L0L2084">aa20bce</a> (no tests with more than one consecutive newline, no tests with lines of only non-printable characters), <a href="https://github.com/emanchado/tor/commit/b248b3f#L0L1665">b248b3f</a> (no tests with just dots, no valid cases with more than one consecutive slash, no invalid cases with content other than slashes), <a href="https://github.com/emanchado/tor/commit/5e771ab4f3b3f91f1aaff8db0284d4a1700954a7#L0L1606">5e771ab</a> (no directories or hidden files), <a href="https://github.com/emanchado/tor/commit/f8ecac5#L0L303">f8ecac5</a> (invalid hex characters don&#8217;t fail, but produce strange behaviour instead; this test actually discovered a bug), <a href="https://github.com/emanchado/tor/commit/7856643#L0R321">7856643</a> (broken escaped content) and <a href="https://github.com/emanchado/tor/commit/87e9f89#L0R256">87e9f89</a> (trailing garbage).</p>
<h2>Not trying to make the tests fail</h2>
<p>This is related to the previous one, but the emphasis is on trying to choose tests that we think will fail (either now or in the future). My impression is that people often fail to do this because they are trying to prove that the code <em>works</em>, which misses the point of testing. The point is trying to prove the code <em>doesn&#8217;t</em> work. And <em>hope</em> that you fail at it, if you will.</p>
<p>The only example I could find was in the <a href="https://github.com/emanchado/tor/commit/03876f0a721ced6ffebb0c61134d5b8396d7600e#L0L616"><code class="syntax c">strcasecmpend</code> tests</a>. Note how there&#8217;s a test that checks that the last three characters of string &#8220;abcDEf&#8221; (ie. &#8220;DEf&#8221;) is less than &#8220;deg&#8221; when compared case-insensitively. That&#8217;s almost pointless, because if we made that same comparison case-sensitively (in other words, if the &#8220;case&#8221; part of the function breaks) the test still passes! Thus it&#8217;s much better to compare the strings &#8221;abcdef&#8221; and &#8220;Deg&#8221;.</p>
<h2>Addendum: trying to cover all cases in the tests</h2>
<p>There&#8217;s another problem I wanted to mention. I have seen several times before, although not in the Tor tests. The problem is making complicated tests that try to cover many/all cases. This seems to stem from the idea that having more test cases is good <em>by itself</em>, when actually more tests are only useful when they <em>increase the chances</em> to catch bugs. For example, if you write tests for a &#8220;sum&#8221; function and you&#8217;re <em>already</em> testing <code class="syntax python">[5, 6, 3, 7]</code>, it&#8217;s probably pointless to add a test for <code class="syntax python">[1, 4, 6, 5]</code>. A test that would increase the chances of catching bugs would probably look more like <code class="syntax python">[-4, 0, 4, 5.6]</code> or <code class="syntax python">[]</code>.</p>
<p>So what&#8217;s wrong with having more tests than necessary? The problem is they make the test suite slower, harder to understand at a glance and harder to review. If they don&#8217;t contribute anything to the chance of catching bugs anyway, why pay that price? But the biggest problem is when we try to cover so many test cases than the code <em>produces</em> the test data. In this cases, we have all the above problems, <em>plus</em> that the test suite becomes almost as complex as production code. Such tests become much easier to introduce bugs in, harder to follow the flow of, etc. The tests are our safety net, so we should be fairly sure that they work as expected.</p>
<p>And that&#8217;s the end of the tips. I hope they were useful :-)</p>
 <p><a href="http://hcoder.org/?flattrss_redirect&amp;id=1322&amp;md5=9727c1870ad1435396033a337cef555b" title="Flattr" target="_blank"><img src="http://hcoder.org/wp-content/plugins/flattr/img/flattr-badge-large.png" alt="flattr this!"/></a></p>]]></content:encoded>
			<wfw:commentRss>http://hcoder.org/2012/02/15/unit-testing-advice-for-seasoned-hackers-22/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		<atom:link rel="payment" href="https://flattr.com/submit/auto?user_id=30124&amp;popout=1&amp;url=http%3A%2F%2Fhcoder.org%2F2012%2F02%2F15%2Funit-testing-advice-for-seasoned-hackers-22%2F&amp;language=en_GB&amp;category=text&amp;title=Unit+testing+advice+for+seasoned+hackers+%282%2F2%29&amp;description=This+is+the+second+part+of+my+unit+testing+advice.+See+the+first+part+on+this+blog.+If+you+need+any+introduction+you+should+really+read+the+first+part.+I%26%238217%3Bll...&amp;tags=automated+tests%2Cfree+software%2Copen+source%2Cprojects%2Csoftware%2Ctesting%2Ctests%2Ctips%2Ctor%2Cunit%2Cblog" type="text/html" />
	</item>
		<item>
		<title>Unit testing advice for seasoned hackers (1/2)</title>
		<link>http://hcoder.org/2012/02/13/unit-testing-advice-for-seasoned-hackers-12/</link>
		<comments>http://hcoder.org/2012/02/13/unit-testing-advice-for-seasoned-hackers-12/#comments</comments>
		<pubDate>Mon, 13 Feb 2012 23:48:23 +0000</pubDate>
		<dc:creator>emanchado</dc:creator>
				<category><![CDATA[Computers]]></category>
		<category><![CDATA[Work]]></category>
		<category><![CDATA[automated tests]]></category>
		<category><![CDATA[free software]]></category>
		<category><![CDATA[open source]]></category>
		<category><![CDATA[projects]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[testing]]></category>
		<category><![CDATA[tests]]></category>
		<category><![CDATA[tips]]></category>
		<category><![CDATA[tor]]></category>
		<category><![CDATA[unit]]></category>

		<guid isPermaLink="false">http://hcoder.org/?p=1301</guid>
		<description><![CDATA[When reviewing tests written by other people I see patterns in the improvements I would make. As I realise that these &#8220;mistakes&#8221; are also made by experienced hackers, I thought it would be useful to write about them. The extra push to write about this now was having concrete examples from my recent involvement in Tor, [...]]]></description>
			<content:encoded><![CDATA[<p>When reviewing tests written by other people I see patterns in the improvements I would make. As I realise that these &#8220;mistakes&#8221; are also made by experienced hackers, I thought it would be useful to write about them. The extra push to write about this <em>now</em> was having concrete examples from my recent involvement in <a href="http://torproject.org/">Tor</a>, that will hopefully illustrate these ideas.</p>
<p>These ideas are presented in no particular order. Each of them has a brief explanation, a concrete example from the Tor tests, and, if applicable, pointers to other commits that illustrate the same idea. Before you read on, let me explicitly acknowledge that (1) I know that many people know these principles, but writing about them is a nice reminder; and (2) I&#8217;m fully aware that sometimes <em>I</em> need that reminder, too.</p>
<p><strong>Edit:</strong>  see the <a href="http://hcoder.org/2012/02/15/unit-testing-advice-for-seasoned-hackers-22/">second part</a> of this blog.</p>
<h2>Tests as spec</h2>
<p>Tests are more useful if they can show how the code is supposed to behave, including safeguarding against future misunderstandings. Thus, it doesn&#8217;t matter if you <em>know</em> the current implementation will pass those tests or that those test cases won&#8217;t add more or different &#8220;edge&#8221; cases. If those test cases show better how the code behaves (and/or could catch errors if you rewrite the code from scratch with a different design), they&#8217;re good to have around.</p>
<p>I think the clearest example were the <a href="https://github.com/emanchado/tor/commit/8db0f914bfa1aeebed463dc2aa438ca8c87f73a0#L0L2279">tests for the <code class="syntax c">eat_whitespace*</code> functions</a>. Two of those functions end in <code class="syntax c">_no_nl</code>, and they only eat initial whitespace (except newlines). The other two functions eat initial whitespace, including newlines&#8230; but also eat comments. The tests from line 2280 on are clearly targeted at the second group, as they don&#8217;t really represent an interesting use case for the first. However, without those tests, a future maintainer could have thought that the <code class="syntax c">_no_nl</code> functions were supposed to eat whitespace too, and break the code. That produces confusing errors and bugs, which in turn make people fear touching the code.</p>
<p>See other examples in commits <a href="https://github.com/emanchado/tor/commit/b7b3b99acbeb29258e071b8f6c2a7d257a94ad99#L0L1552">b7b3b99</a> (escaped &#8216;%&#8217;, negative numbers, %i format string), <a href="https://github.com/emanchado/tor/commit/618836b3bb643db4af457a32cd8f2338153b5e88#L0L1516">618836b</a> (should an empty string be found at the beginning, or not found at all? does &#8220;\n&#8221; count as beginning of a line? can &#8220;\n&#8221; be found by itself? what about a string that expands more than one line? what about a line including the &#8220;\n&#8221;, with and without the haystack having the &#8220;\n&#8221; at the end?), <a href="https://github.com/emanchado/tor/commit/63b018eecea37ea5a09381157624a507a4a9187a">63b018ee</a> (how are errors handled? what happens when a %s gets part of a number?), <a href="https://github.com/emanchado/tor/commit/2210f18cee86cf17817b386aeca1af2cd0b1f249#L0L1131">2210f18</a> (is a newline only \r\n or \n, or any combination or \r and \n?) and <a href="https://github.com/emanchado/tor/commit/46bbf6c015fac412b47ca56279002129a1c2b278#L0L654">46bbf6c</a> (check that all non-printable characters are escaped in octal, even if they were originally in hex; check that characters in octal/hex, when they&#8217;re printable, appear directly and not in octal).</p>
<h2>Testing boundaries</h2>
<p>Boundaries of different kinds are a typical source of bugs, and thus are among the best points of testing we have. It&#8217;s also good to test <em>both</em> sides of the boundaries, both as an example and because bugs can appear on both sides (and not necessarily at once!).</p>
<p>The best example are the <a href="https://github.com/emanchado/tor/commit/770fd9f#L0R1484">tor_strtok_r_impl tests</a> (a function that is supposed to be compatible with <code class="syntax c">strtok_r</code>, that is, it chops a given string into &#8220;tokens&#8221;, separated by one of the given separator characters). In fact, these extra tests discovered an actual bug in the implementation (ie. an incompatibility with <code class="syntax c">strtok_r</code>). Those extra tests asked a couple of interesting questions, including &#8220;when a string <em>ends</em> in the token separator, is there an empty token in the end?&#8221; in the &#8220;howdy!&#8221; example. This test can also be considered valuable as in &#8220;tests as spec&#8221;, if you consider that the answer to be above question is not obvious and both answers could be considered correct.</p>
<p>See other examples in commits <a href="https://github.com/emanchado/tor/commit/5740e0fc1f00fa91be107ee6c4315d114c5ffdc4#L0L598">5740e0f</a> (checking if <code class="syntax c">tor_snprintf</code> correctly counts the number of bytes, as opposed the characters, when calculating if something can fit in a string; also note my embarrassing mistake of testing <code class="syntax c">snprintf</code>, and not <code class="syntax c">tor_snprintf</code>, later in the same commit), <a href="https://github.com/emanchado/tor/commit/46bbf6c015fac412b47ca56279002129a1c2b278#L0L637">46bbf6c</a> (check that character 21 doesn&#8217;t make a difference, but 20 does) and <a href="https://github.com/emanchado/tor/commit/725d6ef37909080a3d2c5bc25245ea0e951882f2#L0L2217">725d6ef</a> (testing 129 is very good, but even better with 128—or, in this case, 7 and 8).</p>
<h2>Testing implementation details</h2>
<p>Testing implementation details tends to be a bad idea. You can usually argue you&#8217;re testing implementation details if you&#8217;re not getting the test information from the APIs provided by whatever you&#8217;re testing. For example, if you test some API that inserts data in a database by checking the database directly, or if you test the result of a method call was correct by checking the object&#8217;s internals or calling protected/private methods. There are two reasons why this is a bad idea: first, the more implementation details you tests depend on, the less implementation details you can change without breaking your tests; second, your tests are typically less readable because they&#8217;re cluttered with details, instead of <em>meaningful</em> code.</p>
<p>The only example I encountered of this in Tor were the <a href="https://github.com/emanchado/tor/commit/c4c1d56d96623a45775ec2544c0c6951fbfa2d9f#L0L968">compression tests</a>. In this case it wasn&#8217;t a big deal, really, but I have seen this before in much worse situations and I feel this illustrates the point well enough. The problem with that deleted line is that it&#8217;s not clear what&#8217;s it&#8217;s purpose (it needs a comment), plus it uses a magic number, meaning if someone ever changes that number by mistake, it&#8217;s not obvious if the problem is the code or the test. Besides, <em>we are already checking that the magic number is correct</em>, by calling the <code class="syntax c">detect_compression_method</code>. Thus, the deleted <code class="syntax c">memcmp</code> doesn&#8217;t add any value, and makes our tests harder to read. Verdict: delete!</p>
<p><em>I hope you liked the examples so far. My next post will contain the second half of the tips.</em></p>
 <p><a href="http://hcoder.org/?flattrss_redirect&amp;id=1301&amp;md5=f51edc2b2e4df2bc4e424b096b2bbe01" title="Flattr" target="_blank"><img src="http://hcoder.org/wp-content/plugins/flattr/img/flattr-badge-large.png" alt="flattr this!"/></a></p>]]></content:encoded>
			<wfw:commentRss>http://hcoder.org/2012/02/13/unit-testing-advice-for-seasoned-hackers-12/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		<atom:link rel="payment" href="https://flattr.com/submit/auto?user_id=30124&amp;popout=1&amp;url=http%3A%2F%2Fhcoder.org%2F2012%2F02%2F13%2Funit-testing-advice-for-seasoned-hackers-12%2F&amp;language=en_GB&amp;category=text&amp;title=Unit+testing+advice+for+seasoned+hackers+%281%2F2%29&amp;description=When+reviewing+tests+written+by+other+people+I+see+patterns+in+the+improvements+I+would+make.+As+I+realise+that+these+%26%238220%3Bmistakes%26%238221%3B+are+also+made+by+experienced+hackers%2C+I+thought...&amp;tags=automated+tests%2Cfree+software%2Copen+source%2Cprojects%2Csoftware%2Ctesting%2Ctests%2Ctips%2Ctor%2Cunit%2Cblog" type="text/html" />
	</item>
		<item>
		<title>Feeling the pressure produces better code?</title>
		<link>http://hcoder.org/2009/12/06/feeling-the-pressure-produces-better-code/</link>
		<comments>http://hcoder.org/2009/12/06/feeling-the-pressure-produces-better-code/#comments</comments>
		<pubDate>Sun, 06 Dec 2009 16:10:00 +0000</pubDate>
		<dc:creator>emanchado</dc:creator>
				<category><![CDATA[Computers]]></category>
		<category><![CDATA[automated]]></category>
		<category><![CDATA[exploratory]]></category>
		<category><![CDATA[qa]]></category>
		<category><![CDATA[teams]]></category>
		<category><![CDATA[testing]]></category>
		<category><![CDATA[tests]]></category>
		<category><![CDATA[unit]]></category>

		<guid isPermaLink="false"></guid>
		<description><![CDATA[The other day I was in a conversation with some developer that was complaining about some feature. He claimed that it was too complex and that it had led to tons of bugs. In the middle of the conversation, the developer said that the feature had been so buggy that he ended up writing a [...]]]></description>
			<content:encoded><![CDATA[<p>The other day I was in a conversation with some developer that was complaining about some feature. He claimed that it was too complex and that it had led to tons of bugs. In the middle of the conversation, the developer said that the feature had been so buggy that he ended up writing a lot of unit tests for it. To be honest I don&#8217;t think there were a lot of bugs <em>after</em> those tests were written, so that made me think:</p>
<blockquote><p>Maybe the testers in his team are doing too good of a job?</p></blockquote>
<p>
Because, you know, if testers are finding enough of &#8220;those bugs&#8221; (the ones that should be caught and controlled by unit tests and not by testers <em>weeks</em> after the code was originally written), maybe some developers are just not &#8220;feeling the pressure&#8221; and can&#8217;t really get that they should be writing tests for their code. If testers are very good, things just work out fine in the end&#8230; sort of. And of course, the problem here is the trailing &#8220;sort of&#8221;.<br />
I know I&#8217;m biased, but in my view there is a <strong>ton</strong> of bugs that should never be seen by someone that is not the developer itself. Testers should deal with more complex, interesting, user-centred bugs. Non-trivial cases. Suboptimal UIs. Implementation disagreements between developers and stakeholders. That kind of thing. It&#8217;s simply a waste of time and resources that testers have to deal with silly, easy-to-avoid bugs on a daily basis. Not to mention that teams shouldn&#8217;t have to wait for days or weeks until they find <em>basic</em> bugs via exploratory testing. Or that a lot of those are much, much quicker to test with unit tests than having to create the whole fixture/environment for them to be found with exploratory testing.<br />
My current conclusion is that pushing on the UI/usability side is not only good for the user, but it&#8217;s likely to produce better code as it will be, on average, more complex and will have to be better controlled by QA (code review, less ad-hoc design, &#8230;) and automated tests. Maybe developers will start hating me for that, but hopefully <em>users</em> will thank me.</p>
 <p><a href="http://hcoder.org/?flattrss_redirect&amp;id=81&amp;md5=51f8ccaa005170cc7a643f0cb4c2a30c" title="Flattr" target="_blank"><img src="http://hcoder.org/wp-content/plugins/flattr/img/flattr-badge-large.png" alt="flattr this!"/></a></p>]]></content:encoded>
			<wfw:commentRss>http://hcoder.org/2009/12/06/feeling-the-pressure-produces-better-code/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		<atom:link rel="payment" href="https://flattr.com/submit/auto?user_id=30124&amp;popout=1&amp;url=http%3A%2F%2Fhcoder.org%2F2009%2F12%2F06%2Ffeeling-the-pressure-produces-better-code%2F&amp;language=en_GB&amp;category=text&amp;title=Feeling+the+pressure+produces+better+code%3F&amp;description=The+other+day+I+was+in+a+conversation+with+some+developer+that+was+complaining+about+some+feature.+He+claimed+that+it+was+too+complex+and+that+it+had+led+to...&amp;tags=automated%2Cexploratory%2Cqa%2Cteams%2Ctesting%2Ctests%2Cunit%2Cblog" type="text/html" />
	</item>
	</channel>
</rss>

