run.sh 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. #!/bin/bash
  2. set -e
  3. image="$1"
  4. testDir="$(readlink -f "$(dirname "$BASH_SOURCE")")"
  5. export MYSQL_ROOT_PASSWORD='this is an example test password'
  6. export MYSQL_USER='0123456789012345' # "ERROR: 1470 String 'my cool mysql user' is too long for user name (should be no longer than 16)"
  7. export MYSQL_PASSWORD='my cool mysql password'
  8. export MYSQL_DATABASE='my cool mysql database'
  9. cname="mysql-container-$RANDOM-$RANDOM"
  10. cid="$(
  11. docker run -d \
  12. -e MYSQL_ROOT_PASSWORD \
  13. -e MYSQL_USER \
  14. -e MYSQL_PASSWORD \
  15. -e MYSQL_DATABASE \
  16. --name "$cname" \
  17. -v "$testDir/initdb.sql:/docker-entrypoint-initdb.d/test.sql":ro \
  18. "$image"
  19. )"
  20. trap "docker rm -vf $cid > /dev/null" EXIT
  21. mysql() {
  22. docker run --rm -i \
  23. --link "$cname":mysql \
  24. --entrypoint mysql \
  25. -e MYSQL_PWD="$MYSQL_PASSWORD" \
  26. "$image" \
  27. -hmysql \
  28. -u"$MYSQL_USER" \
  29. --silent \
  30. "$@" \
  31. "$MYSQL_DATABASE"
  32. }
  33. tries=20
  34. while ! echo 'SELECT 1' | mysql &> /dev/null; do
  35. (( tries-- ))
  36. if [ $tries -le 0 ]; then
  37. echo >&2 'mysqld failed to accept connections in a reasonable amount of time!'
  38. ( set -x && docker logs "$cid" ) >&2 || true
  39. echo 'SELECT 1' | mysql # to hopefully get a useful error message
  40. false
  41. fi
  42. sleep 2
  43. done
  44. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 1 ]
  45. [ "$(echo 'SELECT c FROM test' | mysql)" = 'goodbye!' ]