File: warnings.rst

package info (click to toggle)
python-globus-sdk 3.54.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 5,032 kB
  • sloc: python: 34,226; sh: 44; makefile: 31
file content (130 lines) | stat: -rw-r--r-- 3,222 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
Warnings
========

The following warnings can be emitted by the Globus SDK to indicate a
problem, or a future change, which is not necessarily an error.

.. autoclass:: globus_sdk.RemovedInV4Warning
    :members:
    :show-inheritance:


By default, Python will not display deprecation warnings to end users,
but testing frameworks like pytest will enable deprecation warnings for developers.

..  seealso::

    *   `Python's warnings module`_
    *   `pytest's warnings documentation`_


Enabling deprecation warnings
-----------------------------

By default, Python ignores deprecation warnings,
so end users of your application will not see warnings.

However, you may want to enable deprecation warnings
to help prepare for coming changes in the Globus SDK.
Deprecation warnings can be enabled in several ways:

#.  The ``PYTHONWARNINGS`` environment variable
#.  The Python executable ``-W`` argument
#.  The Python ``warnings.filterwarnings()`` function


..  rubric:: The ``PYTHONWARNINGS`` environment variable

Deprecation warnings can be enabled using this shell syntax:

..  code-block:: bash

    # POSIX shell example
    export PYTHONWARNINGS="error::DeprecationWarning"
    python ...

    # Inline example
    PYTHONWARNINGS="error::DeprecationWarning" python ...

..  code-block:: pwsh

    # Powershell example
    $env:PYTHONWARNINGS="error::DeprecationWarning"
    python ...


..  rubric:: The Python executable ``-W`` argument

Deprecation warnings can be enabled using this Python executable argument:

..  code-block:: text

    python -W "error::DeprecationWarning" ...


..  rubric:: The Python ``warnings.filterwarnings()`` function

Deprecation warnings can be enabled in Python code:

..  code-block:: python

    import warnings

    warnings.filterwarnings("error", category=DeprecationWarning)


Disabling deprecation warnings
------------------------------

Python testing frameworks like pytest enable deprecation warnings by default.
Deprecation warnings can be disabled in several ways:

#.  The ``PYTHONWARNINGS`` environment variable
#.  The pytest executable ``-W`` argument
#.  The ``pytest.ini`` (or similar) file


..  rubric:: The ``PYTHONWARNINGS`` environment variable

You can disable deprecation warnings using environment variables:

..  code-block:: bash

    # POSIX shell example
    export PYTHONWARNINGS="ignore::DeprecationWarning"
    pytest ...

    # Inline example
    PYTHONWARNINGS="ignore::DeprecationWarning" pytest ...

..  code-block:: pwsh

    # Powershell example
    $env:PYTHONWARNINGS="ignore::DeprecationWarning"
    pytest ...


..  rubric:: The pytest executable ``-W`` argument

You can disable deprecation warnings using pytest's ``-W`` argument:

..  code-block:: text

    pytest -W "ignore::DeprecationWarning" ...


..  rubric:: The ``pytest.ini`` (or similar) file

You can disable warnings using a pytest configuration file like ``pytest.ini``:

..  code-block:: ini

    [pytest]
    filterwarnings =
        ignore::DeprecationWarning


..  Links
..  -----
..  _Python's warnings module: https://docs.python.org/3/library/warnings.html
..  _pytest's warnings documentation: https://docs.pytest.org/en/latest/how-to/capture-warnings.html