summaryrefslogtreecommitdiff
path: root/tests/test_ctrl_chars.py
diff options
context:
space:
mode:
authorNoah Spurrier <noah@squaretrade.com>2012-10-26 11:19:10 -0700
committerNoah Spurrier <noah@squaretrade.com>2012-10-26 11:19:10 -0700
commit7999ca657997e78febfb3fb89cfcc066d50bf788 (patch)
tree7ff33465bb4f8f79b92add505d11d4b731dfe6a7 /tests/test_ctrl_chars.py
parent6b65a76c26d72caf0a5b11725750861bf89f2b75 (diff)
downloadpexpect-git-7999ca657997e78febfb3fb89cfcc066d50bf788.tar.gz
Moved everything up one directory level.
Diffstat (limited to 'tests/test_ctrl_chars.py')
-rwxr-xr-xtests/test_ctrl_chars.py109
1 files changed, 109 insertions, 0 deletions
diff --git a/tests/test_ctrl_chars.py b/tests/test_ctrl_chars.py
new file mode 100755
index 0000000..c679609
--- /dev/null
+++ b/tests/test_ctrl_chars.py
@@ -0,0 +1,109 @@
+#!/usr/bin/env python
+'''
+PEXPECT LICENSE
+
+ This license is approved by the OSI and FSF as GPL-compatible.
+ http://opensource.org/licenses/isc-license.txt
+
+ Copyright (c) 2012, Noah Spurrier <noah@noah.org>
+ PERMISSION TO USE, COPY, MODIFY, AND/OR DISTRIBUTE THIS SOFTWARE FOR ANY
+ PURPOSE WITH OR WITHOUT FEE IS HEREBY GRANTED, PROVIDED THAT THE ABOVE
+ COPYRIGHT NOTICE AND THIS PERMISSION NOTICE APPEAR IN ALL COPIES.
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+
+'''
+import pexpect
+import unittest
+import PexpectTestCase
+import time
+import os
+
+class TestCtrlChars(PexpectTestCase.PexpectTestCase):
+
+ def test_control_chars (self):
+
+ '''FIXME: Python unicode was too hard to figure out, so
+ this tests only the true ASCII characters. This is lame
+ and should be fixed. I'm leaving this script here as a
+ placeholder so that it will remind me to fix this one day.
+ This is what it used to do:
+ This tests that we can send all 256 8-bit ASCII characters
+ to a child process.'''
+
+ # FIXME: Getting this to support Python's Unicode was
+ # too hard, so I disabled this. I should fix this one day.
+ return 0
+ child = pexpect.spawn('python getch.py')
+ try:
+ for i in range(256):
+# child.send(unicode('%d'%i, encoding='utf-8'))
+ child.send(chr(i))
+ child.expect ('%d\r\n' % i)
+ except Exception, e:
+ msg = "Did not echo character value: " + str(i) + "\n"
+ msg = msg + str(e)
+ self.fail(msg)
+
+ def test_sendintr (self):
+ try:
+ child = pexpect.spawn('python getch.py')
+ child.sendintr()
+ child.expect ('3\r\n')
+ except Exception, e:
+ msg = "Did not echo character value: 3\n"
+ msg = msg + str(e)
+ self.fail(msg)
+
+ def test_bad_sendcontrol_chars (self):
+
+ '''This tests that sendcontrol will return 0 for an unknown char. '''
+
+ child = pexpect.spawn('python getch.py')
+ retval = child.sendcontrol('1')
+ assert retval == 0, "sendcontrol() should have returned 0 because there is no such thing as ctrl-1."
+
+ def test_sendcontrol(self):
+
+ '''This tests that we can send all special control codes by name.
+ '''
+
+ child = pexpect.spawn('python getch.py')
+ #child.delaybeforesend = 0.1
+ for i in 'abcdefghijklmnopqrstuvwxyz':
+ child.sendcontrol(i)
+ child.expect ('[0-9]+\r\n')
+ #print child.after
+
+ child.sendcontrol('@')
+ child.expect ('0\r\n')
+ #print child.after
+ child.sendcontrol('[')
+ child.expect ('27\r\n')
+ #print child.after
+ child.sendcontrol('\\')
+ child.expect ('28\r\n')
+ #print child.after
+ child.sendcontrol(']')
+ child.expect ('29\r\n')
+ #print child.after
+ child.sendcontrol('^')
+ child.expect ('30\r\n')
+ #print child.after
+ child.sendcontrol('_')
+ child.expect ('31\r\n')
+ #print child.after
+ child.sendcontrol('?')
+ child.expect ('127\r\n')
+ #print child.after
+
+if __name__ == '__main__':
+ unittest.main()
+
+suite = unittest.makeSuite(TestCtrlChars,'test')
+