##// END OF EJS Templates
make sure to run async tests...
Min RK -
Show More
@@ -1,72 +1,87 b''
1 import types
2 import sys
3 1 import builtins
2 import inspect
4 3 import os
5 import pytest
6 4 import pathlib
7 5 import shutil
6 import sys
7 import types
8
9 import pytest
8 10
9 11 # Must register before it gets imported
10 12 pytest.register_assert_rewrite("IPython.testing.tools")
11 13
12 14 from .testing import tools
13 15
14 16
17 def pytest_collection_modifyitems(items):
18 """This function is automatically run by pytest passing all collected test
19 functions.
20
21 We use it to add asyncio marker to all async tests and assert we don't use
22 test functions that are async generators which wouldn't make sense.
23 """
24 for item in items:
25 if inspect.iscoroutinefunction(item.obj):
26 item.add_marker("asyncio")
27 assert not inspect.isasyncgenfunction(item.obj)
28
29
15 30 def get_ipython():
16 31 from .terminal.interactiveshell import TerminalInteractiveShell
17 32 if TerminalInteractiveShell._instance:
18 33 return TerminalInteractiveShell.instance()
19 34
20 35 config = tools.default_config()
21 36 config.TerminalInteractiveShell.simple_prompt = True
22 37
23 38 # Create and initialize our test-friendly IPython instance.
24 39 shell = TerminalInteractiveShell.instance(config=config)
25 40 return shell
26 41
27 42
28 43 @pytest.fixture(scope='session', autouse=True)
29 44 def work_path():
30 45 path = pathlib.Path("./tmp-ipython-pytest-profiledir")
31 46 os.environ["IPYTHONDIR"] = str(path.absolute())
32 47 if path.exists():
33 48 raise ValueError('IPython dir temporary path already exists ! Did previous test run exit successfully ?')
34 49 path.mkdir()
35 50 yield
36 51 shutil.rmtree(str(path.resolve()))
37 52
38 53
39 54 def nopage(strng, start=0, screen_lines=0, pager_cmd=None):
40 55 if isinstance(strng, dict):
41 56 strng = strng.get("text/plain", "")
42 57 print(strng)
43 58
44 59
45 60 def xsys(self, cmd):
46 61 """Replace the default system call with a capturing one for doctest.
47 62 """
48 63 # We use getoutput, but we need to strip it because pexpect captures
49 64 # the trailing newline differently from commands.getoutput
50 65 print(self.getoutput(cmd, split=False, depth=1).rstrip(), end="", file=sys.stdout)
51 66 sys.stdout.flush()
52 67
53 68
54 69 # for things to work correctly we would need this as a session fixture;
55 70 # unfortunately this will fail on some test that get executed as _collection_
56 71 # time (before the fixture run), in particular parametrized test that contain
57 72 # yields. so for now execute at import time.
58 73 #@pytest.fixture(autouse=True, scope='session')
59 74 def inject():
60 75
61 76 builtins.get_ipython = get_ipython
62 77 builtins._ip = get_ipython()
63 78 builtins.ip = get_ipython()
64 79 builtins.ip.system = types.MethodType(xsys, ip)
65 80 builtins.ip.builtin_trap.activate()
66 81 from .core import page
67 82
68 83 page.pager_page = nopage
69 84 # yield
70 85
71 86
72 87 inject()
@@ -1,184 +1,185 b''
1 1 # -*- coding: utf-8 -*-
2 2 """Setup script for IPython.
3 3
4 4 Under Posix environments it works like a typical setup.py script.
5 5 Under Windows, the command sdist is not supported, since IPython
6 6 requires utilities which are not available under Windows."""
7 7
8 8 #-----------------------------------------------------------------------------
9 9 # Copyright (c) 2008-2011, IPython Development Team.
10 10 # Copyright (c) 2001-2007, Fernando Perez <fernando.perez@colorado.edu>
11 11 # Copyright (c) 2001, Janko Hauser <jhauser@zscout.de>
12 12 # Copyright (c) 2001, Nathaniel Gray <n8gray@caltech.edu>
13 13 #
14 14 # Distributed under the terms of the Modified BSD License.
15 15 #
16 16 # The full license is in the file COPYING.rst, distributed with this software.
17 17 #-----------------------------------------------------------------------------
18 18
19 19 import os
20 20 import sys
21 21 from itertools import chain
22 22
23 23 # **Python version check**
24 24 #
25 25 # This check is also made in IPython/__init__, don't forget to update both when
26 26 # changing Python version requirements.
27 27 if sys.version_info < (3, 8):
28 28 pip_message = 'This may be due to an out of date pip. Make sure you have pip >= 9.0.1.'
29 29 try:
30 30 import pip
31 31 pip_version = tuple([int(x) for x in pip.__version__.split('.')[:3]])
32 32 if pip_version < (9, 0, 1) :
33 33 pip_message = 'Your pip version is out of date, please install pip >= 9.0.1. '\
34 34 'pip {} detected.'.format(pip.__version__)
35 35 else:
36 36 # pip is new enough - it must be something else
37 37 pip_message = ''
38 38 except Exception:
39 39 pass
40 40
41 41
42 42 error = """
43 43 IPython 8+ supports Python 3.8 and above, following NEP 29.
44 44 When using Python 2.7, please install IPython 5.x LTS Long Term Support version.
45 45 Python 3.3 and 3.4 were supported up to IPython 6.x.
46 46 Python 3.5 was supported with IPython 7.0 to 7.9.
47 47 Python 3.6 was supported with IPython up to 7.16.
48 48 Python 3.7 was still supported with the 7.x branch.
49 49
50 50 See IPython `README.rst` file for more information:
51 51
52 52 https://github.com/ipython/ipython/blob/master/README.rst
53 53
54 54 Python {py} detected.
55 55 {pip}
56 56 """.format(py=sys.version_info, pip=pip_message )
57 57
58 58 print(error, file=sys.stderr)
59 59 sys.exit(1)
60 60
61 61 # At least we're on the python version we need, move on.
62 62
63 63 from setuptools import setup
64 64
65 65 # Our own imports
66 66 from setupbase import target_update
67 67
68 68 from setupbase import (
69 69 setup_args,
70 70 check_package_data_first,
71 71 find_data_files,
72 72 git_prebuild,
73 73 install_symlinked,
74 74 install_lib_symlink,
75 75 install_scripts_for_symlink,
76 76 unsymlink,
77 77 )
78 78
79 79 #-------------------------------------------------------------------------------
80 80 # Handle OS specific things
81 81 #-------------------------------------------------------------------------------
82 82
83 83 if os.name in ('nt','dos'):
84 84 os_name = 'windows'
85 85 else:
86 86 os_name = os.name
87 87
88 88 # Under Windows, 'sdist' has not been supported. Now that the docs build with
89 89 # Sphinx it might work, but let's not turn it on until someone confirms that it
90 90 # actually works.
91 91 if os_name == 'windows' and 'sdist' in sys.argv:
92 92 print('The sdist command is not available under Windows. Exiting.')
93 93 sys.exit(1)
94 94
95 95
96 96 #-------------------------------------------------------------------------------
97 97 # Things related to the IPython documentation
98 98 #-------------------------------------------------------------------------------
99 99
100 100 # update the manuals when building a source dist
101 101 if len(sys.argv) >= 2 and sys.argv[1] in ('sdist','bdist_rpm'):
102 102
103 103 # List of things to be updated. Each entry is a triplet of args for
104 104 # target_update()
105 105 to_update = [
106 106 (
107 107 "docs/man/ipython.1.gz",
108 108 ["docs/man/ipython.1"],
109 109 "cd docs/man && python -m gzip --best ipython.1",
110 110 ),
111 111 ]
112 112
113 113
114 114 [ target_update(*t) for t in to_update ]
115 115
116 116 #---------------------------------------------------------------------------
117 117 # Find all the packages, package data, and data_files
118 118 #---------------------------------------------------------------------------
119 119
120 120 data_files = find_data_files()
121 121
122 122 setup_args['data_files'] = data_files
123 123
124 124 #---------------------------------------------------------------------------
125 125 # custom distutils commands
126 126 #---------------------------------------------------------------------------
127 127 # imports here, so they are after setuptools import if there was one
128 128 from setuptools.command.sdist import sdist
129 129
130 130 setup_args['cmdclass'] = {
131 131 'build_py': \
132 132 check_package_data_first(git_prebuild('IPython')),
133 133 'sdist' : git_prebuild('IPython', sdist),
134 134 'symlink': install_symlinked,
135 135 'install_lib_symlink': install_lib_symlink,
136 136 'install_scripts_sym': install_scripts_for_symlink,
137 137 'unsymlink': unsymlink,
138 138 }
139 139
140 140
141 141 #---------------------------------------------------------------------------
142 142 # Handle scripts, dependencies, and setuptools specific things
143 143 #---------------------------------------------------------------------------
144 144
145 145 # setuptools requirements
146 146
147 147 extras_require = dict(
148 148 parallel=["ipyparallel"],
149 149 qtconsole=["qtconsole"],
150 150 doc=["Sphinx>=1.3"],
151 151 test=[
152 152 "pytest",
153 "pytest-asyncio",
153 154 "testpath",
154 155 "pygments",
155 156 ],
156 157 test_extra=[
157 158 "pytest",
158 159 "testpath",
159 160 "curio",
160 161 "matplotlib!=3.2.0",
161 162 "nbformat",
162 163 "numpy>=1.17",
163 164 "pandas",
164 165 "pygments",
165 166 "trio",
166 167 ],
167 168 terminal=[],
168 169 kernel=["ipykernel"],
169 170 nbformat=["nbformat"],
170 171 notebook=["notebook", "ipywidgets"],
171 172 nbconvert=["nbconvert"],
172 173 )
173 174
174 175 everything = set(chain.from_iterable(extras_require.values()))
175 176 extras_require['all'] = list(sorted(everything))
176 177
177 178 setup_args["extras_require"] = extras_require
178 179
179 180 #---------------------------------------------------------------------------
180 181 # Do the actual setup now
181 182 #---------------------------------------------------------------------------
182 183
183 184 if __name__ == "__main__":
184 185 setup(**setup_args)
General Comments 0
You need to be logged in to leave comments. Login now