<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Joel Bennett</title>
    <description>The latest articles on DEV Community by Joel Bennett (@928builds).</description>
    <link>https://dev.to/928builds</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3963503%2Fba57e46d-0c39-4155-af04-da19b46a333d.png</url>
      <title>DEV Community: Joel Bennett</title>
      <link>https://dev.to/928builds</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/928builds"/>
    <language>en</language>
    <item>
      <title>Perfect Is the Enemy of Done — and I Learned That the Hard Way</title>
      <dc:creator>Joel Bennett</dc:creator>
      <pubDate>Fri, 12 Jun 2026 23:19:13 +0000</pubDate>
      <link>https://dev.to/928builds/perfect-is-the-enemy-of-done-and-i-learned-that-the-hard-way-2pa</link>
      <guid>https://dev.to/928builds/perfect-is-the-enemy-of-done-and-i-learned-that-the-hard-way-2pa</guid>
      <description>&lt;p&gt;I had something that worked. It wasn't pretty. There were rough edges. A few things I wanted to clean up before anyone saw it. So I kept going.&lt;/p&gt;

&lt;p&gt;Three weeks later I was still cleaning things up.&lt;/p&gt;

&lt;p&gt;The feature I was going to add after launch somehow became a requirement before launch. The design that was good enough somehow needed one more pass. The thing that worked fine somehow needed to be rebuilt the right way before I could feel okay about shipping it.&lt;/p&gt;

&lt;p&gt;Nobody asked for any of that. I did it to myself.&lt;/p&gt;

&lt;p&gt;This is the trap I fall into more than any other. Not building the wrong thing. Not targeting the wrong person. Just refusing to ship the right thing because it isn't perfect yet. And perfect, I've had to learn over and over, is the enemy of good.&lt;/p&gt;

&lt;p&gt;The version sitting on my machine helping nobody is not better than the imperfect version in someone's hands. It doesn't matter how clean the code is, how tight the design is, how well-thought-out the edge cases are — if it's not shipped, it doesn't exist.. The user can't tell you what's wrong with something they've never seen.&lt;/p&gt;

&lt;p&gt;What I've noticed is that the things I agonize over before shipping almost never come up after. The rough edge I spent three days smoothing — nobody mentioned it. The flow I rebuilt from scratch because it felt slightly off — users navigated it without a second thought. The stuff that actually needed fixing was stuff I didn't even know was a problem until real people used it and showed me.&lt;/p&gt;

&lt;p&gt;That's the thing about building in your own head. You manufacture problems. You imagine friction that isn't there. You optimize for a user experience you've never actually watched a real person have. Meanwhile the real problems — the ones that actually matter — are invisible to you until someone else finds them.&lt;/p&gt;

&lt;p&gt;Ship it. Watch what happens. Fix what breaks.. &lt;/p&gt;

&lt;p&gt;That's not laziness. That's the actual process. The first version is a question, not an answer. You're asking the world whether this thing is useful and whether it works. You can't get that answer sitting at your desk making it prettier.&lt;/p&gt;

&lt;p&gt;I've shipped things I wasn't proud of. Some of them became the most useful things I've built — not because they were good at launch but because real feedback made them good. I've also sat on things until they were "ready" and by the time I shipped them the moment had passed or I'd lost interest or the problem had changed.&lt;/p&gt;

&lt;p&gt;Good enough and shipped beats perfect and sitting on your machine every single time.&lt;/p&gt;

&lt;p&gt;Get it out. Improve it after.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;Joel Bennett · Founder, 928 Builds · Tucson, AZ · 928builds.com&lt;/em&gt; #software build #lessons the hard way &lt;/p&gt;

</description>
      <category>devjournal</category>
      <category>learning</category>
      <category>productivity</category>
      <category>softwaredevelopment</category>
    </item>
  </channel>
</rss>
