{"id":5480,"date":"2017-02-03T04:37:28","date_gmt":"2017-02-03T09:37:28","guid":{"rendered":"https:\/\/qxf2.com\/blog\/?p=5480"},"modified":"2017-02-02T04:39:57","modified_gmt":"2017-02-02T09:39:57","slug":"reading-list-understanding-software-startups","status":"publish","type":"post","link":"https:\/\/qxf2.com\/blog\/reading-list-understanding-software-startups\/","title":{"rendered":"Understanding software at startups"},"content":{"rendered":"<p>When working with software startups, you will observe a few counter-intuitive things. Good developers can produce bad software. It is usually ok to put out immature software that is not yet ready. Buggy software can successfully dominate a market. <\/p>\n<p>Many &#8216;good&#8217; habits like adherence to process, discipline, good architecture and responsible communication don&#8217;t seem to correlate with success over the short term. All startups start as short-term experiments that will have a makeover once they achieve traction. Which means, startups do not always need to focus on developing good habits early in a product&#8217;s life. That makes our life as testers harder. But by trying to focus on &#8216;zero-defects&#8217; we may actually be harming our client! <\/p>\n<p>If you come from a big company, the trade-offs made when developing early stage software could seem weird to you. So I have compiled a list of articles that will help you understand early stage software better. Hopefully, you end up developing a feel for one of my pet theories about software &#8211; bugs are usually born outside of code.<\/p>\n<h3>Reading list<\/h3>\n<p>1. <a href=\"http:\/\/www.satisfice.com\/articles\/gooden2.pdf\">The challenge of &#8220;good enough&#8221; software<\/a> by James Bach<br \/>\n2. <a href=\"https:\/\/www.jwz.org\/doc\/worse-is-better.html\">The rise of &#8220;Worse is better&#8221;<\/a><br \/>\n3. <a href=\"http:\/\/www.laputan.org\/mud\/\">Big ball of mud<\/a><br \/>\n4. <a href=\"http:\/\/wiki.c2.com\/?PlanToThrowOneAway\">Plan to throw one away <\/a><br \/>\n5. <a href=\"http:\/\/www.developsense.com\/blog\/2014\/03\/very-short-blog-posts-14-it-works\/\">It works<\/a> by Michael Bolton<br \/>\n6. <a href=\"http:\/\/programmer.97things.oreilly.com\/wiki\/index.php\/Make_the_Invisible_More_Visible\">Make the invisible more visible <\/a><br \/>\n7. <a href=\"http:\/\/ericsink.com\/articles\/Four_Questions.html\">My life as a code economist<\/a><br \/>\n8. <a href=\"https:\/\/www.joelonsoftware.com\/2005\/07\/25\/hitting-the-high-notes\/\">Hitting the high notes<\/a> by Joel Spolsky<br \/>\n9. I highly recommend this book: Weinberg&#8217;s &#8220;<a href=\"http:\/\/www.geraldmweinberg.com\/Site\/Perfect_Software.html\">Perfect software and other illusions about testing<\/a>&#8221;<\/p>\n<p>If you read through all the articles in this page, and you either end up feeling unsure about a few old habits and\/or you end up appreciating your past testing decisions better, then, great! This page has served its purpose.<\/p>\n<hr>\n","protected":false},"excerpt":{"rendered":"<p>When working with software startups, you will observe a few counter-intuitive things. Good developers can produce bad software. It is usually ok to put out immature software that is not yet ready. Buggy software can successfully dominate a market. Many &#8216;good&#8217; habits like adherence to process, discipline, good architecture and responsible communication don&#8217;t seem to correlate with success over the [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[101,82],"tags":[],"class_list":["post-5480","post","type-post","status-publish","format-standard","hentry","category-thoughts-on-software","category-thoughts-on-testing"],"_links":{"self":[{"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/posts\/5480","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/comments?post=5480"}],"version-history":[{"count":10,"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/posts\/5480\/revisions"}],"predecessor-version":[{"id":5499,"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/posts\/5480\/revisions\/5499"}],"wp:attachment":[{"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/media?parent=5480"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/categories?post=5480"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/qxf2.com\/blog\/wp-json\/wp\/v2\/tags?post=5480"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}