#!/usr/bin/python # # Tests the functionality of the connectfour esh plugin. # Written for CS 3214 Spring 2015. # # To run this test on your own shell, simply run: # # python /web/courses/cs3214/spring2015/projects/student-plugins/jareds94_coreym94/connectfour/connectfour_test.py eshoutput.py # # from the directory in which your "esh" and your "eshoutput.py" is located. # # @author jareds94 # @author coreym94 ########## # Set up # ########## import sys, imp, atexit, os sys.path.append("/home/courses/cs3214/software/pexpect-dpty/"); import pexpect, shellio, signal, time, os, re, proc_check # Determine the path this file is in thisdir = os.path.dirname(os.path.realpath(__file__)) #Ensure the shell process is terminated def force_shell_termination(shell_process): c.close(force=True) # pulling in the regular expression and other definitions # this should be the eshoutput.py file of the hosting shell, see usage above definitions_scriptname = sys.argv[1] def_module = imp.load_source('', definitions_scriptname) # you can define logfile=open("log.txt", "w") in your eshoutput.py if you want logging! logfile = None if hasattr(def_module, 'logfile'): logfile = def_module.logfile #spawn an instance of the shell, note the -p flags c = pexpect.spawn(def_module.shell, drainpty=True, logfile=logfile, args=['-p', thisdir]) atexit.register(force_shell_termination, shell_process=c) # set timeout for all following 'expect*' calls to 2 seconds c.timeout = 2 ################ # Actual tests # ################ # ensure that shell prints expected prompt assert c.expect(def_module.prompt) == 0, "Shell did not print expected prompt (1)" # Test a quick game c.sendline("connectfour") assert c.expect("=================\r\n" " CONNECT FOUR! \r\n" "=================\r\n" "\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "\r\n" "Player 1's move: ") == 0, \ "expected a connect four board!" c.sendline("1") assert c.expect("=================\r\n" " CONNECT FOUR! \r\n" "=================\r\n" "\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| X - - - - - - |\r\n" "\r\n" "Player 2's move: ") == 0, \ "expected a connect four board after one move." c.sendline("2") assert c.expect("=================\r\n" " CONNECT FOUR! \r\n" "=================\r\n" "\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| X O - - - - - |\r\n" "\r\n" "Player 1's move: ") == 0, \ "expected a connect four board after two moves." c.sendline("1") assert c.expect("=================\r\n" " CONNECT FOUR! \r\n" "=================\r\n" "\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| X - - - - - - |\r\n" "| X O - - - - - |\r\n" "\r\n" "Player 2's move: ") == 0, \ "expected a connect four board after three moves." c.sendline("2") assert c.expect("=================\r\n" " CONNECT FOUR! \r\n" "=================\r\n" "\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| X O - - - - - |\r\n" "| X O - - - - - |\r\n" "\r\n" "Player 1's move: ") == 0, \ "expected a connect four board after four moves." c.sendline("1") assert c.expect("=================\r\n" " CONNECT FOUR! \r\n" "=================\r\n" "\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| X - - - - - - |\r\n" "| X O - - - - - |\r\n" "| X O - - - - - |\r\n" "\r\n" "Player 2's move: ") == 0, \ "expected a connect four board after five move." c.sendline("2") assert c.expect("=================\r\n" " CONNECT FOUR! \r\n" "=================\r\n" "\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| X O - - - - - |\r\n" "| X O - - - - - |\r\n" "| X O - - - - - |\r\n" "\r\n" "Player 1's move: ") == 0, \ "expected a connect four board after six moves." c.sendline("1") assert c.expect("=================\r\n" " CONNECT FOUR! \r\n" "=================\r\n" "\r\n" "| - - - - - - - |\r\n" "| - - - - - - - |\r\n" "| X - - - - - - |\r\n" "| X O - - - - - |\r\n" "| X O - - - - - |\r\n" "| X O - - - - - |\r\n" "\r\n" "Player 1 won! Game over.") == 0, \ "expected a connect four board after seven moves." #Exit the test shellio.success()