-
Notifications
You must be signed in to change notification settings - Fork 141
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
93cc635
commit a533f4c
Showing
3 changed files
with
109 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
"""Internal helpers for Parcels.""" | ||
|
||
import functools | ||
import warnings | ||
from typing import Callable | ||
|
||
PACKAGE = "Parcels" | ||
|
||
|
||
def deprecated(msg: str = "") -> Callable: | ||
"""Decorator marking a function as being deprecated | ||
Parameters | ||
---------- | ||
msg : str, optional | ||
Custom message to append to the deprecation warning. | ||
Examples | ||
-------- | ||
``` | ||
@deprecated("Please use `another_function` instead") | ||
def some_old_function(x, y): | ||
return x + y | ||
@deprecated() | ||
def some_other_old_function(x, y): | ||
return x + y | ||
``` | ||
""" | ||
if msg: | ||
msg = " " + msg | ||
|
||
def decorator(func): | ||
@functools.wraps(func) | ||
def wrapper(*args, **kwargs): | ||
msg_formatted = ( | ||
f"`{func.__qualname__}` is deprecated and will be removed in a future release of {PACKAGE}.{msg}" | ||
) | ||
|
||
warnings.warn(msg_formatted, category=DeprecationWarning, stacklevel=2) | ||
return func(*args, **kwargs) | ||
|
||
return wrapper | ||
|
||
return decorator | ||
|
||
|
||
def deprecated_made_private(func: Callable) -> Callable: | ||
return deprecated( | ||
"It was identified as part of the internal API as it is not expected to be directly used by " | ||
"the end-user. If you feel that you use this code directly in your scripts, please " | ||
"comment on our tracking issue at <>." # TODO: Add tracking issue | ||
)(func) |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
import pytest | ||
|
||
from parcels.util._helpers import deprecated, deprecated_made_private | ||
|
||
# Write me tests to test deprecated and depreacted_made_private decorators | ||
# They should raise a DeprecationWarning, and also have the function name (or in the case of a method, {class_name}.{method_name}) in the warning message | ||
|
||
|
||
def test_deprecated(): | ||
class SomeClass: | ||
@deprecated() | ||
def some_method(self, x, y): | ||
return x + y | ||
|
||
@staticmethod | ||
@deprecated() | ||
def some_static_method(x, y): | ||
return x + y | ||
|
||
@property | ||
@deprecated() | ||
def some_property(self): | ||
return 2 | ||
|
||
@deprecated() | ||
def some_function(x, y): | ||
return x + y | ||
|
||
with pytest.warns(DeprecationWarning) as record: | ||
SomeClass().some_method(1, 2) | ||
assert "SomeClass.some_method" in record[0].message.args[0] | ||
|
||
with pytest.warns(DeprecationWarning) as record: | ||
SomeClass.some_static_method(1, 2) | ||
assert "SomeClass.some_static_method" in record[0].message.args[0] | ||
|
||
with pytest.warns(DeprecationWarning) as record: | ||
_ = SomeClass().some_property | ||
assert "SomeClass.some_property" in record[0].message.args[0] | ||
|
||
with pytest.warns(DeprecationWarning) as record: | ||
some_function(1, 2) | ||
assert "some_function" in record[0].message.args[0] | ||
|
||
with pytest.warns(DeprecationWarning) as record: | ||
some_function(1, 2) | ||
assert "some_function" in record[0].message.args[0] | ||
|
||
|
||
def test_deprecated_made_private(): | ||
@deprecated_made_private | ||
def some_function(x, y): | ||
return x + y | ||
|
||
with pytest.warns(DeprecationWarning): | ||
some_function(1, 2) |