-
-
Notifications
You must be signed in to change notification settings - Fork 18.4k
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
BUG: Added deprecation warning to Timestamp constructor #61149
base: main
Are you sure you want to change the base?
BUG: Added deprecation warning to Timestamp constructor #61149
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the PR! Can you add a note to the whatsnew of v3.0.0 in the deprecation section.
pandas/tests/indexing/test_loc.py
Outdated
@pytest.mark.filterwarnings("ignore:indexing past lexsort depth") | ||
@pytest.mark.filterwarnings( | ||
"ignore:indexing past lexsort depth", | ||
"ignore:Passing an empty string to Timestamp", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Instead of ignoring in each of these tests, can you test the warning. See
https://pandas.pydata.org/pandas-docs/dev/development/contributing_codebase.html#testing-a-warning
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@jhendricks487 - you still need to modify the other tests where this warning occurs with tm.assert_produces_warning
. Any warning that occurs outside of such a block will result in the test failing.
…dricks/pandas into add-warning-timestamp-blank-string
@rhshadrach should be good now, but let me know if you have any suggested improvements! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When using tm.assert_produces_warning
, you can also pass None
to indicate that no warning should be raised. So a lot of times in the testing code you'll see something like
klass = FutureWarning if [condition] else None
tm.assert_produces_warning(klass, match=msg):
This avoids having to branch in the test itself.
if ts_input == "": | ||
warnings.warn( | ||
"Passing an empty string to Timestamp is deprecated and will raise " | ||
"a ValueError in a future version.", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you add Use `pd.NaT` directly instead.
with tm.assert_produces_warning(FutureWarning, match=msg): | ||
exp_index = index.insert(len(index), key) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks problematic - the warning message will say not to pass ""
to Timestamp
but the user is doing no such thing. It looks like we'll have to change the internals here to avoid triggering the warning message. This applies to all the warnings in this PR where you aren't explicitly passing ""
to Timestamp
.
If you want any assistance in how to change, let me know and I'm happy to take a look.
Part of #11953
Added deprecation warning to Timestamp constructor when
ts_input = ""
.This addition was motivated by this comment: #11953 (comment)
doc/source/whatsnew/vX.X.X.rst
file if fixing a bug or adding a new feature.