Run integration tests with multiple Docker engine versions
Add a run_multiversion.sh script that downloads a variety of Docker engines and runs the integration tests against each of them. Skip some of the tests when running with Docker 1.6.0. It has a bug that prevents these tests from completing successfully. Fixes #751 Signed-off-by: Aaron Lehmann <aaron.lehmann@docker.com>
This commit is contained in:
parent
2b74c46795
commit
e564231f58
2 changed files with 57 additions and 0 deletions
46
contrib/docker-integration/run_multiversion.sh
Executable file
46
contrib/docker-integration/run_multiversion.sh
Executable file
|
@ -0,0 +1,46 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Run the integration tests with multiple versions of the Docker engine
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Don't use /tmp because this isn't available in boot2docker
|
||||||
|
tmpdir_template="`pwd`/docker-versions.XXXXX"
|
||||||
|
tmpdir=`mktemp -d "$tmpdir_template"`
|
||||||
|
trap "rm -rf $tmpdir" EXIT
|
||||||
|
|
||||||
|
# If DOCKER_VOLUME is unset, create a temporary directory to cache containers
|
||||||
|
# between runs
|
||||||
|
# Only do this on Linux, because using /var/lib/docker from a host volume seems
|
||||||
|
# problematic with boot2docker.
|
||||||
|
if [ "$DOCKER_VOLUME" = "" -a `uname` = "Linux" ]; then
|
||||||
|
volumes_template="`pwd`/docker-versions.XXXXX"
|
||||||
|
volume=`mktemp -d "$volumes_template"`
|
||||||
|
trap "rm -rf $tmpdir $volume" EXIT
|
||||||
|
else
|
||||||
|
volume="$DOCKER_VOLUME"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Released versions
|
||||||
|
|
||||||
|
versions="1.6.0 1.7.0"
|
||||||
|
|
||||||
|
for v in $versions; do
|
||||||
|
echo "Downloading Docker $v"
|
||||||
|
binpath="$tmpdir/docker-$v"
|
||||||
|
curl -L -o "$binpath" "https://test.docker.com/builds/Linux/x86_64/docker-$v"
|
||||||
|
chmod +x "$binpath"
|
||||||
|
echo "Running tests with Docker $v"
|
||||||
|
DOCKER_BINARY="$binpath" DOCKER_VOLUME="$volume" ./run.sh
|
||||||
|
done
|
||||||
|
|
||||||
|
# Latest experimental version
|
||||||
|
|
||||||
|
# Extract URI from https://experimental.docker.com/builds/
|
||||||
|
experimental=`curl -sSL https://experimental.docker.com/builds/ | tr " " "\n" | grep 'https://experimental.docker.com/builds/Linux/'`
|
||||||
|
echo "Downloading Docker experimental"
|
||||||
|
binpath="$tmpdir/docker-experimental"
|
||||||
|
curl -L -o "$binpath" "$experimental"
|
||||||
|
chmod +x "$binpath"
|
||||||
|
echo "Running tests with Docker experimental"
|
||||||
|
DOCKER_BINARY="$binpath" DOCKER_VOLUME="$volume" ./run.sh
|
|
@ -13,6 +13,15 @@ function setup() {
|
||||||
docker pull $image
|
docker pull $image
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# skip basic auth tests with Docker 1.6, where they don't pass due to
|
||||||
|
# certificate issues
|
||||||
|
function basic_auth_version_check() {
|
||||||
|
run sh -c 'docker version | fgrep -q "Client version: 1.6.0"'
|
||||||
|
if [ "$status" -eq 0 ]; then
|
||||||
|
skip "Basic auth tests don't support 1.6.0"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# has_digest enforces the last output line is "Digest: sha256:..."
|
# has_digest enforces the last output line is "Digest: sha256:..."
|
||||||
# the input is the name of the array containing the output lines
|
# the input is the name of the array containing the output lines
|
||||||
function has_digest() {
|
function has_digest() {
|
||||||
|
@ -35,6 +44,7 @@ function login() {
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "Test basic auth" {
|
@test "Test basic auth" {
|
||||||
|
basic_auth_version_check
|
||||||
login $hostname:5441
|
login $hostname:5441
|
||||||
docker tag -f $image $hostname:5441/$image
|
docker tag -f $image $hostname:5441/$image
|
||||||
run docker push $hostname:5441/$image
|
run docker push $hostname:5441/$image
|
||||||
|
@ -56,6 +66,7 @@ function login() {
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "Test basic auth with TLS client auth" {
|
@test "Test basic auth with TLS client auth" {
|
||||||
|
basic_auth_version_check
|
||||||
login $hostname:5444
|
login $hostname:5444
|
||||||
docker tag -f $image $hostname:5444/$image
|
docker tag -f $image $hostname:5444/$image
|
||||||
run docker push $hostname:5444/$image
|
run docker push $hostname:5444/$image
|
||||||
|
|
Loading…
Reference in a new issue