marking1/drumb_test.sh
author Christian Urban <urbanc@in.tum.de>
Thu, 07 Dec 2017 12:09:06 +0000
changeset 165 9325fa158cd1
parent 158 f60e0908f80b
child 169 8a1bd8ddb96c
permissions -rwxr-xr-x
updated
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
158
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
#!/bin/bash
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
set -e
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
out=${1:-output}
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     5
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     6
echo "" > $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     7
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
echo "Below is the feedback for your submission for drumb.scala" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     9
echo "" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    10
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    11
# compilation tests
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    12
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    13
function scala_compile {
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    14
  (ulimit -t 30 -m 1024000 ; scala "$1" 2>> $out 1>> $out) 
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    15
}
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    16
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    17
# functional tests
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    18
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    19
function scala_assert {
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    20
  (ulimit -t 30 -m 1024000 ; scala -i "$1" "$2" -e "" 2> /dev/null 1> /dev/null)
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    21
}
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    22
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    23
# purity test
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    24
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    25
function scala_vars {
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    26
   (egrep '\bvar\b|\breturn\b|\.par|ListBuffer|mutable' "$1" 2> /dev/null 1> /dev/null)
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    27
}
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    28
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    29
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    30
# var, .par return, ListBuffer test
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    31
#
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    32
echo "drumb.scala does not contain vars, returns etc?" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    33
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    34
if (scala_vars drumb.scala)
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    35
then
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    36
  echo "  --> fail" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    37
  tsts0=$(( 1 ))
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    38
else
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    39
  echo "  --> success" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    40
  tsts0=$(( 0 )) 
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    41
fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    42
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    43
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    44
# compilation test
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    45
if  [ $tsts0 -eq 0 ]
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    46
then 
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    47
  echo "drumb.scala runs?" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    48
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    49
  if (scala_compile alcohol.scala)
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    50
  then
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    51
    echo "  --> success" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    52
    tsts=$(( 0 ))
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    53
  else
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    54
    echo "  --> scala did not run alcohol.scala" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    55
    tsts=$(( 1 )) 
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    56
  fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    57
else
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    58
  tsts=$(( 1 ))     
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    59
fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    60
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    61
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    62
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    63
### get prices tests
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    64
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    65
if [ $tsts -eq 0 ]
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    66
then
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    67
  echo "  get_prices(List(\"GOOG\", \"AAPL\"), 2010 to 2012) ==" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    68
  echo "       List(List(Some(311.349976), Some(27.505054))," >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    69
  echo "            List(Some(300.222351), Some(42.357094))," >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    70
  echo "            List(Some(330.555054), Some(52.852215)))" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    71
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    72
  if (scala_assert "drumb.scala" "drumb_test1.scala")
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    73
  then
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    74
    echo "  --> success" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    75
  else
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    76
    echo "  --> test failed" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    77
  fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    78
fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    79
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    80
### get_deltas_test
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    81
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    82
if [ $tsts -eq 0 ]
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    83
then
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    84
  echo "  get_deltas(get_prices(List(\"GOOG\", \"AAPL\"), 2010 to 2012)) == " >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    85
  echo "    List(List(Some(-0.03573992567129673), Some(0.5399749442411563)), " >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    86
  echo "         List(Some(0.10103412653643493), Some(0.2477771728154912)))" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    87
  
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    88
  if (scala_assert "drumb.scala" "drumb_test2.scala") 
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    89
  then
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    90
    echo "  --> success" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    91
  else
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    92
    echo "  --> test failed" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    93
  fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    94
fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    95
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    96
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    97
### yield_tests, investment_test
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    98
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    99
if [ $tsts -eq 0 ]
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   100
then
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   101
  echo "  yearly_yield(get_deltas(<<GOOG+AAPL 2010 - 2012>>), 100, 0) == 125" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   102
  echo "" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   103
  echo "  investment(rstate_portfolio, 1978 to 2017, 100) == 30895" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   104
  echo "  investment(bchips_portfolio, 1978 to 2017, 100) == 349597" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   105
  
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   106
  if (scala_assert "drumb.scala" "drumb_test3.scala") 
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   107
  then
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   108
    echo "  --> success" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   109
  else
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   110
    echo "  --> test failed" >> $out
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   111
  fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   112
fi
f60e0908f80b updated
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   113