Blame | Last modification | View Log | Download | RSS feed
#!/usr/bin/python## Block header comment##import sys, imp, atexitsys.path.append("/home/courses/cs3214/software/pexpect-dpty/");import pexpect, shellio, signal, time, os, re, proc_check#Ensure the shell process is terminateddef force_shell_termination(shell_process):c.close(force=True)#pulling in the regular expression and other definitionsdefinitions_scriptname = sys.argv[1]def_module = imp.load_source('', definitions_scriptname)logfile = Noneif hasattr(def_module, 'logfile'):logfile = def_module.logfile#spawn an instance of the shellc = pexpect.spawn(def_module.shell, drainpty=True, logfile=logfile)atexit.register(force_shell_termination, shell_process=c)# set timeout for all following 'expect*' calls to 2 secondsc.timeout = 2# ensure that shell prints expected promptassert c.expect(def_module.prompt) == 0, "Shell did not print expected prompt"# save a string to a filec.sendline("echo This is a test message > testfile")# ensure that the shell prints the expected promptassert c.expect(def_module.prompt) == 0, "Shell did not print expected prompt"# print out contents of said filec.sendline("wc < testfile")# check if correct string was writtenassert c.expect(" 1 5 23") == 0, "Shell did not print expected output"# remove tmp filec.sendline("rm testfile")c.sendline("exit");assert c.expect_exact("exit\r\n") == 0, "Shell output extraneous characters"shellio.success()