FastAPI is already being used in production in many applications and systems. And the test coverage is kept at 100%. But its development is still moving quickly.
New features are added frequently, bugs are fixed regularly, and the code is still continuously improving.
That's why the current versions are still 0.x.x, this reflects that each version could potentially have breaking changes. This follows the Semantic Versioning conventions.
You can create production applications with FastAPI right now (and you have probably been doing it for some time), you just have to make sure that you use a version that works correctly with the rest of your code.
The first thing you should do is to "pin" the version of FastAPI you are using to the specific latest version that you know works correctly for your application.
For example, let's say you are using version 0.112.0 in your app.
If you use a requirements.txt file you could specify the version with:
fastapi[standard]==0.112.0
that would mean that you would use exactly the version 0.112.0.
Or you could also pin it with:
fastapi[standard]>=0.112.0,<0.113.0
that would mean that you would use the versions 0.112.0 or above, but less than 0.113.0, for example, a version 0.112.2 would still be accepted.
If you use any other tool to manage your installations, like uv, Poetry, Pipenv, or others, they all have a way that you can use to define specific versions for your packages.
With FastAPI it's very easy (thanks to Starlette), check the docs: Testing
After you have tests, then you can upgrade the FastAPI version to a more recent one, and make sure that all your code is working correctly by running your tests.
If everything is working, or after you make the necessary changes, and all your tests are passing, then you can pin your fastapi to that new recent version.