run.sh 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839
  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="$(docker run -d -e MYSQL_ROOT_PASSWORD -e MYSQL_USER -e MYSQL_PASSWORD -e MYSQL_DATABASE --name "$cname" "$image")"
  10. trap "docker rm -f $cid > /dev/null" EXIT
  11. mysql() {
  12. docker run --rm -i --link "$cname":mysql --entrypoint mysql -e MYSQL_PWD="$MYSQL_PASSWORD" "$image" -hmysql -u"$MYSQL_USER" --silent "$@" "$MYSQL_DATABASE"
  13. }
  14. tries=10
  15. while ! echo 'SELECT 1' | mysql &> /dev/null; do
  16. (( tries-- ))
  17. if [ $tries -le 0 ]; then
  18. echo >&2 'mysqld failed to accept connections in a reasonable amount of time!'
  19. echo 'SELECT 1' | mysql # to hopefully get a useful error message
  20. false
  21. fi
  22. sleep 2
  23. done
  24. echo 'CREATE TABLE test (a INT, b INT, c VARCHAR(255))' | mysql
  25. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 0 ]
  26. echo 'INSERT INTO test VALUES (1, 2, "hello")' | mysql
  27. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 1 ]
  28. echo 'INSERT INTO test VALUES (2, 3, "goodbye!")' | mysql
  29. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 2 ]
  30. echo 'DELETE FROM test WHERE a = 1' | mysql
  31. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 1 ]
  32. [ "$(echo 'SELECT c FROM test' | mysql)" = "goodbye!" ]
  33. echo 'DROP TABLE test' | mysql