aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/python/ipython/py2/IPython/testing/skipdoctest.py
blob: 8357f609b0effc8be30691388dc6c139a5683515 (plain) (blame)
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
"""Decorators marks that a doctest should be skipped, for both python 2 and 3. 
 
The IPython.testing.decorators module triggers various extra imports, including 
numpy and sympy if they're present. Since this decorator is used in core parts 
of IPython, it's in a separate module so that running IPython doesn't trigger 
those imports.""" 
 
#----------------------------------------------------------------------------- 
#  Copyright (C) 2009-2011  The IPython Development Team 
# 
#  Distributed under the terms of the BSD License.  The full license is in 
#  the file COPYING, distributed as part of this software. 
#----------------------------------------------------------------------------- 
 
#----------------------------------------------------------------------------- 
# Imports 
#----------------------------------------------------------------------------- 
 
import sys 
 
#----------------------------------------------------------------------------- 
# Decorators 
#----------------------------------------------------------------------------- 
 
def skip_doctest(f): 
    """Decorator - mark a function or method for skipping its doctest. 
 
    This decorator allows you to mark a function whose docstring you wish to 
    omit from testing, while preserving the docstring for introspection, help, 
    etc.""" 
    f.skip_doctest = True 
    return f 
 
 
def skip_doctest_py3(f): 
    """Decorator - skip the doctest under Python 3.""" 
    f.skip_doctest = (sys.version_info[0] >= 3) 
    return f 

def skip_doctest_py2(f):
    """Decorator - skip the doctest under Python 3."""
    f.skip_doctest = (sys.version_info[0] < 3)
    return f