DEV Community

Cover image for Your Vibe-Coded App Isn't Real Until It Has a URL
Dmitry Chervonyi
Dmitry Chervonyi

Posted on

Your Vibe-Coded App Isn't Real Until It Has a URL

Here's a sentence that has quietly become a lie: "I built an app."

You built something that runs on your screen. Maybe in a preview pane, maybe on localhost, maybe inside a chat window. It works. It's real to you. And for most of human software history, that was 90% of the battle — getting the thing to actually function.

That era is over. The functioning part is solved now. You describe what you want, an AI writes it, and it runs. The 90% collapsed to about four minutes.

But here's what nobody updated: the definition of "done" didn't move with it. And that gap is where I watch person after person celebrate a finish line that isn't one.

A preview is not a product

A preview is a promise. It says "this could exist." It runs in a sandboxed, temporary, you-only environment that quietly handles everything real software has to handle for itself — the server, the domain, the build, the environment, the fact that it has to keep working when you close your laptop.

The moment you want one other human to use the thing, all of that stops being handled for you. And that's the moment most AI-built apps die. Not because the code is bad. Because "runs on my screen" and "is live for someone else" are two completely different achievements, and the tools let you mistake the first for the second.

Think about what "real" actually requires:

  • A URL a stranger can open — not localhost:3000, not something.preview.app, not a link that dies with your session.
  • It stays up when you're not looking at it.
  • It lives on your domain, so it's yours and not a demo on someone else's.
  • Someone who isn't you can use it and come back tomorrow and it still works.

None of that is the fun part. None of that is what the demos show you. And all of it is the actual product.

The demo culture is training us wrong

Scroll any feed right now and you'll see the same clip a hundred times: a prompt, a four-minute build, a working preview, a triumphant "shipped!" 🚀

Except it wasn't shipped. Shipped means it left the building. What got shown was a thing that works in the one place it will never need to work in production: the creator's own screen.

I don't think this is dishonest. I think it's a genuine blind spot. The people making those clips are mostly developers, and for a developer, deployment is muscle memory — a git push, a Vercel connect, a domain they bought years ago. They skip showing it because to them it's not a step. It's breathing.

But the entire reason vibe coding matters is that it brought in people who are not developers. People like me — I run marketing, I can't write the backend, but I know exactly what I want to build. For us, deployment isn't breathing. It's a wall. A wall the demos pretend isn't there, built out of a hundred years of assumptions nobody bothered to remove when they removed the assumption that you had to know how to code.

So you get this cruel asymmetry: the creative half of software got democratized, and the boring, load-bearing half stayed exactly as gatekept as it always was. The AI hands you a working app and drops you at the foot of the wall it never mentioned.

Move your finish line

I'm not here to make you feel bad about a preview. Previews are great. They're the most exciting thing to happen to building in a decade.

I'm here to move where you plant the flag.

Stop letting "it runs" be the moment you celebrate. It's a checkpoint, not the finish. The finish line — the only one that counts — is a URL you can text to someone who has never met you, on a domain that's yours, that still works after you've gone to sleep.

When I started treating that as "done," two things happened. First, I stopped accumulating a graveyard of apps that technically existed and reached exactly zero humans. Second, I got way more honest about what I'd actually accomplished on any given night. "I made a cool preview" is a fine thing to have done. It is just not the same thing as having built an app, and pretending otherwise is how you end up with eleven dead projects and a vague sense that AI didn't deliver what it promised.

It did deliver. It delivered the hard 90%. The last 10% is just hiding in plain sight, and it has a name, and the name is: it needs a URL.

That last step is the whole reason I'm now working on livemy.app — taking the thing that runs on your screen and turning it into a link someone else can open, without asking you to learn a single config file. I'll leave it there.

But even if you never touch what I'm building: change your definition of done. Your apps will stop dying. And "I built an app" will go back to being true.


Honest question for the room: what's the last thing you vibe-coded that's still trapped in a preview right now? What tool was it, and what exactly stopped you from putting it live? I genuinely think the answers cluster, and I want to see if I'm right.

Top comments (0)