##// END OF EJS Templates
Merge pull request #10030 from takluyver/i10028...
Matthias Bussonnier -
r22986:51cf0cd8 merge
parent child Browse files
Show More
@@ -816,6 +816,11 b' python-profiler package from non-free.""")'
816 self.shell.InteractiveTB.pdb = self.shell.InteractiveTB.debugger_cls()
816 self.shell.InteractiveTB.pdb = self.shell.InteractiveTB.debugger_cls()
817 deb = self.shell.InteractiveTB.pdb
817 deb = self.shell.InteractiveTB.pdb
818
818
819 # deb.checkline() fails if deb.curframe exists but is None; it can
820 # handle it not existing. https://github.com/ipython/ipython/issues/10028
821 if hasattr(deb, 'curframe'):
822 del deb.curframe
823
819 # reset Breakpoint state, which is moronically kept
824 # reset Breakpoint state, which is moronically kept
820 # in a class
825 # in a class
821 bdb.Breakpoint.next = 1
826 bdb.Breakpoint.next = 1
@@ -207,9 +207,16 b' class TestMagicRunPass(tt.TempFileMixin):'
207 def test_run_profile( self ):
207 def test_run_profile( self ):
208 """Test that the option -p, which invokes the profiler, do not
208 """Test that the option -p, which invokes the profiler, do not
209 crash by invoking execfile"""
209 crash by invoking execfile"""
210 get_ipython()
211 self.run_tmpfile_p()
210 self.run_tmpfile_p()
212
211
212 def test_run_debug_twice(self):
213 # https://github.com/ipython/ipython/issues/10028
214 _ip = get_ipython()
215 with tt.fake_input(['c']):
216 _ip.magic('run -d %s' % self.fname)
217 with tt.fake_input(['c']):
218 _ip.magic('run -d %s' % self.fname)
219
213
220
214 class TestMagicRunSimple(tt.TempFileMixin):
221 class TestMagicRunSimple(tt.TempFileMixin):
215
222
@@ -6,16 +6,8 b' Authors'
6 """
6 """
7
7
8
8
9 #-----------------------------------------------------------------------------
9 # Copyright (c) IPython Development Team.
10 # Copyright (C) 2009 The IPython Development Team
10 # Distributed under the terms of the Modified BSD License.
11 #
12 # Distributed under the terms of the BSD License. The full license is in
13 # the file COPYING, distributed as part of this software.
14 #-----------------------------------------------------------------------------
15
16 #-----------------------------------------------------------------------------
17 # Imports
18 #-----------------------------------------------------------------------------
19
11
20 import os
12 import os
21 import re
13 import re
@@ -25,6 +17,7 b' import tempfile'
25 from contextlib import contextmanager
17 from contextlib import contextmanager
26 from io import StringIO
18 from io import StringIO
27 from subprocess import Popen, PIPE
19 from subprocess import Popen, PIPE
20 from unittest.mock import patch
28
21
29 try:
22 try:
30 # These tools are used by parts of the runtime, so we make the nose
23 # These tools are used by parts of the runtime, so we make the nose
@@ -45,9 +38,6 b' from IPython.utils.encoding import DEFAULT_ENCODING'
45 from . import decorators as dec
38 from . import decorators as dec
46 from . import skipdoctest
39 from . import skipdoctest
47
40
48 #-----------------------------------------------------------------------------
49 # Functions and classes
50 #-----------------------------------------------------------------------------
51
41
52 # The docstring for full_path doctests differently on win32 (different path
42 # The docstring for full_path doctests differently on win32 (different path
53 # separator) so just skip the doctest there. The example remains informative.
43 # separator) so just skip the doctest there. The example remains informative.
@@ -443,6 +433,25 b' def make_tempfile(name):'
443 finally:
433 finally:
444 os.unlink(name)
434 os.unlink(name)
445
435
436 def fake_input(inputs):
437 """Temporarily replace the input() function to return the given values
438
439 Use as a context manager:
440
441 with fake_input(['result1', 'result2']):
442 ...
443
444 Values are returned in order. If input() is called again after the last value
445 was used, EOFError is raised.
446 """
447 it = iter(inputs)
448 def mock_input(prompt=''):
449 try:
450 return next(it)
451 except StopIteration:
452 raise EOFError('No more inputs given')
453
454 return patch('builtins.input', mock_input)
446
455
447 def help_output_test(subcommand=''):
456 def help_output_test(subcommand=''):
448 """test that `ipython [subcommand] -h` works"""
457 """test that `ipython [subcommand] -h` works"""
General Comments 0
You need to be logged in to leave comments. Login now