#!/bin/bash -x # # The 'run' performs a simple test that verifies that STI image. # The main focus here is to excersise the STI scripts. # # IMAGE_NAME specifies a name of the candidate image used for testing. # The image has to be available before this script is executed. # IMAGE_NAME=${IMAGE_NAME-openshift/ruby-22-centos7-candidate} declare -a WEB_SERVERS=(db puma rack) #declare -a WEB_SERVERS=(db) # TODO: Make command compatible for Mac users test_dir="$(readlink -zf $(dirname "${BASH_SOURCE[0]}"))" image_dir=$(readlink -zf ${test_dir}/..) # TODO: This should be part of the image metadata test_port=8080 info() { echo -e "\n\e[1m[INFO] $@...\e[0m\n" } image_exists() { docker inspect $1 &>/dev/null } container_exists() { image_exists $(cat $cid_file) } container_ip() { docker inspect --format="{{ .NetworkSettings.IPAddress }}" $(cat $cid_file) } run_sti_build() { s2i build ${sti_args} file://${test_dir}/${1}-test-app ${IMAGE_NAME} ${IMAGE_NAME}-testapp } prepare() { if ! image_exists ${IMAGE_NAME}; then echo "ERROR: The image ${IMAGE_NAME} must exist before this script is executed." exit 1 fi # TODO: STI build require the application is a valid 'GIT' repository, we # should remove this restriction in the future when a file:// is used. info "Build the test application image" pushd ${test_dir}/${1}-test-app >/dev/null git init git config user.email "build@localhost" && git config user.name "builder" git add -A && git commit -m "Sample commit" popd >/dev/null } run_test_application() { docker run --user=10001 --rm --cidfile=${cid_file} ${IMAGE_NAME}-testapp } cleanup() { info "Cleaning up the test application image $1" if [ -f $cid_file ]; then if container_exists; then docker stop $(cat $cid_file) fi fi if image_exists ${IMAGE_NAME}-testapp; then docker rmi -f ${IMAGE_NAME}-testapp fi rm -rf ${test_dir}/${1}-test-app/.git if [[ $1 == "db" ]]; then rm -rf ${test_dir}/db-test-app fi } check_result() { local result="$1" if [[ "$result" != "0" ]]; then info "TEST FAILED (${result})" cleanup exit $result fi } wait_for_cid() { local max_attempts=10 local sleep_time=1 local attempt=1 local result=1 info "Waiting for application container to start" while [ $attempt -le $max_attempts ]; do [ -f $cid_file ] && [ -s $cid_file ] && break attempt=$(( $attempt + 1 )) sleep $sleep_time done } test_sti_usage() { info "Testing 's2i usage'" s2i usage ${sti_args} ${IMAGE_NAME} &>/dev/null } test_docker_run_usage() { info "Testing 'docker run' usage" docker run ${IMAGE_NAME} &>/dev/null } test_connection() { info "Testing the HTTP connection (http://$(container_ip):${test_port})" local max_attempts=10 local sleep_time=1 local attempt=1 local result=1 local tmpout=$(mktemp /tmp/test-passenger-XXXXXX) while [ $attempt -le $max_attempts ]; do response_code=$(curl -s -w %{http_code} -o ${tmpout} http://$(container_ip):${test_port}/) status=$? if [ $status -eq 0 ]; then if [ $response_code -eq 200 ]; then result=0 else echo "ERROR[curl] got response_code $response_code, out is:" cat ${tmpout} fi break fi attempt=$(( $attempt + 1 )) sleep $sleep_time done return $result } test_scl_usage() { local run_cmd="$1" local expected="$2" info "Testing the image SCL enable" out=$(docker run --rm ${IMAGE_NAME} /bin/bash -c "${run_cmd}") if ! echo "${out}" | grep -q "${expected}"; then echo "ERROR[/bin/bash -c "${run_cmd}"] Expected '${expected}', got '${out}'" return 1 fi # out=$(docker run --rm -i ${IMAGE_NAME} /bin/bash -i <<< "${run_cmd}") # if ! echo "${out}" | grep -q "${expected}"; then # echo "ERROR[-i /bin/bash -c "${run_cmd}"] Expected '${expected}', got '${out}'" # return 1 # fi # out=$(docker run --rm -i ${IMAGE_NAME} /bin/bash -l <<< "${run_cmd}") # if ! echo "${out}" | grep -q "${expected}"; then # echo "ERROR[-i /bin/bash -l "${run_cmd}"] Expected '${expected}', got '${out}'" # return 1 # fi # out=$(docker run --rm -i ${IMAGE_NAME} /bin/sh -ic "${run_cmd}") # if ! echo "${out}" | grep -q "${expected}"; then # echo "ERROR[/bin/sh -c "${run_cmd}"] Expected '${expected}', got '${out}'" # return 1 # fi out=$(docker exec $(cat ${cid_file}) /bin/bash -c "${run_cmd}" 2>&1) if ! echo "${out}" | grep -q "${expected}"; then echo "ERROR[exec /bin/bash -c "${run_cmd}"] Expected '${expected}', got '${out}'" return 1 fi out=$(docker exec $(cat ${cid_file}) /bin/sh -ic "${run_cmd}" 2>&1) if ! echo "${out}" | grep -q "${expected}"; then echo "ERROR[exec /bin/sh -ic "${run_cmd}"] Expected '${expected}', got '${out}'" return 1 fi } pushd ${test_dir} rm -rf ruby-hello-world db-test-app git clone git://github.com/openshift/ruby-hello-world mv ruby-hello-world db-test-app popd for server in ${WEB_SERVERS[@]}; do cid_file=$(mktemp -u --suffix=.cid) # Since we built the candidate image locally, we don't want STI attempt to pull # it from Docker hub sti_args="--force-pull=false" prepare ${server} run_sti_build ${server} check_result $? # Verify the 'usage' script is working properly when running the base image with 's2i usage ...' test_sti_usage check_result $? # Verify the 'usage' script is working properly when running the base image with 'docker run ...' test_docker_run_usage check_result $? # Verify that the HTTP connection can be established to test application container run_test_application & # Wait for the container to write it's CID file wait_for_cid test_connection check_result $? test_scl_usage "ruby --version" "ruby 2." check_result $? info "All tests for the ${server}-test-app finished successfully." cleanup ${server} done info "All tests finished successfully."