Skip to content
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

Remove deprecated logging.Logger.warn() method in Python 3.13 #105376

Closed
vstinner opened this issue Jun 6, 2023 · 18 comments
Closed

Remove deprecated logging.Logger.warn() method in Python 3.13 #105376

vstinner opened this issue Jun 6, 2023 · 18 comments
Labels
type-bug An unexpected behavior, bug, or error

Comments

@vstinner
Copy link
Member

vstinner commented Jun 6, 2023

The logging.Logger.warn() method was deprecated in Python 3.3 by issue #57444 and commit 04d5bc0. This method is not documented and emits a DeprecationWarning since Python 3.3.

#57444 (comment):

That's deliberate. The original code (before incorporation into Python) had warn(), which was kept for backward compatibility. The docs refer to warning() because that's what everyone is supposed to use. The method names map to the lower case of the appropriate logging level name.

I propose to remove this logging.Logger.warn() method in Python 3.13.

Linked PRs

@vstinner vstinner added the type-bug An unexpected behavior, bug, or error label Jun 6, 2023
vstinner added a commit to vstinner/cpython that referenced this issue Jun 6, 2023
@vstinner
Copy link
Member Author

vstinner commented Jun 6, 2023

cc @vsajip

The alternative is to remove the deprecation and keep this alias: see issue #105373.

vstinner added a commit to vstinner/cpython that referenced this issue Jun 6, 2023
@vstinner vstinner closed this as completed Jun 9, 2023
vstinner added a commit to vstinner/cpython that referenced this issue Jul 8, 2023
fernandoataoldotcom added a commit to glueops-rip/terraform-cloud-backup that referenced this issue Dec 18, 2023
this likely won't affect us for a while, but might as well clean it up
python/cpython#105376
fernandoataoldotcom added a commit to glueops-rip/terraform-cloud-backup that referenced this issue Dec 18, 2023
this likely won't affect us for a while, but might as well clean it up
python/cpython#105376
hroncok added a commit to hroncok/pyzmq that referenced this issue Mar 11, 2024
@davidmayo
Copy link

davidmayo commented Aug 6, 2024

I would like to speak up for reversing this change. A lot of people, especially non-professional programmers, have written a lot of code with logging.warn(), and it is going to break in a way that will be very confusing to them. It's going to be especially thorny, since the thing that will fail will be their logging utility itself, which is usually where they would go to begin troubleshooting.

If this really is going to be removed, I would recommend at least one Python release where using logging.warn() emits a SyntaxWarning instead of a DeprecationWarning before removing it entirely, so that people have at least some visibility of the problem before their code breaks. This was done for invalid escape sequences in string literals in Python3.12, and I think it's a good model. Release notes link.

EDIT: I didn't notice until after I posted that the SyntaxWarning for invalid escape sequences was also done by @vstinner !

@vsajip
Copy link
Member

vsajip commented Aug 6, 2024

Whereas invalid escape sequences might reasonably be considered syntax warnings, I'm not sure that applies to methods that were deprecated long ago. In any case, it's easy enough for users to fix their broken code, in the (presumably) very rare instances where they didn't see the deprecation warning because they upgraded to the very latest Python version from a pre- 3.3 version.

Can you explain why you think a SyntaxWarning is better than the DeprecationWarning which was already in place?

@hugovk
Copy link
Member

hugovk commented Aug 6, 2024

These can be found with the Ruff linter: https://docs.astral.sh/ruff/rules/#flake8-logging-format-g

For example:

ruff check --isolated --select G010 .

And auto-fixed:

ruff check --isolated --select G010 . --fix

And found with pylint: https://pylint.readthedocs.io/en/stable/user_guide/messages/warning/deprecated-method.html

pylint  --disable=all --enable=W4902 .

And a Flake8 plugin: https://pypi.org/project/flake8-logging-format/

@davidmayo
Copy link

@vsajip My preferred solution is to keep the warn() method in Logger with no changes.

If that isn't possible, I recommended the SyntaxWarning approach because I thought that it is visible by default, whereas DeprecationWarning is invisible by default. But based on some quick testing, that seems like it's not actually the case, at least universally.

I was trying to replicate this kind of behavior, where the warning about the deprecated behavior became more visible in 3.12:

❯ python3.11 -c "print('\d')"
\d

❯ python3.12 -c "print('\d')"
<string>:1: SyntaxWarning: invalid escape sequence '\d'
\d

@vsajip
Copy link
Member

vsajip commented Aug 6, 2024

whereas DeprecationWarning is invisible by default

I've no idea what you mean - DeprecationWarning seems quite visible to me!

~> python3                                                                                    
Python 3.8.8 (tags/v3.8.8:024d805, Feb 19 2021, 13:18:16) [MSC v.1928 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.                        
>>> import logging                                                                            
>>> logging.warn('foo')                                                                       
<stdin>:1: DeprecationWarning: The 'warn' function is deprecated, use 'warning' instead       
WARNING:root:foo                                                                              
>>> logging.getLogger().warn('bar')                                                           
<stdin>:1: DeprecationWarning: The 'warn' method is deprecated, use 'warning' instead         
WARNING:root:bar                                                                              
>>>

@davidmayo
Copy link

davidmayo commented Aug 6, 2024

Right, I have realized I was wrong about that. I don't know much about how warnings work, honestly. My belief was based off of this comment

I propose now raises a SyntaxError, rather than a DeprecationWarning (which is silent in most cases).

which is about a SyntaxError, not a SyntaxWarning. I was reading it wrong.

I still think the Logger.warn() method should be left in place, though.

@vstinner
Copy link
Member Author

vstinner commented Aug 7, 2024

I removed Logger.warn() because it was deprecated since Python 3.3. Sadly, DeprecationWarning is silent by default: you have to run python -Wdefault or python -X dev to see them.

Calling Logger.warn() is slower since it emits a DeprecationWarning. I don't think that keeping a deprecated method forever is a good long term solution.

Either we decide that Logger.warn() is a convenient alias and it should not emit a DeprecationWarning (maybe it can be soft deprecated instead), or we decide that Logger.warning() must be used instead (current state, removed warn() method).

@vstinner
Copy link
Member Author

vstinner commented Aug 7, 2024

I've no idea what you mean - DeprecationWarning seems quite visible to me!

Since Python 3.7, DeprecationWarning are shown in the main module: https://peps.python.org/pep-0565/ It includes the REPL. But DeprecationWarning is still hidden by default if the warning is emitted from another module.

@vsajip
Copy link
Member

vsajip commented Aug 7, 2024

TIL! I'm OK with the current state.

@Yhg1s
Copy link
Member

Yhg1s commented Aug 7, 2024

I don't see a problem with keeping (adding back) the warn method with DeprecationWarning. There's value in nudging people to the preferred method and there's value in not breaking user code willy-nilly. I don't see a problem with keeping a deprecated method indefinitely, either.

vstinner added a commit to vstinner/cpython that referenced this issue Aug 7, 2024
…105377)"

This reverts commit dcc028d and
commit 6c54e5d.

Keep warn() method in Python 3.13.
vstinner added a commit to vstinner/cpython that referenced this issue Aug 7, 2024
This reverts commit dcc028d and
commit 6c54e5d.

Keep warn() method in Python 3.13.
vstinner added a commit to vstinner/cpython that referenced this issue Aug 7, 2024
This reverts commit dcc028d and
commit 6c54e5d.

Keep warn() method in Python 3.13.
vstinner added a commit to vstinner/cpython that referenced this issue Aug 7, 2024
This reverts commit dcc028d and
commit 6c54e5d.

Keep deprecated logging warn() method in Python 3.13.
vstinner added a commit to vstinner/cpython that referenced this issue Aug 7, 2024
This reverts commit dcc028d and
commit 6c54e5d.

Keep the deprecated logging warn() method in Python 3.13.
@vstinner
Copy link
Member Author

vstinner commented Aug 7, 2024

I created PR gh-122775 to restore the deprecated logging warn() method.

@vstinner vstinner reopened this Aug 7, 2024
@zooba
Copy link
Member

zooba commented Aug 7, 2024

I vote to keep it. This is hardly a maintenance burden - if we were to drop the deprecation warning then it's no maintenance burden at all.

"warn()", a verb, is a better method name anyway. I would normally assume "logging.warning" is a constant or type.

@vsajip
Copy link
Member

vsajip commented Aug 7, 2024

a verb, is a better method name anyway

In this case, the methods just echo the names of the levels they log at - they are just conveniences for the verb "log at ".

@ncoghlan
Copy link
Contributor

ncoghlan commented Aug 8, 2024

In this case, the methods just echo the names of the levels they log at - they are just conveniences for the verb "log at ".

The novelty of warning is that unlike the other log levels, it does have a directly corresponding verb (warn). Sure, it's a shorthand for a shorthand, but it's a pretty harmless one.

@joukewitteveen
Copy link
Contributor

no maintenance burden at all.

This is not true. The wrapper was an additional concern in #28287. In fact, it absorbed a substantial part of the total effort.

Remember the Zen of Python:

There should be one-- and preferably only one --obvious way to do it.

I'm in favor of removing the long-deprecated method.

@zooba
Copy link
Member

zooba commented Aug 8, 2024

no maintenance burden at all.

This is not true.

If we dropped the warning (which was the part of my message you clipped out), it would be an alias of warning rather than a wrapper, and this would've been a non-issue. (Personally I'd redesign the whole thing to avoid stacklevel-type shenanigans anyway, but I'm not that motivated on it.)

vstinner added a commit that referenced this issue Aug 9, 2024
This reverts commit dcc028d and
commit 6c54e5d.

Keep the deprecated logging warn() method in Python 3.13.

Co-authored-by: Gregory P. Smith <greg@krypto.org>
Co-authored-by: Hugo van Kemenade <1324225+hugovk@users.noreply.github.com>
miss-islington pushed a commit to miss-islington/cpython that referenced this issue Aug 9, 2024
…22775)

This reverts commit dcc028d and
commit 6c54e5d.

Keep the deprecated logging warn() method in Python 3.13.

(cherry picked from commit d323997)

Co-authored-by: Victor Stinner <vstinner@python.org>
Co-authored-by: Gregory P. Smith <greg@krypto.org>
Co-authored-by: Hugo van Kemenade <1324225+hugovk@users.noreply.github.com>
vstinner added a commit that referenced this issue Aug 9, 2024
#122856)

gh-105376: Restore deprecated logging warn() method (GH-122775)

This reverts commit dcc028d and
commit 6c54e5d.

Keep the deprecated logging warn() method in Python 3.13.

(cherry picked from commit d323997)

Co-authored-by: Victor Stinner <vstinner@python.org>
Co-authored-by: Gregory P. Smith <greg@krypto.org>
Co-authored-by: Hugo van Kemenade <1324225+hugovk@users.noreply.github.com>
@vstinner
Copy link
Member Author

vstinner commented Aug 9, 2024

I added again the warn() method.

@vstinner vstinner closed this as completed Aug 9, 2024
blhsing pushed a commit to blhsing/cpython that referenced this issue Aug 22, 2024
)

This reverts commit dcc028d and
commit 6c54e5d.

Keep the deprecated logging warn() method in Python 3.13.

Co-authored-by: Gregory P. Smith <greg@krypto.org>
Co-authored-by: Hugo van Kemenade <1324225+hugovk@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type-bug An unexpected behavior, bug, or error
Projects
None yet
Development

No branches or pull requests

8 participants