##// END OF EJS Templates
Merge pull request #13329 from Kojoley/ipdoctest-cleanup...
Matthias Bussonnier -
r27160:335a1eb2 merge
parent child Browse files
Show More
@@ -80,18 +80,6 b' class IPDoctestOutputChecker(doctest.OutputChecker):'
80 80 class IPExample(doctest.Example): pass
81 81
82 82
83 class IPExternalExample(doctest.Example):
84 """Doctest examples to be run in an external process."""
85
86 def __init__(self, source, want, exc_msg=None, lineno=0, indent=0,
87 options=None):
88 # Parent constructor
89 doctest.Example.__init__(self,source,want,exc_msg,lineno,indent,options)
90
91 # An EXTRA newline is needed to prevent pexpect hangs
92 self.source += '\n'
93
94
95 83 class IPDocTestParser(doctest.DocTestParser):
96 84 """
97 85 A class used to parse strings containing doctest examples.
@@ -137,9 +125,6 b' class IPDocTestParser(doctest.DocTestParser):'
137 125 # we don't need to modify any other code.
138 126 _RANDOM_TEST = re.compile(r'#\s*all-random\s+')
139 127
140 # Mark tests to be executed in an external process - currently unsupported.
141 _EXTERNAL_IP = re.compile(r'#\s*ipdoctest:\s*EXTERNAL')
142
143 128 def ip2py(self,source):
144 129 """Convert input IPython source into valid Python."""
145 130 block = _ip.input_transformer_manager.transform_cell(source)
@@ -182,25 +167,10 b' class IPDocTestParser(doctest.DocTestParser):'
182 167 terms = list(self._EXAMPLE_RE_PY.finditer(string))
183 168 if terms:
184 169 # Normal Python example
185 #print '-'*70 # dbg
186 #print 'PyExample, Source:\n',string # dbg
187 #print '-'*70 # dbg
188 170 Example = doctest.Example
189 171 else:
190 # It's an ipython example. Note that IPExamples are run
191 # in-process, so their syntax must be turned into valid python.
192 # IPExternalExamples are run out-of-process (via pexpect) so they
193 # don't need any filtering (a real ipython will be executing them).
172 # It's an ipython example.
194 173 terms = list(self._EXAMPLE_RE_IP.finditer(string))
195 if self._EXTERNAL_IP.search(string):
196 #print '-'*70 # dbg
197 #print 'IPExternalExample, Source:\n',string # dbg
198 #print '-'*70 # dbg
199 Example = IPExternalExample
200 else:
201 #print '-'*70 # dbg
202 #print 'IPExample, Source:\n',string # dbg
203 #print '-'*70 # dbg
204 174 Example = IPExample
205 175 ip2py = True
206 176
@@ -217,10 +187,6 b' class IPDocTestParser(doctest.DocTestParser):'
217 187 # cases, it's only non-empty for 'all-random' tests):
218 188 want += random_marker
219 189
220 if Example is IPExternalExample:
221 options[doctest.NORMALIZE_WHITESPACE] = True
222 want += '\n'
223
224 190 # Create an Example, and add it to the list.
225 191 if not self._IS_BLANK_OR_COMMENT(source):
226 192 output.append(Example(source, want, exc_msg,
@@ -328,18 +294,6 b' class IPDocTestRunner(doctest.DocTestRunner,object):'
328 294 """
329 295
330 296 def run(self, test, compileflags=None, out=None, clear_globs=True):
331
332 # Hack: ipython needs access to the execution context of the example,
333 # so that it can propagate user variables loaded by %run into
334 # test.globs. We put them here into our modified %run as a function
335 # attribute. Our new %run will then only make the namespace update
336 # when called (rather than unconditionally updating test.globs here
337 # for all examples, most of which won't be calling %run anyway).
338 #_ip._ipdoctest_test_globs = test.globs
339 #_ip._ipdoctest_test_filename = test.filename
340
341 test.globs.update(_ip.user_ns)
342
343 297 # Override terminal size to standardise traceback format
344 298 with modified_env({'COLUMNS': '80', 'LINES': '24'}):
345 299 return super(IPDocTestRunner,self).run(test,
@@ -1,7 +1,7 b''
1 1 """Simple example using doctests.
2 2
3 3 This file just contains doctests both using plain python and IPython prompts.
4 All tests should be loaded by nose.
4 All tests should be loaded by Pytest.
5 5 """
6 6
7 7 def pyfunc():
@@ -24,10 +24,21 b' def pyfunc():'
24 24 return 'pyfunc'
25 25
26 26
27 def ipyfunc2():
28 """Some pure python tests...
27 def ipyfunc():
28 """Some IPython tests...
29
30 In [1]: ipyfunc()
31 Out[1]: 'ipyfunc'
32
33 In [2]: import os
34
35 In [3]: 2+3
36 Out[3]: 5
29 37
30 >>> 1+1
31 2
38 In [4]: for i in range(3):
39 ...: print(i, end=' ')
40 ...: print(i+1, end=' ')
41 ...:
42 Out[4]: 0 1 1 2 2 3
32 43 """
33 return 'pyfunc2'
44 return "ipyfunc"
General Comments 0
You need to be logged in to leave comments. Login now