| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- #!/bin/bash
- set -e
- image="$1"
- export MYSQL_ROOT_PASSWORD='this is an example test password'
- export MYSQL_USER='0123456789012345' # "ERROR: 1470 String 'my cool mysql user' is too long for user name (should be no longer than 16)"
- export MYSQL_PASSWORD='my cool mysql password'
- export MYSQL_DATABASE='my cool mysql database'
- cname="mysql-container-$RANDOM-$RANDOM"
- cid="$(
- docker run -d \
- -e MYSQL_ROOT_PASSWORD \
- -e MYSQL_USER \
- -e MYSQL_PASSWORD \
- -e MYSQL_DATABASE \
- --name "$cname" \
- "$image"
- )"
- trap "docker rm -vf $cid > /dev/null" EXIT
- mysql() {
- docker run --rm -i \
- --link "$cname":mysql \
- --entrypoint mysql \
- -e MYSQL_PWD="$MYSQL_PASSWORD" \
- "$image" \
- -hmysql \
- -u"$MYSQL_USER" \
- --silent \
- "$@" \
- "$MYSQL_DATABASE"
- }
- tries=20
- while ! echo 'SELECT 1' | mysql &> /dev/null; do
- (( tries-- ))
- if [ $tries -le 0 ]; then
- echo >&2 'mysqld failed to accept connections in a reasonable amount of time!'
- ( set -x && docker logs "$cid" ) >&2 || true
- echo 'SELECT 1' | mysql # to hopefully get a useful error message
- false
- fi
- echo >&2 -n .
- sleep 2
- done
- echo 'CREATE TABLE test (a INT, b INT, c VARCHAR(255))' | mysql
- [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 0 ]
- echo 'INSERT INTO test VALUES (1, 2, "hello")' | mysql
- [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 1 ]
- echo 'INSERT INTO test VALUES (2, 3, "goodbye!")' | mysql
- [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 2 ]
- echo 'DELETE FROM test WHERE a = 1' | mysql
- [ "$(echo 'SELECT COUNT(*) FROM test' | mysql)" = 1 ]
- [ "$(echo 'SELECT c FROM test' | mysql)" = 'goodbye!' ]
- echo 'DROP TABLE test' | mysql
|