##// END OF EJS Templates
Add test for writing non-ascii characters to file with %hist.
Thomas Kluyver -
Show More
@@ -1,144 +1,153 b''
1 1 # coding: utf-8
2 2 """Tests for the IPython tab-completion machinery.
3 3 """
4 4 #-----------------------------------------------------------------------------
5 5 # Module imports
6 6 #-----------------------------------------------------------------------------
7 7
8 8 # stdlib
9 9 import os
10 import shutil
10 11 import sys
11 12 import tempfile
12 13 import unittest
13 14 from datetime import datetime
14 15
15 16 # third party
16 17 import nose.tools as nt
17 18
18 19 # our own packages
19 20 from IPython.config.loader import Config
20 21 from IPython.utils.tempdir import TemporaryDirectory
21 22 from IPython.core.history import HistoryManager, extract_hist_ranges
22 23 from IPython.utils import py3compat
23 24
24 25 def setUp():
25 26 nt.assert_equal(sys.getdefaultencoding(), "utf-8" if py3compat.PY3 else "ascii")
26 27
27 28 def test_history():
28 29 ip = get_ipython()
29 30 with TemporaryDirectory() as tmpdir:
30 31 hist_manager_ori = ip.history_manager
31 32 hist_file = os.path.join(tmpdir, 'history.sqlite')
32 33 try:
33 34 ip.history_manager = HistoryManager(shell=ip, hist_file=hist_file)
34 35 hist = ['a=1', 'def f():\n test = 1\n return test', u"b='β‚¬Γ†ΒΎΓ·ΓŸ'"]
35 36 for i, h in enumerate(hist, start=1):
36 37 ip.history_manager.store_inputs(i, h)
37 38
38 39 ip.history_manager.db_log_output = True
39 40 # Doesn't match the input, but we'll just check it's stored.
40 41 ip.history_manager.output_hist_reprs[3] = "spam"
41 42 ip.history_manager.store_output(3)
42 43
43 44 nt.assert_equal(ip.history_manager.input_hist_raw, [''] + hist)
44 45
45 46 # Detailed tests for _get_range_session
46 47 grs = ip.history_manager._get_range_session
47 48 nt.assert_equal(list(grs(start=2,stop=-1)), zip([0], [2], hist[1:-1]))
48 49 nt.assert_equal(list(grs(start=-2)), zip([0,0], [2,3], hist[-2:]))
49 50 nt.assert_equal(list(grs(output=True)), zip([0,0,0], [1,2,3], zip(hist, [None,None,'spam'])))
50 51
51 52 # Check whether specifying a range beyond the end of the current
52 53 # session results in an error (gh-804)
53 54 ip.magic('%hist 2-500')
55
56 # Check that we can write non-ascii characters to a file
57 tmpdir = tempfile.mkdtemp()
58 try:
59 ip.magic("%%hist -f %s" % os.path.join(tmpdir, "test1"))
60 ip.magic("%%save %s 1-10" % os.path.join(tmpdir, "test2"))
61 finally:
62 shutil.rmtree(tmpdir)
54 63
55 64 # New session
56 65 ip.history_manager.reset()
57 66 newcmds = ["z=5","class X(object):\n pass", "k='p'"]
58 67 for i, cmd in enumerate(newcmds, start=1):
59 68 ip.history_manager.store_inputs(i, cmd)
60 69 gothist = ip.history_manager.get_range(start=1, stop=4)
61 70 nt.assert_equal(list(gothist), zip([0,0,0],[1,2,3], newcmds))
62 71 # Previous session:
63 72 gothist = ip.history_manager.get_range(-1, 1, 4)
64 73 nt.assert_equal(list(gothist), zip([1,1,1],[1,2,3], hist))
65 74
66 75 # Check get_hist_tail
67 76 gothist = ip.history_manager.get_tail(4, output=True,
68 77 include_latest=True)
69 78 expected = [(1, 3, (hist[-1], "spam")),
70 79 (2, 1, (newcmds[0], None)),
71 80 (2, 2, (newcmds[1], None)),
72 81 (2, 3, (newcmds[2], None)),]
73 82 nt.assert_equal(list(gothist), expected)
74 83
75 84 gothist = ip.history_manager.get_tail(2)
76 85 expected = [(2, 1, newcmds[0]),
77 86 (2, 2, newcmds[1])]
78 87 nt.assert_equal(list(gothist), expected)
79 88
80 89 # Check get_hist_search
81 90 gothist = ip.history_manager.search("*test*")
82 91 nt.assert_equal(list(gothist), [(1,2,hist[1])] )
83 92 gothist = ip.history_manager.search("b*", output=True)
84 93 nt.assert_equal(list(gothist), [(1,3,(hist[2],"spam"))] )
85 94
86 95 # Cross testing: check that magic %save can get previous session.
87 96 testfilename = os.path.realpath(os.path.join(tmpdir, "test.py"))
88 97 ip.magic_save(testfilename + " ~1/1-3")
89 98 with py3compat.open(testfilename) as testfile:
90 99 nt.assert_equal(testfile.read(),
91 100 u"# coding: utf-8\n" + u"\n".join(hist))
92 101
93 102 # Duplicate line numbers - check that it doesn't crash, and
94 103 # gets a new session
95 104 ip.history_manager.store_inputs(1, "rogue")
96 105 ip.history_manager.writeout_cache()
97 106 nt.assert_equal(ip.history_manager.session_number, 3)
98 107 finally:
99 108 # Restore history manager
100 109 ip.history_manager = hist_manager_ori
101 110
102 111
103 112 def test_extract_hist_ranges():
104 113 instr = "1 2/3 ~4/5-6 ~4/7-~4/9 ~9/2-~7/5"
105 114 expected = [(0, 1, 2), # 0 == current session
106 115 (2, 3, 4),
107 116 (-4, 5, 7),
108 117 (-4, 7, 10),
109 118 (-9, 2, None), # None == to end
110 119 (-8, 1, None),
111 120 (-7, 1, 6)]
112 121 actual = list(extract_hist_ranges(instr))
113 122 nt.assert_equal(actual, expected)
114 123
115 124 def test_magic_rerun():
116 125 """Simple test for %rerun (no args -> rerun last line)"""
117 126 ip = get_ipython()
118 127 ip.run_cell("a = 10", store_history=True)
119 128 ip.run_cell("a += 1", store_history=True)
120 129 nt.assert_equal(ip.user_ns["a"], 11)
121 130 ip.run_cell("%rerun", store_history=True)
122 131 nt.assert_equal(ip.user_ns["a"], 12)
123 132
124 133 def test_timestamp_type():
125 134 ip = get_ipython()
126 135 info = ip.history_manager.get_session_info()
127 136 nt.assert_true(isinstance(info[1], datetime))
128 137
129 138 def test_hist_file_config():
130 139 cfg = Config()
131 140 tfile = tempfile.NamedTemporaryFile(delete=False)
132 141 cfg.HistoryManager.hist_file = tfile.name
133 142 try:
134 143 hm = HistoryManager(shell=get_ipython(), config=cfg)
135 144 nt.assert_equals(hm.hist_file, cfg.HistoryManager.hist_file)
136 145 finally:
137 146 try:
138 147 os.remove(tfile.name)
139 148 except OSError:
140 149 # same catch as in testing.tools.TempFileMixin
141 150 # On Windows, even though we close the file, we still can't
142 151 # delete it. I have no clue why
143 152 pass
144 153
General Comments 0
You need to be logged in to leave comments. Login now