-
-
Notifications
You must be signed in to change notification settings - Fork 254
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Sourcing config from pyproject.toml #708
Comments
I'm not really sure. pyproject.toml seems like it is more related to coding concerns rather than "how to connect to the database" concerns. Like you wouldn't (I assume?) deploy a flask web application and then have all your database passwords and web service URLs in the pyproject.toml file. or are people using pyproject.toml as application deployment config? that would be very strange to me. |
@zzzeek thanks for the reply. I get what you mean and I think my original inclination came from the feeling that alembic is another tool external to my project. And having all configuration for external tools in a single spot was quite appealing. However this could simply be chocked up to a misunderstanding on my part. |
again I'm not really sure. but usually there's a database URL in this file and this is something that would change on dev vs. production, unless you are using named config sections. my impression is that pyproject.toml is not the right place, plus it would be a lot of work to add a whole new configuational thing, certainly anyone could make their own format here and then populate an alembic.config.Config object with it. that is, people are making their own confgurational things for Alembic all the time so you certainly can do this. maybe it's not that hard and we could put it up as a recipe. long story short though it's not on my immediate radar as a priority to work on. |
there's no plans to integrate to pyproject.toml and I dont think this is the appropriate place for alembic config in any case (update: at least as far as database URLs, logging configuration, which are deployment configurations, not source code configs). it certainly can be implemented by a custom front end, however. |
It would be useful to be able to specify the location of the alembic config in pyproject.toml, though. I prefer to keep the alembic.ini in my project's |
Other useful things in alembic.ini that would be nice to put in pyproject.toml:
|
I'm not against people that like to have several ini files everywhere. My alembic.ini usually contains this:
I think this example could be easy to add into the pyproject.toml as experimental and support both ways until everyone starts to use pyproject which eventually will happen because it is the new pythonic way. I said experimental because in that way it could be added some support to some stuff so ini lovers doesn't have to feel afraid of the change |
I think we could consider PR that would implement this. Thoughts @zzzeek ? |
pyproject.toml is intended for Python package distribution and development metadata (with the latter being subject to debate). Alembic is not a development tool (think test runners, code formatters, linters, that sort of thing) - it would not be appropriate for it to use pyproject.toml. |
I agree with @layday that this is application configuration, not package/python configuration. things in pyproject.toml have to do with people installing, testing or developing an application. database migrations are part of the application's runtime behavior. |
Ok, makes sense to me. |
Considered all said above: the part of alembic which helps with generating the migration's code and files (but not executing them) seems pretty close to package configuration so having script_location and file_template settings in pyproject.toml maybe still handy. |
Not sure if maybe we could just support a single Not great, but would allow people to not have another file thoughts on this @zzzeek ? |
that's really strange they did it that way, they basically created more work for themselves by building a brand new format that they would then need to throw away. I think it's a good idea if one wants to add pyproject.toml support to actually add pyproject.toml support for real, I guess tox had a lot more pressure on this one and they caved to it without putting in the time to just implement for real. then again they have a more complicated configuration.
I will open a new issue with my thoughts on this. |
please refer to #1082 |
I didn't see this anywhere in the docs, but is it possible to place the configuration that would have lived in
alembic.ini
into mypyproject.toml
file? Or if not, is this something planned for the future?The text was updated successfully, but these errors were encountered: