#!/usr/bin/python # # jobs_test: tests the jobs command # # Test the jobs command for status messages and proper output # of the command and jobid. Requires the following commands to be implemented # or otherwise usable: # # jobs, ctrl-z control, ctrl-c control, sleep, fg, clear # import sys, imp, atexit sys.path.append("/home/courses/cs3214/software/pexpect-dpty/"); import pexpect, shellio, signal, time, os, re, proc_check #Ensure the shell process is terminated def force_shell_termination(shell_process): c.close(force=True) #pulling in the regular expression and other definitions definitions_scriptname = sys.argv[1] def_module = imp.load_source('', definitions_scriptname) logfile = None if hasattr(def_module, 'logfile'): logfile = def_module.logfile # spawn an instance of bash. PS1 is the env variable from which bash # draws its prompt c = 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 seconds c.timeout = 3 # ensure that shell prints expected prompt c.sendline("superhero Aquaman") assert c.expect_exact("Aquaman alias is Arthur Curry") == 0, "Please enter a correct name." # ensure that shell prints expected prompt c.sendline("superhero Arthur Curry") assert c.expect_exact("Arthur Curry hero name is Aquaman") == 0, "Please enter a correct name." # exit c.sendline("exit"); assert c.expect_exact("exit\r\n") == 0, "Shell output extraneous characters" shellio.success()