vm-run.sh 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. #!/bin/bash
  2. cd "$(dirname $0)"
  3. if [ -z "$TESTDIR" ] ; then
  4. TESTDIR=$(pwd)/../
  5. fi
  6. LOGS=/tmp/hwsim-test-logs
  7. # increase the memory size if you want to run with valgrind, 512 MB works
  8. MEMORY=128
  9. # Some ubuntu systems (notably 12.04) have issues with this - since the guest
  10. # mounts as read-only it should be safe to not specify ,readonly. Override in
  11. # vm-config if needed (see below)
  12. ROTAG=,readonly
  13. # set this to ttyS0 to see kvm messages (if something doesn't work)
  14. KVMOUT=ttyS1
  15. # you can set EPATH if you need anything extra in $PATH inside the VM
  16. #EPATH=/some/dir
  17. # extra KVM arguments, e.g., -s for gdbserver
  18. #KVMARGS=-s
  19. # number of channels each hwsim device supports
  20. CHANNELS=1
  21. test -f vm-config && . vm-config
  22. test -f ~/.wpas-vm-config && . ~/.wpas-vm-config
  23. if [ -z "$KERNEL" ] && [ -z "$KERNELDIR" ] ; then
  24. echo "You need to set a KERNEL or KERNELDIR (in the environment or vm-config)"
  25. exit 2
  26. fi
  27. if [ -z "$KERNEL" ] ; then
  28. KERNEL=$KERNELDIR/arch/x86_64/boot/bzImage
  29. fi
  30. CMD=$TESTDIR/vm/inside.sh
  31. unset RUN_TEST_ARGS
  32. TIMESTAMP=$(date +%s)
  33. DATE=$TIMESTAMP
  34. CODECOV=no
  35. TIMEWARP=0
  36. while [ "$1" != "" ]; do
  37. case $1 in
  38. --timestamp ) shift
  39. TIMESTAMP=$1
  40. shift
  41. ;;
  42. --ext ) shift
  43. DATE=$TIMESTAMP.$1
  44. shift
  45. ;;
  46. --codecov ) shift
  47. CODECOV=yes
  48. ;;
  49. --timewrap ) shift
  50. TIMEWARP=1
  51. ;;
  52. * )
  53. RUN_TEST_ARGS="$RUN_TEST_ARGS$1 "
  54. shift
  55. ;;
  56. esac
  57. done
  58. LOGDIR=$LOGS/$DATE
  59. mkdir -p $LOGDIR
  60. if [ $CODECOV = "yes" ]; then
  61. DIR=$PWD
  62. if [ -e /tmp/logs ]; then
  63. echo "/tmp/logs exists - cannot prepare build trees"
  64. exit 1
  65. fi
  66. mkdir /tmp/logs
  67. echo "Preparing separate build trees for hostapd/wpa_supplicant"
  68. cd ../../..
  69. git archive --format=tar --prefix=hostap/ HEAD > /tmp/logs/hostap.tar
  70. cd $DIR
  71. cat ../../../wpa_supplicant/.config > /tmp/logs/wpa_supplicant.config
  72. echo "CONFIG_CODE_COVERAGE=y" >> /tmp/logs/wpa_supplicant.config
  73. cat ../../../hostapd/.config > /tmp/logs/hostapd.config
  74. echo "CONFIG_CODE_COVERAGE=y" >> /tmp/logs/hostapd.config
  75. cd /tmp/logs
  76. tar xf hostap.tar
  77. mv hostap alt-wpa_supplicant
  78. mv wpa_supplicant.config alt-wpa_supplicant/wpa_supplicant/.config
  79. tar xf hostap.tar
  80. mv hostap alt-hostapd
  81. cp hostapd.config alt-hostapd/hostapd/.config
  82. tar xf hostap.tar
  83. mv hostap alt-hostapd-as
  84. cp hostapd.config alt-hostapd-as/hostapd/.config
  85. tar xf hostap.tar
  86. mv hostap alt-hlr_auc_gw
  87. mv hostapd.config alt-hlr_auc_gw/hostapd/.config
  88. rm hostap.tar
  89. cd /tmp/logs/alt-wpa_supplicant/wpa_supplicant
  90. echo "Building wpa_supplicant"
  91. make -j8 > /dev/null
  92. cd /tmp/logs/alt-hostapd/hostapd
  93. echo "Building hostapd"
  94. make -j8 hostapd > /dev/null
  95. cd /tmp/logs/alt-hostapd-as/hostapd
  96. echo "Building hostapd (AS)"
  97. make -j8 hostapd > /dev/null
  98. cd /tmp/logs/alt-hlr_auc_gw/hostapd
  99. echo "Building hlr_auc_gw"
  100. make -j8 hlr_auc_gw > /dev/null
  101. cd $DIR
  102. mv /tmp/logs/alt-wpa_supplicant $LOGDIR
  103. mv /tmp/logs/alt-hostapd $LOGDIR
  104. mv /tmp/logs/alt-hostapd-as $LOGDIR
  105. mv /tmp/logs/alt-hlr_auc_gw $LOGDIR
  106. else
  107. CODECOV=no
  108. fi
  109. echo "Starting test run in a virtual machine"
  110. kvm \
  111. -kernel $KERNEL -smp 4 \
  112. $KVMARGS -m $MEMORY -nographic \
  113. -fsdev local,security_model=none,id=fsdev-root,path=/$ROTAG \
  114. -device virtio-9p-pci,id=fs-root,fsdev=fsdev-root,mount_tag=/dev/root \
  115. -fsdev local,security_model=none,id=fsdev-logs,path="$LOGDIR",writeout=immediate \
  116. -device virtio-9p-pci,id=fs-logs,fsdev=fsdev-logs,mount_tag=logshare \
  117. -monitor null -serial stdio -serial file:$LOGDIR/console \
  118. -append "mac80211_hwsim.support_p2p_device=0 mac80211_hwsim.channels=$CHANNELS mac80211_hwsim.radios=6 init=$CMD testdir=$TESTDIR timewarp=$TIMEWARP console=$KVMOUT root=/dev/root rootflags=trans=virtio,version=9p2000.u ro rootfstype=9p EPATH=$EPATH ARGS=$RUN_TEST_ARGS"
  119. if [ $CODECOV = "yes" ]; then
  120. mv $LOGDIR/alt-wpa_supplicant /tmp/logs
  121. mv $LOGDIR/alt-hostapd /tmp/logs
  122. mv $LOGDIR/alt-hostapd-as /tmp/logs
  123. mv $LOGDIR/alt-hlr_auc_gw /tmp/logs
  124. echo "Generating code coverage report for wpa_supplicant"
  125. cd /tmp/logs/alt-wpa_supplicant/wpa_supplicant
  126. lcov -c -d .. > lcov.info 2> lcov.log
  127. genhtml -t "wpa_supplicant hwsim test run $DATE" lcov.info --output-directory $LOGDIR/lcov-wpa_supplicant >> lcov.log 2>&1
  128. mv lcov.info lcov.log $LOGDIR/lcov-wpa_supplicant
  129. echo "Generating code coverage report for hostapd"
  130. cd /tmp/logs/alt-hostapd/hostapd
  131. lcov -c -d .. > lcov.info 2> lcov.log
  132. genhtml -t "hostapd hwsim test run $DATE" lcov.info --output-directory $LOGDIR/lcov-hostapd >> lcov.log 2>&1
  133. mv lcov.info lcov.log $LOGDIR/lcov-hostapd
  134. echo "Generating code coverage report for hostapd (AS)"
  135. cd /tmp/logs/alt-hostapd-as/hostapd
  136. lcov -c -d .. > lcov.info 2> lcov.log
  137. genhtml -t "hostapd (AS) hwsim test run $DATE" lcov.info --output-directory $LOGDIR/lcov-hostapd-as >> lcov.log 2>&1
  138. mv lcov.info lcov.log $LOGDIR/lcov-hostapd-as
  139. echo "Generating code coverage report for hlr_auc_gw"
  140. cd /tmp/logs/alt-hlr_auc_gw/hostapd
  141. lcov -c -d .. > lcov.info 2> lcov.log
  142. genhtml -t "hlr_auc_gw hwsim test run $DATE" lcov.info --output-directory $LOGDIR/lcov-hlr_auc_gw >> lcov.log 2>&1
  143. mv lcov.info lcov.log $LOGDIR/lcov-hlr_auc_gw
  144. echo "Generating combined code coverage report"
  145. mkdir $LOGDIR/lcov-combined
  146. for i in wpa_supplicant hostapd hostapd-as hlr_auc_gw; do
  147. sed s%SF:/tmp/logs/alt-[^/]*/%SF:/tmp/logs/alt-wpa_supplicant/% < $LOGDIR/lcov-$i/lcov.info > $LOGDIR/lcov-combined/$i.info
  148. done
  149. cd $LOGDIR/lcov-combined
  150. lcov -a wpa_supplicant.info -a hostapd.info -a hostapd-as.info -a hlr_auc_gw.info -o combined.info > lcov.log 2>&1
  151. genhtml -t "wpa_supplicant/hostapd combined for hwsim test run $DATE" combined.info --output-directory . >> lcov.log 2>&1
  152. cd $DIR
  153. rm -r /tmp/logs/alt-wpa_supplicant
  154. rm -r /tmp/logs/alt-hostapd
  155. rm -r /tmp/logs/alt-hostapd-as
  156. rm -r /tmp/logs/alt-hlr_auc_gw
  157. rmdir /tmp/logs
  158. fi
  159. echo
  160. echo "Test run completed"
  161. echo "Logfiles are at $LOGDIR"
  162. if [ $CODECOV = "yes" ]; then
  163. echo "Code coverage reports:"
  164. echo "wpa_supplicant: file://$LOGDIR/lcov-wpa_supplicant/index.html"
  165. echo "hostapd: file://$LOGDIR/lcov-hostapd/index.html"
  166. echo "hostapd (AS): file://$LOGDIR/lcov-hostapd-as/index.html"
  167. echo "hlr_auc_gw: file://$LOGDIR/lcov-hlr_auc_gw/index.html"
  168. echo "combined: file://$LOGDIR/lcov-combined/index.html"
  169. fi