##// END OF EJS Templates
Autoclose stdin/err for bg scripts, when not assigned to user_ns...
Matthias Bussonnier -
Show More
@@ -31,14 +31,14 b' def script_args(f):'
31 31 '--out', type=str,
32 32 help="""The variable in which to store stdout from the script.
33 33 If the script is backgrounded, this will be the stdout *pipe*,
34 instead of the stderr text itself.
34 instead of the stderr text itself and will not be auto closed.
35 35 """
36 36 ),
37 37 magic_arguments.argument(
38 38 '--err', type=str,
39 39 help="""The variable in which to store stderr from the script.
40 40 If the script is backgrounded, this will be the stderr *pipe*,
41 instead of the stderr text itself.
41 instead of the stderr text itself and will not be autoclosed.
42 42 """
43 43 ),
44 44 magic_arguments.argument(
@@ -187,11 +187,16 b' class ScriptMagics(Magics):'
187 187 if args.bg:
188 188 self.bg_processes.append(p)
189 189 self._gc_bg_processes()
190 to_close = []
190 191 if args.out:
191 192 self.shell.user_ns[args.out] = p.stdout
193 else:
194 to_close.append(p.stdout)
192 195 if args.err:
193 196 self.shell.user_ns[args.err] = p.stderr
194 self.job_manager.new(self._run_script, p, cell, daemon=True)
197 else:
198 to_close.append(p.stderr)
199 self.job_manager.new(self._run_script, p, cell, to_close, daemon=True)
195 200 if args.proc:
196 201 self.shell.user_ns[args.proc] = p
197 202 return
@@ -231,10 +236,12 b' class ScriptMagics(Magics):'
231 236 sys.stderr.write(err)
232 237 sys.stderr.flush()
233 238
234 def _run_script(self, p, cell):
239 def _run_script(self, p, cell, to_close):
235 240 """callback for running the script in the background"""
236 241 p.stdin.write(cell)
237 242 p.stdin.close()
243 for s in to_close:
244 s.close()
238 245 p.wait()
239 246
240 247 @line_magic("killbgscripts")
@@ -562,17 +562,6 b' def test_timeit_shlex():'
562 562 _ip.magic('timeit -r1 -n1 f("a " + "b ")')
563 563
564 564
565 def test_timeit_arguments():
566 "Test valid timeit arguments, should not cause SyntaxError (GH #1269)"
567 if sys.version_info < (3,7):
568 _ip.magic("timeit ('#')")
569 else:
570 # 3.7 optimize no-op statement like above out, and complain there is
571 # nothing in the for loop.
572 _ip.magic("timeit a=('#')")
573
574
575
576 565 def test_timeit_special_syntax():
577 566 "Test %%timeit with IPython special syntax"
578 567 @register_line_magic
@@ -839,13 +828,16 b' def test_script_out_err():'
839 828 def test_script_bg_out():
840 829 ip = get_ipython()
841 830 ip.run_cell_magic("script", "--bg --out output sh", "echo 'hi'")
831
842 832 nt.assert_equal(ip.user_ns['output'].read(), b'hi\n')
833 ip.user_ns['output'].close()
843 834
844 835 @dec.skip_win32
845 836 def test_script_bg_err():
846 837 ip = get_ipython()
847 838 ip.run_cell_magic("script", "--bg --err error sh", "echo 'hello' >&2")
848 839 nt.assert_equal(ip.user_ns['error'].read(), b'hello\n')
840 ip.user_ns['error'].close()
849 841
850 842 @dec.skip_win32
851 843 def test_script_bg_out_err():
@@ -853,6 +845,8 b' def test_script_bg_out_err():'
853 845 ip.run_cell_magic("script", "--bg --out output --err error sh", "echo 'hi'\necho 'hello' >&2")
854 846 nt.assert_equal(ip.user_ns['output'].read(), b'hi\n')
855 847 nt.assert_equal(ip.user_ns['error'].read(), b'hello\n')
848 ip.user_ns['output'].close()
849 ip.user_ns['error'].close()
856 850
857 851 def test_script_defaults():
858 852 ip = get_ipython()
@@ -1072,4 +1066,15 b' def test_logging_magic_not_quiet():'
1072 1066 lm.logstart(os.path.join(td, "not_quiet.log"))
1073 1067 finally:
1074 1068 _ip.logger.logstop()
1075
1069
1070 ##
1071 # this is slow, put at the end for local testing.
1072 ##
1073 def test_timeit_arguments():
1074 "Test valid timeit arguments, should not cause SyntaxError (GH #1269)"
1075 if sys.version_info < (3,7):
1076 _ip.magic("timeit ('#')")
1077 else:
1078 # 3.7 optimize no-op statement like above out, and complain there is
1079 # nothing in the for loop.
1080 _ip.magic("timeit a=('#')")
General Comments 0
You need to be logged in to leave comments. Login now