blob: dd8981f8935b96a3462245fc2bb67478388a72e4 [file] [log] [blame]
Christian Heimesd8654cf2007-12-02 15:22:16 +00001"""
2Test script for the 'cmd' module
3Original by Michael Schneider
4"""
5
6
Christian Heimesd8654cf2007-12-02 15:22:16 +00007import cmd
8import sys
Christian Heimes2137b6a2007-12-02 16:50:20 +00009import re
R. David Murray7905d612010-08-01 03:31:09 +000010import unittest
11import io
Victor Stinner45df8202010-04-28 22:31:17 +000012from test import support
Christian Heimesd8654cf2007-12-02 15:22:16 +000013
14class samplecmdclass(cmd.Cmd):
15 """
16 Instance the sampleclass:
17 >>> mycmd = samplecmdclass()
18
19 Test for the function parseline():
20 >>> mycmd.parseline("")
21 (None, None, '')
22 >>> mycmd.parseline("?")
23 ('help', '', 'help ')
24 >>> mycmd.parseline("?help")
25 ('help', 'help', 'help help')
26 >>> mycmd.parseline("!")
27 ('shell', '', 'shell ')
28 >>> mycmd.parseline("!command")
29 ('shell', 'command', 'shell command')
30 >>> mycmd.parseline("func")
31 ('func', '', 'func')
32 >>> mycmd.parseline("func arg1")
33 ('func', 'arg1', 'func arg1')
34
35
36 Test for the function onecmd():
37 >>> mycmd.onecmd("")
38 >>> mycmd.onecmd("add 4 5")
39 9
40 >>> mycmd.onecmd("")
41 9
42 >>> mycmd.onecmd("test")
43 *** Unknown syntax: test
44
45 Test for the function emptyline():
46 >>> mycmd.emptyline()
47 *** Unknown syntax: test
48
49 Test for the function default():
50 >>> mycmd.default("default")
51 *** Unknown syntax: default
52
53 Test for the function completedefault():
54 >>> mycmd.completedefault()
55 This is the completedefault methode
56 >>> mycmd.completenames("a")
57 ['add']
58
59 Test for the function completenames():
60 >>> mycmd.completenames("12")
61 []
62 >>> mycmd.completenames("help")
Benjamin Petersona28e7022010-01-09 18:53:06 +000063 ['help']
Christian Heimesd8654cf2007-12-02 15:22:16 +000064
65 Test for the function complete_help():
66 >>> mycmd.complete_help("a")
67 ['add']
68 >>> mycmd.complete_help("he")
Benjamin Petersona28e7022010-01-09 18:53:06 +000069 ['help']
Christian Heimesd8654cf2007-12-02 15:22:16 +000070 >>> mycmd.complete_help("12")
71 []
Benjamin Petersona28e7022010-01-09 18:53:06 +000072 >>> sorted(mycmd.complete_help(""))
73 ['add', 'exit', 'help', 'shell']
Christian Heimesd8654cf2007-12-02 15:22:16 +000074
75 Test for the function do_help():
76 >>> mycmd.do_help("testet")
77 *** No help on testet
78 >>> mycmd.do_help("add")
79 help text for add
80 >>> mycmd.onecmd("help add")
81 help text for add
82 >>> mycmd.do_help("")
83 <BLANKLINE>
84 Documented commands (type help <topic>):
85 ========================================
Raymond Hettinger44d7b6a2010-09-09 03:53:22 +000086 add help
Christian Heimesd8654cf2007-12-02 15:22:16 +000087 <BLANKLINE>
88 Undocumented commands:
89 ======================
Raymond Hettinger44d7b6a2010-09-09 03:53:22 +000090 exit shell
Christian Heimesd8654cf2007-12-02 15:22:16 +000091 <BLANKLINE>
92
93 Test for the function print_topics():
94 >>> mycmd.print_topics("header", ["command1", "command2"], 2 ,10)
95 header
96 ======
97 command1
98 command2
99 <BLANKLINE>
100
101 Test for the function columnize():
Christian Heimes2137b6a2007-12-02 16:50:20 +0000102 >>> mycmd.columnize([str(i) for i in range(20)])
Christian Heimesd8654cf2007-12-02 15:22:16 +0000103 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
Christian Heimes2137b6a2007-12-02 16:50:20 +0000104 >>> mycmd.columnize([str(i) for i in range(20)], 10)
Christian Heimesd8654cf2007-12-02 15:22:16 +0000105 0 7 14
106 1 8 15
107 2 9 16
108 3 10 17
109 4 11 18
110 5 12 19
111 6 13
112
Martin Panter7462b6492015-11-02 03:37:02 +0000113 This is an interactive test, put some commands in the cmdqueue attribute
Christian Heimesd8654cf2007-12-02 15:22:16 +0000114 and let it execute
115 This test includes the preloop(), postloop(), default(), emptyline(),
116 parseline(), do_help() functions
117 >>> mycmd.use_rawinput=0
118 >>> mycmd.cmdqueue=["", "add", "add 4 5", "help", "help add","exit"]
119 >>> mycmd.cmdloop()
120 Hello from preloop
121 help text for add
122 *** invalid number of arguments
123 9
124 <BLANKLINE>
125 Documented commands (type help <topic>):
126 ========================================
Raymond Hettinger44d7b6a2010-09-09 03:53:22 +0000127 add help
Christian Heimesd8654cf2007-12-02 15:22:16 +0000128 <BLANKLINE>
129 Undocumented commands:
130 ======================
Raymond Hettinger44d7b6a2010-09-09 03:53:22 +0000131 exit shell
Christian Heimesd8654cf2007-12-02 15:22:16 +0000132 <BLANKLINE>
133 help text for add
134 Hello from postloop
135 """
136
137 def preloop(self):
Christian Heimes2137b6a2007-12-02 16:50:20 +0000138 print("Hello from preloop")
Christian Heimesd8654cf2007-12-02 15:22:16 +0000139
140 def postloop(self):
Christian Heimes2137b6a2007-12-02 16:50:20 +0000141 print("Hello from postloop")
Christian Heimesd8654cf2007-12-02 15:22:16 +0000142
143 def completedefault(self, *ignored):
Christian Heimes2137b6a2007-12-02 16:50:20 +0000144 print("This is the completedefault methode")
Christian Heimesd8654cf2007-12-02 15:22:16 +0000145
146 def complete_command(self):
Christian Heimes2137b6a2007-12-02 16:50:20 +0000147 print("complete command")
Christian Heimesd8654cf2007-12-02 15:22:16 +0000148
Benjamin Petersona28e7022010-01-09 18:53:06 +0000149 def do_shell(self, s):
Christian Heimesd8654cf2007-12-02 15:22:16 +0000150 pass
151
152 def do_add(self, s):
153 l = s.split()
154 if len(l) != 2:
Christian Heimes2137b6a2007-12-02 16:50:20 +0000155 print("*** invalid number of arguments")
Christian Heimesd8654cf2007-12-02 15:22:16 +0000156 return
157 try:
158 l = [int(i) for i in l]
159 except ValueError:
Christian Heimes2137b6a2007-12-02 16:50:20 +0000160 print("*** arguments should be numbers")
Christian Heimesd8654cf2007-12-02 15:22:16 +0000161 return
Christian Heimes2137b6a2007-12-02 16:50:20 +0000162 print(l[0]+l[1])
Christian Heimesd8654cf2007-12-02 15:22:16 +0000163
164 def help_add(self):
Christian Heimes2137b6a2007-12-02 16:50:20 +0000165 print("help text for add")
Christian Heimesd8654cf2007-12-02 15:22:16 +0000166 return
167
168 def do_exit(self, arg):
169 return True
170
R. David Murray7905d612010-08-01 03:31:09 +0000171
172class TestAlternateInput(unittest.TestCase):
173
174 class simplecmd(cmd.Cmd):
175
176 def do_print(self, args):
177 print(args, file=self.stdout)
178
179 def do_EOF(self, args):
180 return True
181
Jesus Cea14ed7f22012-02-19 03:52:23 +0100182
183 class simplecmd2(simplecmd):
184
185 def do_EOF(self, args):
186 print('*** Unknown syntax: EOF', file=self.stdout)
187 return True
188
189
R. David Murray7905d612010-08-01 03:31:09 +0000190 def test_file_with_missing_final_nl(self):
191 input = io.StringIO("print test\nprint test2")
192 output = io.StringIO()
193 cmd = self.simplecmd(stdin=input, stdout=output)
194 cmd.use_rawinput = False
195 cmd.cmdloop()
196 self.assertMultiLineEqual(output.getvalue(),
197 ("(Cmd) test\n"
198 "(Cmd) test2\n"
199 "(Cmd) "))
200
201
Jesus Cea14ed7f22012-02-19 03:52:23 +0100202 def test_input_reset_at_EOF(self):
203 input = io.StringIO("print test\nprint test2")
204 output = io.StringIO()
205 cmd = self.simplecmd2(stdin=input, stdout=output)
206 cmd.use_rawinput = False
207 cmd.cmdloop()
208 self.assertMultiLineEqual(output.getvalue(),
209 ("(Cmd) test\n"
210 "(Cmd) test2\n"
211 "(Cmd) *** Unknown syntax: EOF\n"))
212 input = io.StringIO("print \n\n")
213 output = io.StringIO()
214 cmd.stdin = input
215 cmd.stdout = output
216 cmd.cmdloop()
217 self.assertMultiLineEqual(output.getvalue(),
218 ("(Cmd) \n"
219 "(Cmd) \n"
220 "(Cmd) *** Unknown syntax: EOF\n"))
221
222
Christian Heimesd8654cf2007-12-02 15:22:16 +0000223def test_main(verbose=None):
Victor Stinner45df8202010-04-28 22:31:17 +0000224 from test import test_cmd
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000225 support.run_doctest(test_cmd, verbose)
R. David Murray7905d612010-08-01 03:31:09 +0000226 support.run_unittest(TestAlternateInput)
Christian Heimesd8654cf2007-12-02 15:22:16 +0000227
Christian Heimesd8654cf2007-12-02 15:22:16 +0000228def test_coverage(coverdir):
Victor Stinner45df8202010-04-28 22:31:17 +0000229 trace = support.import_module('trace')
Vinay Sajip7ded1f02012-05-26 03:45:29 +0100230 tracer=trace.Trace(ignoredirs=[sys.base_prefix, sys.base_exec_prefix,],
Christian Heimesd8654cf2007-12-02 15:22:16 +0000231 trace=0, count=1)
Berker Peksag67ef5912014-06-30 04:04:52 +0300232 tracer.run('import importlib; importlib.reload(cmd); test_main()')
Christian Heimesd8654cf2007-12-02 15:22:16 +0000233 r=tracer.results()
Christian Heimes2137b6a2007-12-02 16:50:20 +0000234 print("Writing coverage results...")
Christian Heimesd8654cf2007-12-02 15:22:16 +0000235 r.write_results(show_missing=True, summary=True, coverdir=coverdir)
236
237if __name__ == "__main__":
238 if "-c" in sys.argv:
239 test_coverage('/tmp/cmd.cover')
Benjamin Petersona28e7022010-01-09 18:53:06 +0000240 elif "-i" in sys.argv:
241 samplecmdclass().cmdloop()
Christian Heimesd8654cf2007-12-02 15:22:16 +0000242 else:
243 test_main()