run.sh 1.6 KB

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