#!/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 #!/usr/bin/python # # Block header comment # # 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 the shell c = pexpect.spawn(def_module.shell, drainpty=True, logfile=logfile) atexit.register(force_shell_termination, shell_process=c) # doge 0 call c.sendline('doge 0') assert c.expect('Shibe 0 is not gonna do anythang\n') == 0, 'doge 0 returns incorrect string' # dogee call c.sendline('doge') assert c.expect('Needs a second argument. Format your answer as \'doge [amount]\'\n') == 0, 'doge 0 returns incorrect string' c.sendline('exit'); assert c.expect_exact('exit\r\n') == 0, 'Shell output extraneous characters' shellio.success()