2008-08-16 23:26:59 +08:00
|
|
|
=======
|
|
|
|
py.io
|
|
|
|
=======
|
|
|
|
|
|
|
|
|
|
|
|
The 'py' lib provides helper classes for capturing IO during
|
2010-07-27 03:15:15 +08:00
|
|
|
execution of a program.
|
2008-08-16 23:26:59 +08:00
|
|
|
|
|
|
|
IO Capturing examples
|
|
|
|
===============================================
|
|
|
|
|
2009-11-02 20:00:48 +08:00
|
|
|
``py.io.StdCapture``
|
2008-08-16 23:26:59 +08:00
|
|
|
---------------------------
|
|
|
|
|
2009-11-02 20:00:48 +08:00
|
|
|
Basic Example::
|
2008-08-16 23:26:59 +08:00
|
|
|
|
|
|
|
>>> import py
|
|
|
|
>>> capture = py.io.StdCapture()
|
|
|
|
>>> print "hello"
|
|
|
|
>>> out,err = capture.reset()
|
|
|
|
>>> out.strip() == "hello"
|
|
|
|
True
|
|
|
|
|
2010-07-27 03:15:15 +08:00
|
|
|
For calling functions you may use a shortcut::
|
2008-08-16 23:26:59 +08:00
|
|
|
|
|
|
|
>>> import py
|
|
|
|
>>> def f(): print "hello"
|
|
|
|
>>> res, out, err = py.io.StdCapture.call(f)
|
|
|
|
>>> out.strip() == "hello"
|
|
|
|
True
|
|
|
|
|
2009-11-02 20:00:48 +08:00
|
|
|
``py.io.StdCaptureFD``
|
2008-08-16 23:26:59 +08:00
|
|
|
---------------------------
|
|
|
|
|
|
|
|
If you also want to capture writes to the stdout/stderr
|
2009-11-02 20:00:48 +08:00
|
|
|
filedescriptors you may invoke::
|
2008-08-16 23:26:59 +08:00
|
|
|
|
|
|
|
>>> import py, sys
|
2009-11-02 20:00:48 +08:00
|
|
|
>>> capture = py.io.StdCaptureFD(out=False, in_=False)
|
2008-08-16 23:26:59 +08:00
|
|
|
>>> sys.stderr.write("world")
|
|
|
|
>>> out,err = capture.reset()
|
|
|
|
>>> err
|
|
|
|
'world'
|