integration.sh 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. #!/bin/bash
  2. set -e
  3. function run_tests() {
  4. local clusterSize=3
  5. local version=$1
  6. local auth=$2
  7. if [ "$auth" = true ]; then
  8. clusterSize=1
  9. fi
  10. local keypath="$(pwd)/testdata/pki"
  11. local conf=(
  12. "client_encryption_options.enabled: true"
  13. "client_encryption_options.keystore: $keypath/.keystore"
  14. "client_encryption_options.keystore_password: cassandra"
  15. "client_encryption_options.require_client_auth: true"
  16. "client_encryption_options.truststore: $keypath/.truststore"
  17. "client_encryption_options.truststore_password: cassandra"
  18. "concurrent_reads: 2"
  19. "concurrent_writes: 2"
  20. "rpc_server_type: sync"
  21. "rpc_min_threads: 2"
  22. "rpc_max_threads: 2"
  23. "write_request_timeout_in_ms: 5000"
  24. "read_request_timeout_in_ms: 5000"
  25. )
  26. ccm remove test || true
  27. ccm create test -v binary:$version -n $clusterSize -d --vnodes --jvm_arg="-Xmx256m -XX:NewSize=100m"
  28. ccm updateconf "${conf[@]}"
  29. if [ "$auth" = true ]
  30. then
  31. ccm updateconf 'authenticator: PasswordAuthenticator' 'authorizer: CassandraAuthorizer'
  32. rm -rf $HOME/.ccm/test/node1/data/system_auth
  33. fi
  34. ccm start -v
  35. ccm status
  36. ccm node1 nodetool status
  37. local proto=2
  38. if [[ $version == 1.2.* ]]; then
  39. proto=1
  40. elif [[ $version == 2.0.* ]]; then
  41. proto=2
  42. elif [[ $version == 2.1.* ]]; then
  43. proto=3
  44. elif [[ $version == 2.2.* ]]; then
  45. proto=4
  46. fi
  47. if [ "$auth" = true ]
  48. then
  49. sleep 30s
  50. go test -v . -timeout 15s -run=TestAuthentication -tags integration -runssl -runauth -proto=$proto -cluster=$(ccm liveset) -clusterSize=$clusterSize -autowait=1000ms
  51. else
  52. go test -timeout 5m -tags integration -cover -v -runssl -proto=$proto -rf=3 -cluster=$(ccm liveset) -clusterSize=$clusterSize -autowait=2000ms -compressor=snappy ./... | tee results.txt
  53. if [ ${PIPESTATUS[0]} -ne 0 ]; then
  54. echo "--- FAIL: ccm status follows:"
  55. ccm status
  56. ccm node1 nodetool status
  57. ccm node1 showlog > status.log
  58. cat status.log
  59. echo "--- FAIL: Received a non-zero exit code from the go test execution, please investigate this"
  60. exit 1
  61. fi
  62. cover=`cat results.txt | grep coverage: | grep -o "[0-9]\{1,3\}" | head -n 1`
  63. if [[ $cover -lt "55" ]]; then
  64. echo "--- FAIL: expected coverage of at least 60 %, but coverage was $cover %"
  65. exit 1
  66. fi
  67. fi
  68. ccm remove
  69. }
  70. run_tests $1 $2