summaryrefslogtreecommitdiff
path: root/tests/run/__debug__.srctree
blob: a399970eee66252d90789987df824b3ec7611d5c (plain)
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
"""
PYTHON setup.py build_ext -i
PYTHON debug_test.py
PYTHON -O debug_test.py
PYTHON -OO debug_test.py
"""

######## setup.py ########

from distutils.core import setup
from Cython.Build import cythonize

setup(ext_modules = cythonize('debug_test_cython.pyx'))

######## debug_test.py ########

if __debug__:
    DBG = True
else:
    DBG = False

import sys
try:
    optimised = bool(sys.flags.optimize)
except AttributeError:
    # Py2.[45]
    optimised = eval('not __debug__')

if DBG == optimised:
    raise RuntimeError(
        "PYTHON: unexpected debug value %s, expected %s" % (
        DBG, optimised))

ASSERT_CALLED = False
def sideeffect():
    global ASSERT_CALLED
    ASSERT_CALLED = True
    return True

assert sideeffect()
if ASSERT_CALLED == optimised:
    raise RuntimeError("Assert called in optimised Python run")

import debug_test_cython
if debug_test_cython.DBG == optimised:
    raise RuntimeError(
        "CYTHON: unexpected debug value %s, expected %s" % (
        debug_test_cython.DBG, optimised))


######## debug_test_cython.pyx ########

if __debug__:
    DBG = True
else:
    DBG = False

import sys
try:
    optimised = bool(sys.flags.optimize)
except AttributeError:
    # Py2.[45]
    optimised = eval('not __debug__')

ASSERT_CALLED = False
def sideeffect():
    global ASSERT_CALLED
    ASSERT_CALLED = True
    return True

if DBG == optimised:
    raise RuntimeError("Unexpected debug value %s, expected %s" % (
                       DBG, optimised))

assert sideeffect()
if ASSERT_CALLED == optimised:
    raise RuntimeError("Assert called in optimised Python run")