From b5337eaa664faa0a892d5923d34c2fd664c8b1b2 Mon Sep 17 00:00:00 2001 From: Michael Bayer Date: Wed, 6 Nov 2024 18:43:43 -0500 Subject: [PATCH] Fix `alembic.ini` templates to match `configparser` file format. In the `alembic.ini` templates, I moved the inline comment about `version_path_separator` to their own lines as required by `configparser`. ### Description In a recent project, I included the following configuration values in my `alembic.ini`. Note that the last line is the default line from the current generic `alembic.ini` template. ``` # version location specification; This defaults # to migrations/versions. When using multiple version # directories, initial revisions must be specified with --version-path. # The path separator used here should be the separator specified by "version_path_separator" below. version_locations = %(here)s/migrations/versions # version path separator; As mentioned above, this is the character used to split # version_locations. The default within new alembic.ini files is "os", which uses os.pathsep. # If this key is omitted entirely, it falls back to the legacy behavior of splitting on spaces and/or commas. # Valid values for version_path_separator are: # # version_path_separator = : # version_path_separator = ; # version_path_separator = space version_path_separator = os # Use os.pathsep. Default configuration used for new projects. ``` When running `alembic check`, I encountered: ``` ValueError: 'os # Use os.pathsep. Default configuration used for new projects.' is not a valid value for version_path_separator; expected 'space', 'os', ':', ';' ``` It seemed that the comment in the last line was being included as part of the parsed config value, which should be `os`. Alembic currently [uses `configparser.ConfigParser` from the standard libary](https://github.com/sqlalchemy/alembic/blob/2d60c77c81a72a78b575b96aef511e658073dec5/alembic/util/compat.py#L82-L89) to parse `alembic.ini` files. The [default `configparser` file format](https://docs.python.org/3/library/configparser.html#supported-ini-file-structure) requires that comments be on their own lines, although this can be customized. I changed the three copies of this line in Alembic's `alembic.ini` templates to remove the inline comments. In my case, this change fixed the `ValueError`. This issue could also be fixed by changing [the default instance of `ConfigParser`](https://github.com/sqlalchemy/alembic/blob/2d60c77c81a72a78b575b96aef511e658073dec5/alembic/config.py#L202), using `inline_comment_prefixes=("#",)`. I imagine, however, that it might be better to use the default file format. ### Checklist This pull request is: - [x] A documentation / typographical error fix - Good to go, no issue or tests are needed - [ ] A short code fix - please include the issue number, and create an issue if none exists, which must include a complete example of the issue. one line code fixes without an issue and demonstration will not be accepted. - Please include: `Fixes: #` in the commit message - please include tests. one line code fixes without tests will not be accepted. - [ ] A new feature implementation - please include the issue number, and create an issue if none exists, which must include a complete example of how the feature would look. - Please include: `Fixes: #` in the commit message - please include tests. **Have a nice day!** Closes: #1397 Pull-request: https://github.com/sqlalchemy/alembic/pull/1397 Pull-request-sha: 073cbd9b076fffa78be3b374e20ece4a2562f7bd Change-Id: I49bc76994617a3c17a2443a4e4387c2479a661a4 --- alembic/templates/async/alembic.ini.mako | 4 +++- alembic/templates/generic/alembic.ini.mako | 4 +++- alembic/templates/multidb/alembic.ini.mako | 4 +++- 3 files changed, 9 insertions(+), 3 deletions(-) diff --git a/alembic/templates/async/alembic.ini.mako b/alembic/templates/async/alembic.ini.mako index 02ddb9e1..f97e2d66 100644 --- a/alembic/templates/async/alembic.ini.mako +++ b/alembic/templates/async/alembic.ini.mako @@ -48,7 +48,9 @@ prepend_sys_path = . # version_path_separator = ; # version_path_separator = space # version_path_separator = newline -version_path_separator = os # Use os.pathsep. Default configuration used for new projects. +# +# Use os.pathsep. Default configuration used for new projects. +version_path_separator = os # set to 'true' to search source files recursively # in each "version_locations" directory diff --git a/alembic/templates/generic/alembic.ini.mako b/alembic/templates/generic/alembic.ini.mako index fb709232..4fc5d01a 100644 --- a/alembic/templates/generic/alembic.ini.mako +++ b/alembic/templates/generic/alembic.ini.mako @@ -50,7 +50,9 @@ prepend_sys_path = . # version_path_separator = ; # version_path_separator = space # version_path_separator = newline -version_path_separator = os # Use os.pathsep. Default configuration used for new projects. +# +# Use os.pathsep. Default configuration used for new projects. +version_path_separator = os # set to 'true' to search source files recursively # in each "version_locations" directory diff --git a/alembic/templates/multidb/alembic.ini.mako b/alembic/templates/multidb/alembic.ini.mako index 687da570..116bd4a8 100644 --- a/alembic/templates/multidb/alembic.ini.mako +++ b/alembic/templates/multidb/alembic.ini.mako @@ -50,7 +50,9 @@ prepend_sys_path = . # version_path_separator = ; # version_path_separator = space # version_path_separator = newline -version_path_separator = os # Use os.pathsep. Default configuration used for new projects. +# +# Use os.pathsep. Default configuration used for new projects. +version_path_separator = os # set to 'true' to search source files recursively # in each "version_locations" directory -- 2.47.3