##// END OF EJS Templates
make hiding of initial namespace optional...
make hiding of initial namespace optional It is by design that names loaded by startup files, etc. are hidden from things like `%who`. But this behavior is pretty surprising, especially since ipython -i script.py and %run -i script.py have different behaviors with respect to the hidden namespace. Since the current behavior was added at the request of @fperez, I left the default behavior unchanged, but added a flag to disable hiding initial variables.

File last commit:

r7115:a8a64ebc
r13616:680d854b
Show More
test_logger.py
32 lines | 917 B | text/x-python | PythonLexer
# -*- coding: utf-8 -*-
"""Test IPython.core.logger"""
import os.path
import nose.tools as nt
from IPython.utils.tempdir import TemporaryDirectory
_ip = get_ipython()
def test_logstart_inaccessible_file():
try:
_ip.logger.logstart(logfname="/") # Opening that filename will fail.
except IOError:
pass
else:
nt.assert_true(False) # The try block should never pass.
try:
_ip.run_cell("a=1") # Check it doesn't try to log this
finally:
_ip.logger.log_active = False # If this fails, don't let later tests fail
def test_logstart_unicode():
with TemporaryDirectory() as tdir:
logfname = os.path.join(tdir, "test_unicode.log")
_ip.run_cell("'abc€'")
try:
_ip.magic("logstart -to %s" % logfname)
_ip.run_cell("'abc€'")
finally:
_ip.logger.logstop()