Show More
@@ -24,7 +24,7 b' import nose.tools as nt' | |||
|
24 | 24 | from IPython.kernel import KernelManager |
|
25 | 25 | from IPython.kernel.tests.test_message_spec import execute, flush_channels |
|
26 | 26 | from IPython.testing import decorators as dec |
|
27 | from IPython.utils import path | |
|
27 | from IPython.utils import path, py3compat | |
|
28 | 28 | |
|
29 | 29 | #------------------------------------------------------------------------------- |
|
30 | 30 | # Tests |
@@ -33,6 +33,9 b' IPYTHONDIR = None' | |||
|
33 | 33 | save_env = None |
|
34 | 34 | save_get_ipython_dir = None |
|
35 | 35 | |
|
36 | STARTUP_TIMEOUT = 60 | |
|
37 | TIMEOUT = 15 | |
|
38 | ||
|
36 | 39 | def setup(): |
|
37 | 40 | """setup temporary IPYTHONDIR for tests""" |
|
38 | 41 | global IPYTHONDIR |
@@ -75,7 +78,7 b' def new_kernel():' | |||
|
75 | 78 | |
|
76 | 79 | # wait for kernel to be ready |
|
77 | 80 | KC.shell_channel.execute("import sys") |
|
78 |
KC.shell_channel.get_msg(block=True, timeout= |
|
|
81 | KC.shell_channel.get_msg(block=True, timeout=STARTUP_TIMEOUT) | |
|
79 | 82 | flush_channels(KC) |
|
80 | 83 | try: |
|
81 | 84 | yield KC |
@@ -116,6 +119,8 b' def _check_mp_mode(kc, expected=False, stream="stdout"):' | |||
|
116 | 119 | nt.assert_equal(eval(stdout.strip()), expected) |
|
117 | 120 | |
|
118 | 121 | |
|
122 | # printing tests | |
|
123 | ||
|
119 | 124 | def test_simple_print(): |
|
120 | 125 | """simple print statement in kernel""" |
|
121 | 126 | with new_kernel() as kc: |
@@ -125,7 +130,6 b' def test_simple_print():' | |||
|
125 | 130 | nt.assert_equal(stdout, 'hi\n') |
|
126 | 131 | nt.assert_equal(stderr, '') |
|
127 | 132 | _check_mp_mode(kc, expected=False) |
|
128 | print ('hello') | |
|
129 | 133 | |
|
130 | 134 | |
|
131 | 135 | @dec.knownfailureif(sys.platform == 'win32', "subprocess prints fail on Windows") |
@@ -201,3 +205,47 b' def test_subprocess_error():' | |||
|
201 | 205 | |
|
202 | 206 | _check_mp_mode(kc, expected=False) |
|
203 | 207 | _check_mp_mode(kc, expected=False, stream="stderr") |
|
208 | ||
|
209 | ||
|
210 | # raw_input tests | |
|
211 | ||
|
212 | def test_raw_input(): | |
|
213 | """test [raw_]input""" | |
|
214 | with new_kernel() as kc: | |
|
215 | iopub = kc.iopub_channel | |
|
216 | ||
|
217 | input_f = "input" if py3compat.PY3 else "raw_input" | |
|
218 | theprompt = "prompt> " | |
|
219 | code = 'print({input_f}("{theprompt}"))'.format(**locals()) | |
|
220 | msg_id = kc.execute(code, allow_stdin=True) | |
|
221 | msg = kc.get_stdin_msg(block=True, timeout=TIMEOUT) | |
|
222 | nt.assert_equal(msg['header']['msg_type'], u'input_request') | |
|
223 | content = msg['content'] | |
|
224 | nt.assert_equal(content['prompt'], theprompt) | |
|
225 | text = "some text" | |
|
226 | kc.input(text) | |
|
227 | reply = kc.get_shell_msg(block=True, timeout=TIMEOUT) | |
|
228 | nt.assert_equal(reply['content']['status'], 'ok') | |
|
229 | stdout, stderr = assemble_output(iopub) | |
|
230 | nt.assert_equal(stdout, text + "\n") | |
|
231 | ||
|
232 | ||
|
233 | @dec.skipif(py3compat.PY3) | |
|
234 | def test_eval_input(): | |
|
235 | """test input() on Python 2""" | |
|
236 | with new_kernel() as kc: | |
|
237 | iopub = kc.iopub_channel | |
|
238 | ||
|
239 | input_f = "input" if py3compat.PY3 else "raw_input" | |
|
240 | theprompt = "prompt> " | |
|
241 | code = 'print(input("{theprompt}"))'.format(**locals()) | |
|
242 | msg_id = kc.execute(code, allow_stdin=True) | |
|
243 | msg = kc.get_stdin_msg(block=True, timeout=TIMEOUT) | |
|
244 | nt.assert_equal(msg['header']['msg_type'], u'input_request') | |
|
245 | content = msg['content'] | |
|
246 | nt.assert_equal(content['prompt'], theprompt) | |
|
247 | kc.input("1+1") | |
|
248 | reply = kc.get_shell_msg(block=True, timeout=TIMEOUT) | |
|
249 | nt.assert_equal(reply['content']['status'], 'ok') | |
|
250 | stdout, stderr = assemble_output(iopub) | |
|
251 | nt.assert_equal(stdout, "2\n") |
@@ -131,6 +131,7 b' class Kernel(Configurable):' | |||
|
131 | 131 | # A reference to the Python builtin 'raw_input' function. |
|
132 | 132 | # (i.e., __builtin__.raw_input for Python 2.7, builtins.input for Python 3) |
|
133 | 133 | _sys_raw_input = Any() |
|
134 | _sys_eval_input = Any() | |
|
134 | 135 | |
|
135 | 136 | # set of aborted msg_ids |
|
136 | 137 | aborted = Set() |
@@ -352,15 +353,18 b' class Kernel(Configurable):' | |||
|
352 | 353 | # raw_input in the user namespace. |
|
353 | 354 | if content.get('allow_stdin', False): |
|
354 | 355 | raw_input = lambda prompt='': self._raw_input(prompt, ident, parent) |
|
356 | input = lambda prompt='': eval(raw_input(prompt)) | |
|
355 | 357 | else: |
|
356 | raw_input = lambda prompt='' : self._no_raw_input() | |
|
358 | raw_input = input = lambda prompt='' : self._no_raw_input() | |
|
357 | 359 | |
|
358 | 360 | if py3compat.PY3: |
|
359 | 361 | self._sys_raw_input = __builtin__.input |
|
360 | 362 | __builtin__.input = raw_input |
|
361 | 363 | else: |
|
362 | 364 | self._sys_raw_input = __builtin__.raw_input |
|
365 | self._sys_eval_input = __builtin__.input | |
|
363 | 366 | __builtin__.raw_input = raw_input |
|
367 | __builtin__.input = input | |
|
364 | 368 | |
|
365 | 369 | # Set the parent message of the display hook and out streams. |
|
366 | 370 | shell.displayhook.set_parent(parent) |
@@ -403,6 +407,7 b' class Kernel(Configurable):' | |||
|
403 | 407 | __builtin__.input = self._sys_raw_input |
|
404 | 408 | else: |
|
405 | 409 | __builtin__.raw_input = self._sys_raw_input |
|
410 | __builtin__.input = self._sys_eval_input | |
|
406 | 411 | |
|
407 | 412 | reply_content[u'status'] = status |
|
408 | 413 |
@@ -1,6 +1,6 b'' | |||
|
1 | 1 | { |
|
2 | 2 | "metadata": { |
|
3 | "name": "Frontend-Kernel Model" | |
|
3 | "name": "" | |
|
4 | 4 | }, |
|
5 | 5 | "nbformat": 3, |
|
6 | 6 | "nbformat_minor": 0, |
@@ -152,6 +152,21 b'' | |||
|
152 | 152 | "cell_type": "code", |
|
153 | 153 | "collapsed": false, |
|
154 | 154 | "input": [ |
|
155 | "# Python 3 compat\n", | |
|
156 | "try:\n", | |
|
157 | " raw_input\n", | |
|
158 | "except NameError:\n", | |
|
159 | " raw_input = input" | |
|
160 | ], | |
|
161 | "language": "python", | |
|
162 | "metadata": {}, | |
|
163 | "outputs": [], | |
|
164 | "prompt_number": 1 | |
|
165 | }, | |
|
166 | { | |
|
167 | "cell_type": "code", | |
|
168 | "collapsed": false, | |
|
169 | "input": [ | |
|
155 | 170 | "name = raw_input(\"What is your name? \")\n", |
|
156 | 171 | "name" |
|
157 | 172 | ], |
@@ -169,13 +184,49 b'' | |||
|
169 | 184 | { |
|
170 | 185 | "metadata": {}, |
|
171 | 186 | "output_type": "pyout", |
|
172 |
"prompt_number": |
|
|
187 | "prompt_number": 2, | |
|
173 | 188 | "text": [ |
|
174 |
" |
|
|
189 | "'Sir Robin'" | |
|
175 | 190 | ] |
|
176 | 191 | } |
|
177 | 192 | ], |
|
178 |
"prompt_number": |
|
|
193 | "prompt_number": 2 | |
|
194 | }, | |
|
195 | { | |
|
196 | "cell_type": "markdown", | |
|
197 | "metadata": {}, | |
|
198 | "source": [ | |
|
199 | "**Python 2-only**: the eval input works as well (`input` is just `eval(raw_input(prompt))`)" | |
|
200 | ] | |
|
201 | }, | |
|
202 | { | |
|
203 | "cell_type": "code", | |
|
204 | "collapsed": false, | |
|
205 | "input": [ | |
|
206 | "fingers = input(\"How many fingers? \")\n", | |
|
207 | "fingers, type(fingers)" | |
|
208 | ], | |
|
209 | "language": "python", | |
|
210 | "metadata": {}, | |
|
211 | "outputs": [ | |
|
212 | { | |
|
213 | "name": "stdout", | |
|
214 | "output_type": "stream", | |
|
215 | "stream": "stdout", | |
|
216 | "text": [ | |
|
217 | "How many fingers? 4\n" | |
|
218 | ] | |
|
219 | }, | |
|
220 | { | |
|
221 | "metadata": {}, | |
|
222 | "output_type": "pyout", | |
|
223 | "prompt_number": 3, | |
|
224 | "text": [ | |
|
225 | "(4, int)" | |
|
226 | ] | |
|
227 | } | |
|
228 | ], | |
|
229 | "prompt_number": 3 | |
|
179 | 230 | }, |
|
180 | 231 | { |
|
181 | 232 | "cell_type": "code", |
@@ -195,13 +246,13 b'' | |||
|
195 | 246 | "output_type": "pyerr", |
|
196 | 247 | "traceback": [ |
|
197 | 248 | "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m\n\u001b[1;31mZeroDivisionError\u001b[0m Traceback (most recent call last)", |
|
198 |
"\u001b[1;32m<ipython-input- |
|
|
199 |
"\u001b[1;32m<ipython-input- |
|
|
249 | "\u001b[1;32m<ipython-input-4-a5097cc0c0c5>\u001b[0m in \u001b[0;36m<module>\u001b[1;34m()\u001b[0m\n\u001b[0;32m 2\u001b[0m \u001b[1;32mreturn\u001b[0m \u001b[0mx\u001b[0m\u001b[1;33m/\u001b[0m\u001b[0my\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m 3\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m----> 4\u001b[1;33m \u001b[0mdiv\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;36m1\u001b[0m\u001b[1;33m,\u001b[0m\u001b[1;36m0\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m", | |
|
250 | "\u001b[1;32m<ipython-input-4-a5097cc0c0c5>\u001b[0m in \u001b[0;36mdiv\u001b[1;34m(x, y)\u001b[0m\n\u001b[0;32m 1\u001b[0m \u001b[1;32mdef\u001b[0m \u001b[0mdiv\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mx\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0my\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m----> 2\u001b[1;33m \u001b[1;32mreturn\u001b[0m \u001b[0mx\u001b[0m\u001b[1;33m/\u001b[0m\u001b[0my\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m 3\u001b[0m \u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m 4\u001b[0m \u001b[0mdiv\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;36m1\u001b[0m\u001b[1;33m,\u001b[0m\u001b[1;36m0\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n", | |
|
200 | 251 | "\u001b[1;31mZeroDivisionError\u001b[0m: integer division or modulo by zero" |
|
201 | 252 | ] |
|
202 | 253 | } |
|
203 | 254 | ], |
|
204 |
"prompt_number": |
|
|
255 | "prompt_number": 4 | |
|
205 | 256 | }, |
|
206 | 257 | { |
|
207 | 258 | "cell_type": "code", |
@@ -216,7 +267,7 b'' | |||
|
216 | 267 | "output_type": "stream", |
|
217 | 268 | "stream": "stdout", |
|
218 | 269 | "text": [ |
|
219 |
"> \u001b[1;32m<ipython-input- |
|
|
270 | "> \u001b[1;32m<ipython-input-4-a5097cc0c0c5>\u001b[0m(2)\u001b[0;36mdiv\u001b[1;34m()\u001b[0m\n", | |
|
220 | 271 | "\u001b[1;32m 1 \u001b[1;33m\u001b[1;32mdef\u001b[0m \u001b[0mdiv\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mx\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0my\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n", |
|
221 | 272 | "\u001b[0m\u001b[1;32m----> 2 \u001b[1;33m \u001b[1;32mreturn\u001b[0m \u001b[0mx\u001b[0m\u001b[1;33m/\u001b[0m\u001b[0my\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n", |
|
222 | 273 | "\u001b[0m\u001b[1;32m 3 \u001b[1;33m\u001b[1;33m\u001b[0m\u001b[0m\n", |
@@ -262,7 +313,7 b'' | |||
|
262 | 313 | ] |
|
263 | 314 | } |
|
264 | 315 | ], |
|
265 |
"prompt_number": |
|
|
316 | "prompt_number": 5 | |
|
266 | 317 | } |
|
267 | 318 | ], |
|
268 | 319 | "metadata": {} |
General Comments 0
You need to be logged in to leave comments.
Login now