mqltest.sh 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. export LANG=zh_CN.utf8
  2. export LC_ALL=zh_CN.utf8 2>/dev/null
  3. #改变工作目录到当前脚本所在路径
  4. if [[ "$0" =~ / ]]; then cd "${0%/*}"; fi
  5. export CWD=`pwd`
  6. if [[ -e ~/odbserver/mql ]]; then
  7. mqlver=`ls -l mql`
  8. newmqlver=`cd ~/odbserver/; ls -l mql; cd ${CWD}`
  9. if [[ "$mqlver" != "$newmqlver" ]]; then
  10. cp -pf ~/odbserver/mql mql
  11. fi
  12. fi
  13. if [[ ! -e mql.conf ]]; then
  14. if [[ "${ODBPATH}" = "" ]]; then
  15. export ODBPATH=127.0.0.1:11001
  16. fi
  17. if [[ "${KEYSPACE}" = "" ]]; then
  18. export KEYSPACE=oktest
  19. fi
  20. fi
  21. odbver=`./mql odbver? log.level=error "$@"`
  22. odbpath=`./mql odbpath? log.level=error "$@"`
  23. keyspace=`./mql keyspace? log.level=error "$@"`
  24. if [[ `echo "${keyspace}" | wc -w` == "1" ]]; then
  25. logfile="${keyspace}.test.log"
  26. lastlogfile="${keyspace}.last.log"
  27. else
  28. logfile="test.log"
  29. lastlogfile="last.log"
  30. fi
  31. if [[ "${odbpath}" != "" ]]; then
  32. echo ODBPATH="${odbpath}"
  33. fi
  34. if [[ "${keyspace}" != "" ]]; then
  35. echo keyspace="${keyspace}"
  36. fi
  37. sleep 2
  38. filescount=`./mql files? log.level=error "$@" | wc -l`
  39. if [[ "${filescount}" == "0" ]]; then
  40. ./mql "$@"
  41. exit $?
  42. fi
  43. if [[ "${filescount}" == "1" ]]; then
  44. logfile="${keyspace}.1test.log"
  45. ./mql "$@" 2>&1 | tee ${logfile}
  46. exit $?
  47. fi
  48. filepath=`echo "$@" | awk '{print $NF}'`
  49. # remove ./
  50. filepath=${filepath/\.\//}
  51. # remove last slash
  52. filepath=${filepath%/}
  53. mqlproc=`ps -ef | grep -v grep | grep mql | grep "${filepath}"`
  54. if [[ "$mqlproc" != "" ]]; then
  55. echo "another mql test is running"
  56. exit 111
  57. fi
  58. if [[ -e ${logfile} ]]; then
  59. mv -f ${logfile} ${lastlogfile}
  60. fi
  61. n=`./mql keyspace=matrix - "cql:select count(*) from system_schema.columns where keyspace_name='${keyspace}' and table_name='object_test'" 2>/dev/null | grep "count" | grep -v "grep" | grep -v "select" | awk '{print $2}'`
  62. if [[ "${n}" == "0" ]]; then
  63. n=1
  64. else
  65. n=`cat ${keyspace}.test.count 2>/dev/null`
  66. n=`expr 0${n} + 1`
  67. fi
  68. echo "${n}" > ${keyspace}.test.count
  69. ./mql "$@" "log.prefix=test $n" 2>&1 | tee ${logfile}
  70. lastline=`tail -n 1 $logfile 2>&1`
  71. if [[ "$lastline" = "FAIL" ]]; then
  72. exit 123
  73. elif [[ "$lastline" = "PASS" ]]; then
  74. echo "./mql $@" "log.prefix=test $n" 2>/dev/null >> ${keyspace}.history.log
  75. echo "${odbver}" 2>/dev/null >> ${keyspace}.history.log
  76. grep "test.code.version=" $logfile 2>/dev/null >> ${keyspace}.history.log
  77. tail -n 4 $logfile | head -n 1 2>/dev/null >> ${keyspace}.history.log
  78. exit 0
  79. elif [[ `echo "$lastline" | grep './mqltest.sh:' | grep "已杀死"` != "" ]]; then
  80. exit 99
  81. elif [[ `echo "$lastline" | grep './mqltest.sh:' | grep "killed"` != "" ]]; then
  82. exit 99
  83. fi
  84. # unkown status
  85. exit 125