main_marking4/knight_test.sh
changeset 424 daf561a83ba6
parent 387 6282b88511d8
child 463 0315d9983cd0
equal deleted inserted replaced
423:e9d14d58be3c 424:daf561a83ba6
       
     1 #!/bin/zsh
       
     2 
       
     3 # to make the script fail safely
       
     4 set -euo pipefail
       
     5 
       
     6 out=${1:-output}
       
     7 
       
     8 echo "" > $out
       
     9 
       
    10 echo `date` >> $out
       
    11 echo -e "" >> $out
       
    12 echo -e "Below is the feedback and provisional marks for your submission" >> $out
       
    13 echo -e "of the Main Part 4 (Scala).  Please note all marks are provisional until" >> $out
       
    14 echo -e "ratified by the assessment board -- this is not an official" >> $out
       
    15 echo -e "results transcript." >> $out
       
    16 echo -e "" >> $out
       
    17 
       
    18 echo -e "" >> $out
       
    19 echo -e "Below is the feedback for your submission knight1.scala" >> $out
       
    20 echo -e "" >> $out
       
    21 
       
    22 
       
    23 
       
    24 # marks for CW8 part 1
       
    25 marks=$(( 0.0 ))
       
    26 
       
    27 # compilation tests
       
    28 
       
    29 function scala_compile {
       
    30   (ulimit -t 30; JAVA_OPTS="-Xmx1g" scala -Xprint:parser "$1" 2> c$out 1> c$out)
       
    31 }
       
    32 
       
    33 # functional tests
       
    34 
       
    35 function scala_assert {
       
    36   (ulimit -t 30; JAVA_OPTS="-Xmx1g" scala -i "$1" -- "$2" -e "" 2> /dev/null 1> /dev/null)
       
    37 }
       
    38 
       
    39 function scala_assert_slow {
       
    40   (ulimit -t 120; JAVA_OPTS="-Xmx1g" scala -i "$1" -- "$2" -e "" 2> /dev/null 1> /dev/null)  
       
    41 }
       
    42 
       
    43 function scala_assert_thirty {
       
    44   (ulimit -t 40; JAVA_OPTS="-Xmx1g" scala -i "$1" -- "$2" -e "" 2> /dev/null 1> /dev/null)  
       
    45 }
       
    46 
       
    47 function scala_assert_quick {
       
    48   (ulimit -t 30; JAVA_OPTS="-Xmx1g" scala -i "$1" -- "$2" -e "" 2> /dev/null 1> /dev/null)    
       
    49 }
       
    50 
       
    51 function scala_assert_long {
       
    52   (ulimit -t 60; JAVA_OPTS="-Xmx1g" scala -i "$1" -- "$2" -e "" 2> /dev/null 1> /dev/null)    
       
    53 }
       
    54 
       
    55 function scala_assert_elong {
       
    56   (ulimit -t 90; JAVA_OPTS="-Xmx1g" scala -i "$1" -- "$2" -e "" 2> /dev/null 1> /dev/null) 
       
    57 }
       
    58 
       
    59 # purity test
       
    60 function scala_vars {
       
    61    (sed 's/immutable/ok/g' c$out > cb$out;
       
    62     egrep '\bvar\b|\breturn\b|\.par\.|\.par |ListBuffer|AtomicInteger|mutable|util.control|new Array' cb$out 2> /dev/null 1> /dev/null)
       
    63 }
       
    64 
       
    65 
       
    66 
       
    67 # compilation test
       
    68 
       
    69 echo -e "knight1.scala runs?" | tee -a $out
       
    70 
       
    71 if (scala_compile knight1.scala)
       
    72 then
       
    73     echo -e "  --> success " | tee -a $out
       
    74     tsts=$(( 0 ))
       
    75 else
       
    76     echo -e "  --> SCALA DID NOT RUN KNIGHT1.SCALA\n" | tee -a $out
       
    77     tsts=$(( 1 )) 
       
    78 fi
       
    79 
       
    80 
       
    81 # knights1: purity test
       
    82 if  [ $tsts -eq 0 ]
       
    83   then   
       
    84   echo -e "knight1.scala does not contain VARS, RETURNS etc?" | tee -a $out
       
    85 
       
    86   if (scala_vars knight1.scala)
       
    87   then
       
    88      echo -e "  --> FAIL\n" | tee -a $out
       
    89      tsts=$(( 1 ))
       
    90   else
       
    91      echo -e "  --> success" | tee -a $out
       
    92      tsts=$(( 0 )) 
       
    93   fi
       
    94 else
       
    95   tsts=$(( 1 ))  
       
    96 fi
       
    97 
       
    98 echo >> $out
       
    99 
       
   100 ### knight1 test
       
   101 
       
   102 if [ $tsts -eq 0 ]
       
   103 then
       
   104     echo " is_legal(8, Nil, (3, 4)) == true " | tee -a $out
       
   105     echo " is_legal(8, List((4, 1), (1, 0)), (4, 1)) == false " | tee -a $out
       
   106     echo " is_legal(2, Nil, (0, 0)) == true" | tee -a $out                          
       
   107 
       
   108     if (scala_assert "knight1.scala" "knight1_test1.scala")
       
   109     then
       
   110         echo -e "  --> success" | tee -a $out
       
   111 	marks=$(( marks + 1.0 ))
       
   112     else
       
   113         echo -e "  --> \n ONE TEST FAILED\n"| tee -a $out
       
   114     fi
       
   115 fi
       
   116 
       
   117 ### knight2 test
       
   118 
       
   119 if [ $tsts -eq 0 ]
       
   120 then
       
   121   echo " legal_moves(8, Nil, (2,2)) == List((3,4), (4,3), (4,1), (3,0), (1,0), (0,1), (0,3), (1,4))" | tee -a $out
       
   122   echo " legal_moves(8, Nil, (7,7)) == List((6,5), (5,6))" | tee -a $out
       
   123   echo " legal_moves(8, List((4,1), (1,0)), (2,2)) == List((3,4), (4,3), (3,0), (0,1), (0,3), (1,4))" | tee -a $out
       
   124   echo " legal_moves(8, Nil, (0,1)) == List((1,3), (2,2), (2,0))" | tee -a $out
       
   125   echo " legal_moves(8, List((6,6)), (7,7)) == List((6,5), (5,6))" | tee -a $out
       
   126   echo " legal_moves(1, Nil, (0,0)) == Nil" | tee -a $out
       
   127   echo " legal_moves(2, Nil, (0,0)) == Nil" | tee -a $out
       
   128   echo " legal_moves(3, Nil, (0,0)) == List((1,2), (2,1))" | tee -a $out
       
   129   
       
   130   if (scala_assert "knight1.scala" "knight1_test2.scala")
       
   131   then
       
   132      echo -e "  --> success\n" | tee -a $out
       
   133      marks=$(( marks + 1 ))
       
   134   else
       
   135      echo -e "  --> ONE TEST FAILED\n" | tee -a $out
       
   136   fi
       
   137 fi
       
   138 
       
   139 
       
   140 ### knight3 test
       
   141 
       
   142 if [ $tsts -eq 0 ]
       
   143 then
       
   144   echo " count_tours from every position on the board 1 - 4 (0.5% marks)" | tee -a $out
       
   145   echo " dim = 1: 1" | tee -a $out
       
   146   echo "       2: 0,0,0,0" | tee -a $out
       
   147   echo "       3: 0,0,0,0,0,0,0,0,0" | tee -a $out
       
   148   echo "       4: 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0" | tee -a $out
       
   149   START=$(date +%s)
       
   150   
       
   151   if (scala_assert_thirty "knight1.scala" "knight1_test3a.scala") 
       
   152   then
       
   153      END=$(date +%s)
       
   154      DIFF=$(( $END - $START ))
       
   155      #echo " This test ran for $DIFF seconds." | tee -a $out  
       
   156      echo -e "  --> success\n" | tee -a $out
       
   157      marks=$(( marks + 0.5 ))
       
   158   else
       
   159      END=$(date +%s)
       
   160      DIFF=$(( $END - $START ))
       
   161      echo " This test ran for $DIFF seconds." | tee -a $out 
       
   162      echo -e "  --> ONE TEST FAILED\n" | tee -a $out
       
   163   fi
       
   164 fi
       
   165 
       
   166 
       
   167 
       
   168 if [ $tsts -eq 0 ]
       
   169 then
       
   170   echo " count_tours from every position on the board of dim 5 for the first 3 rows (0.25% marks)" | tee -a $out
       
   171   echo " dim = 5: 304,0,56,0,304,0,56,0,56,0,56,0,64,0,56)" | tee -a $out
       
   172   START=$(date +%s)
       
   173   
       
   174   if (scala_assert_thirty "knight1.scala" "knight1_test3b.scala") 
       
   175   then
       
   176      END=$(date +%s)
       
   177      DIFF=$(( $END - $START ))
       
   178      #echo " This test ran for $DIFF seconds." | tee -a $out  
       
   179      echo -e "  --> success\n" | tee -a $out
       
   180      marks=$(( marks + 0.25 ))
       
   181   else
       
   182      END=$(date +%s)
       
   183      DIFF=$(( $END - $START ))
       
   184      echo " This test ran for $DIFF seconds." | tee -a $out 
       
   185      echo -e "  --> ONE TEST FAILED\n" | tee -a $out
       
   186   fi
       
   187 fi
       
   188 
       
   189 
       
   190 
       
   191 if [ $tsts -eq 0 ]
       
   192 then
       
   193   echo " enum_tours(5, List((0,2)) ) => 56 tours? and all correct?" | tee -a $out
       
   194   echo " enum_tours(5, List((0,0)) ) => 304 tours? and all correct?" | tee -a $out
       
   195   echo " (0.25% marks) " | tee -a $out
       
   196   START=$(date +%s)
       
   197   
       
   198   if (scala_assert_thirty "knight1.scala" "knight1_test3c.scala") 
       
   199   then
       
   200      END=$(date +%s)
       
   201      DIFF=$(( $END - $START ))
       
   202      #echo " This test ran for $DIFF seconds." | tee -a $out 
       
   203      echo -e "  --> success\n" | tee -a $out
       
   204      marks=$(( marks + 0.25 ))
       
   205   else
       
   206      END=$(date +%s)
       
   207      DIFF=$(( $END - $START ))
       
   208      echo " This test ran for $DIFF seconds." | tee -a $out 
       
   209      echo -e "  --> \n ONE TEST FAILED\n" | tee -a $out
       
   210   fi
       
   211 fi
       
   212 
       
   213 
       
   214 ### knight4 test
       
   215 
       
   216 if [ $tsts -eq 0 ]
       
   217 then
       
   218   echo -e " Let f = (x:(Int, Int)) => if (x._1 > 3) Some(List(x)) else None " | tee -a $out
       
   219   echo -e "   first(List((1,0),(2,0),(3,0),(4,0)), f) == Some(List((4,0)))" | tee -a $out
       
   220   echo -e "   first(List((1,0),(2,0),(3,0)), f) == None" | tee -a $out  
       
   221   
       
   222   if (scala_assert "knight1.scala" "knight1_test4.scala") 
       
   223   then
       
   224       echo -e "  --> success" | tee -a $out
       
   225       marks=$(( marks + 1.0 ))
       
   226   else
       
   227       echo -e "  --> ONE OF THE TESTS FAILED\n" | tee -a $out
       
   228   fi
       
   229 fi
       
   230 
       
   231 ### knight5 test
       
   232 
       
   233 if [ $tsts -eq 0 ]
       
   234 then
       
   235   echo -e " is first_tour(6, List((0,0))) ok? " | tee -a $out
       
   236   echo -e " is first_tour(4, List((0,0))) == None " | tee -a $out
       
   237   START=$(date +%s)
       
   238   
       
   239   if (scala_assert_thirty "knight1.scala" "knight1_test5.scala") 
       
   240   then
       
   241       END=$(date +%s)
       
   242       DIFF=$(( $END - $START ))
       
   243       echo -e "  This test ran for $DIFF seconds" | tee -a $out  
       
   244       echo -e "  --> success" | tee -a $out
       
   245       marks=$(( marks + 1.0 ))
       
   246   else
       
   247       END=$(date +%s)
       
   248       DIFF=$(( $END - $START ))
       
   249       echo -e "  This test ran for $DIFF seconds" | tee -a $out 
       
   250       echo -e "  --> TEST FAILED\n" | tee -a $out
       
   251   fi
       
   252 fi
       
   253 
       
   254 echo -e "" >> $out
       
   255 echo -e  "Below is the feedback for your submission knight2.scala" >> $out
       
   256 echo -e  "" >> $out
       
   257 
       
   258 
       
   259 # knights2: compilation test
       
   260 
       
   261 echo "knight2.scala runs?" | tee -a $out
       
   262 
       
   263 if (scala_compile knight2.scala)
       
   264 then
       
   265     echo -e "  --> success" | tee -a $out
       
   266     tsts=$(( 0 ))
       
   267 else
       
   268     echo -e "  --> SCALA DID NOT RUN knight2.scala\n" | tee -a $out
       
   269     tsts=$(( 1 )) 
       
   270 fi
       
   271 
       
   272 
       
   273 
       
   274 # knights2: purity test
       
   275 #
       
   276 if [ $tsts -eq 0 ]
       
   277 then 
       
   278     echo "knight2.scala does not VARS, RETURNS etc?" | tee -a $out
       
   279 
       
   280     if (scala_vars knight2.scala)
       
   281     then   
       
   282 	echo -e "  --> TEST FAILED\n" | tee -a $out
       
   283 	tsts=$(( 1 ))
       
   284     else
       
   285 	echo -e "  --> success" | tee -a $out
       
   286 	tsts=$(( 0 )) 
       
   287     fi
       
   288 else
       
   289     tsts=$(( 1 ))  
       
   290 fi
       
   291 
       
   292 
       
   293 # ordered move test
       
   294 
       
   295 if [ $tsts -eq 0 ]
       
   296 then
       
   297   echo -e " ordered_moves(8, List((3,4), (3,2)), (1,3)) == List((0,1), (0,5), (2,1), (2,5))" | tee -a $out
       
   298   echo -e " ordered_moves(8, List((4,0)), (0,0)) == List((2,1), (1,2))" | tee -a $out
       
   299   echo -e " ordered_moves(8, List((0,4)), (0,0)) == List((1,2), (2,1))" | tee -a $out
       
   300   
       
   301   if (scala_assert "knight2.scala" "knight2_test6.scala")
       
   302   then
       
   303       echo -e "  --> success" | tee -a $out
       
   304       marks=$(( marks + 1.0 ))
       
   305   else
       
   306       echo -e "  --> ONE OF THE TESTS FAILED\n" | tee -a $out
       
   307   fi
       
   308 fi
       
   309 
       
   310 
       
   311 # first-closed-tour test
       
   312 
       
   313 if [ $tsts -eq 0 ]
       
   314 then
       
   315   echo -e " first_closed_tour_heuristics(6, List((3,3))) found and correct?" | tee -a $out
       
   316   START=$(date +%s)
       
   317   
       
   318   if (scala_assert_thirty "knight2.scala" "knight2_test7.scala")
       
   319   then
       
   320       END=$(date +%s)
       
   321       DIFF=$(( $END - $START ))
       
   322       echo -e "  This test ran for $DIFF seconds" | tee -a $out 
       
   323       echo -e "  --> success" | tee -a $out
       
   324       marks=$(( marks + 1.0 ))
       
   325   else
       
   326       END=$(date +%s)
       
   327       DIFF=$(( $END - $START ))
       
   328       echo -e "  This test ran for $DIFF seconds." | tee -a $out 
       
   329       echo -e "  --> TEST FAILED\n" | tee -a $out
       
   330   fi
       
   331 fi
       
   332 
       
   333 
       
   334 # first-tour test
       
   335 
       
   336 if [ $tsts -eq 0 ]
       
   337 then
       
   338   echo -e " first_tour_heuristics(8, List((0,0))) found and correct?" | tee -a $out
       
   339   echo -e " first_tour_heuristics(30, List((0,0))) found and correct?" | tee -a $out
       
   340   START=$(date +%s)
       
   341   
       
   342   if (scala_assert_thirty "knight2.scala" "knight2_test8.scala")
       
   343   then
       
   344       END=$(date +%s)
       
   345       DIFF=$(( $END - $START ))
       
   346       echo "  This test ran for $DIFF seconds" | tee -a $out
       
   347       echo -e "  --> success" | tee -a $out
       
   348       marks=$(( marks + 1.0 ))
       
   349   else
       
   350       END=$(date +%s)
       
   351       DIFF=$(( $END - $START ))
       
   352       echo "  This test ran for $DIFF seconds." | tee -a $out
       
   353       echo -e "  --> ONE OF THE TESTS FAILED\n" | tee -a $out
       
   354   fi
       
   355 fi
       
   356 
       
   357 echo -e "" >> $out
       
   358 echo -e  "Below is the feedback for your submission knight3.scala" >> $out
       
   359 echo -e  "" >> $out
       
   360 
       
   361 # compilation test
       
   362 echo "knight3.scala runs?" | tee -a $out
       
   363 
       
   364 if (scala_compile knight3.scala)
       
   365 then
       
   366     echo "  --> success" | tee -a $out
       
   367     tsts=$(( 0 ))
       
   368 else
       
   369     echo -e "  --> SCALA DID NOT RUN knight3.scala\n" | tee -a $out  
       
   370     tsts=$(( 1 )) 
       
   371 fi
       
   372 
       
   373 
       
   374 # knights3: purity test
       
   375 #
       
   376 if [ $tsts -eq 0 ]
       
   377 then 
       
   378     echo -e "knight3.scala does not contain VARS, RETURNS etc?" | tee -a $out
       
   379 
       
   380     if (scala_vars knight3.scala)
       
   381     then
       
   382 	echo "  --> TEST FAILED\n" | tee -a $out
       
   383 	tsts=$(( 1 ))
       
   384     else
       
   385 	echo "  --> success" | tee -a $out
       
   386 	tsts=$(( 0 )) 
       
   387     fi
       
   388 else
       
   389     tsts=$(( 1 ))  
       
   390 fi
       
   391 
       
   392 
       
   393 if [ $tsts -eq 0 ]
       
   394 then
       
   395   echo -e " tour_on_mega_board(70, List((0,0))) found and correct?" | tee -a $out
       
   396   START=$(date +%s)
       
   397   
       
   398   if (scala_assert_thirty "knight3.scala" "knight3_test9.scala")
       
   399   then
       
   400       END=$(date +%s)
       
   401       DIFF=$(( $END - $START ))
       
   402       echo -e "  This test ran for $DIFF seconds." | tee -a $out
       
   403       echo -e "  --> success" | tee -a $out
       
   404       marks=$(( marks + 1.0 ))
       
   405   else
       
   406       END=$(date +%s)
       
   407       DIFF=$(( $END - $START ))
       
   408       echo -e "  This test ran for $DIFF seconds." | tee -a $out
       
   409       echo -e "  --> TEST FAILED\n" | tee -a $out 
       
   410   fi
       
   411 fi
       
   412 
       
   413 
       
   414 ## final marks
       
   415 echo -e "" >> $out
       
   416 echo -e "Overall mark for Main Part 4 (Scala)" | tee -a $out
       
   417 printf " %0.2f\n" $marks | tee -a $out
       
   418 
       
   419