diff options
author | Mohamed Ashiq Liyazudeen <mliyazud@redhat.com> | 2017-05-08 21:08:09 +0530 |
---|---|---|
committer | Mohamed Ashiq Liyazudeen <mliyazud@redhat.com> | 2017-05-08 22:39:07 +0530 |
commit | ec2d37cd987c6aafc7d0d71ab6c2643487d8ef92 (patch) | |
tree | 9d6137f38a97b149c4ef75878745ddd26095e2b2 /tests/Dockerfiletest/test_gluster_dockerfile.sh | |
parent | e63a97ed1b464975c9df07ea07dec3b136fa034a (diff) | |
download | gluster-ec2d37cd987c6aafc7d0d71ab6c2643487d8ef92.tar.gz gluster-ec2d37cd987c6aafc7d0d71ab6c2643487d8ef92.tar.bz2 gluster-ec2d37cd987c6aafc7d0d71ab6c2643487d8ef92.tar.xz gluster-ec2d37cd987c6aafc7d0d71ab6c2643487d8ef92.zip |
Unit Test to check the shell script and Dockerfile lint. Travis.ci intergrated.
Refer: https://github.com/projectatomic/dockerfile_lint
Signed-off-by: Mohamed Ashiq Liyazudeen <mliyazud@redhat.com>
Diffstat (limited to 'tests/Dockerfiletest/test_gluster_dockerfile.sh')
-rwxr-xr-x | tests/Dockerfiletest/test_gluster_dockerfile.sh | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/tests/Dockerfiletest/test_gluster_dockerfile.sh b/tests/Dockerfiletest/test_gluster_dockerfile.sh new file mode 100755 index 0000000..fc52d44 --- /dev/null +++ b/tests/Dockerfiletest/test_gluster_dockerfile.sh @@ -0,0 +1,45 @@ +#!/bin/bash + +SCRIPT_DIR=$(cd $(dirname ${0}); pwd) +TESTS_DIR="${SCRIPT_DIR}/.." +INC_DIR="${TESTS_DIR}/common" +BASE_DIR="${SCRIPT_DIR}/../.." +FAULTY_DOCKERFILE="${SCRIPT_DIR}/Dockerfile_faulty" + +source "${INC_DIR}/subunit.sh" + +check_dockerfilelint_invalid() { + local file="${1}" + check_dockerfilelint ${file} + if [[ "x$?" == "x0" ]]; then + echo "ERROR: parsing invalid Dockerfile succeeded" + return 1 + fi + + return 0 +} + +check_dockerfilelint() { + local file="${1}" + if ! which dockerfile_lint ; then + echo "dockerfile_lint not found: skipping..." + return 0 + fi + + dockerfile_lint -p -f ${file} +} + +failed=0 + + testit "check invalid Dockerfile" \ + check_dockerfilelint_invalid ${FAULTY_DOCKERFILE} \ + || ((failed++)) + + for Dockerfile in $(find ${BASE_DIR} -name "Dockerfile") ; do + testit "check Dockerfile_lint $(basename ${Dockerfile})" \ + check_dockerfilelint ${Dockerfile} \ + || ((failed++)) + done + + +testok $0 ${failed} |