run.sh 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. #!/bin/bash
  2. set -eo pipefail
  3. dir="$(dirname "$(readlink -f "$BASH_SOURCE")")"
  4. image="$1"
  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. "$image"
  18. )"
  19. trap "docker rm -vf $cid > /dev/null" EXIT
  20. mysql() {
  21. docker run --rm -i \
  22. --link "$cname":mysql \
  23. --entrypoint sh \
  24. -e MYSQL_PWD="$MYSQL_PASSWORD" \
  25. "$image" \
  26. -euc 'if command -v mariadb > /dev/null; then exec mariadb "$@"; else exec mysql "$@"; fi' -- \
  27. -hmysql \
  28. -u"$MYSQL_USER" \
  29. --silent \
  30. "$@" \
  31. "$MYSQL_DATABASE"
  32. }
  33. . "$dir/../../retry.sh" --tries 30 "mysql -e 'SELECT 1'"
  34. echo 'CREATE TABLE test (a INT, b INT, c VARCHAR(255))' | mysql
  35. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 0 ]
  36. echo 'INSERT INTO test VALUES (1, 2, "hello")' | mysql
  37. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 1 ]
  38. echo 'INSERT INTO test VALUES (2, 3, "goodbye!")' | mysql
  39. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 2 ]
  40. echo 'DELETE FROM test WHERE a = 1' | mysql
  41. [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 1 ]
  42. [ "$(echo 'SELECT c FROM test' | mysql)" = 'goodbye!' ]
  43. echo 'DROP TABLE test' | mysql