X-Git-Url: https://gerrit.opnfv.org/gerrit/gitweb?a=blobdiff_plain;f=build.sh;h=9ccb16a1cf8decbb33ac5ea5e070d3dacd1c1b2f;hb=39ab5b6cab5d6c664dc96bbb92781a9eed0aa41d;hp=c7efc6384dc82e09e4cdc2beb217262c40f3b104;hpb=9e1e91caba0f9c3a2b5c6874ea0277c86e756806;p=functest.git diff --git a/build.sh b/build.sh index c7efc6384..9ccb16a1c 100644 --- a/build.sh +++ b/build.sh @@ -2,14 +2,50 @@ set -e -repo=${repo:-opnfv} +repo=${REPO:-opnfv} +amd64_dirs=${amd64_dirs-"\ +docker/core \ +docker/tempest \ +docker/healthcheck \ +docker/smoke \ +docker/benchmarking \ +docker/features \ +docker/vnf"} +arm64_dirs=${arm64_dirs-${amd64_dirs}} +build_opts=(--pull=true --no-cache --force-rm=true) -(cd docker && docker build -t "${repo}/functest" .) -docker push "${repo}/functest" +find . -name Dockerfile -exec sed -i \ + -e "s|opnfv/functest-core|${repo}/functest-core:amd64-latest|g" {} + +find . -name Dockerfile -exec sed -i \ + -e "s|opnfv/functest-tempest|${repo}/functest-tempest:amd64-latest|g" {} + +for dir in ${amd64_dirs}; do + (cd "${dir}" && + docker build "${build_opts[@]}" \ + -t "${repo}/functest-${dir##**/}:amd64-latest" .) + docker push "${repo}/functest-${dir##**/}:amd64-latest" + [ "${dir}" != "docker/core" ] && + (docker rmi "${repo}/functest-${dir##**/}:amd64-latest" || true) +done +[ ! -z "${amd64_dirs}" ] && + (docker rmi "${repo}/functest-core:amd64-latest" alpine:3.8 || true) +find . -name Dockerfile -exec git checkout {} + -for dir in docker/core docker/healthcheck docker/smoke docker/features; do - (cd ${dir} && docker build -t "${repo}/functest-${dir##**/}" .) - docker push "${repo}/functest-${dir##**/}" +find . -name Dockerfile -exec sed -i \ + -e "s|alpine:3.8|multiarch/alpine:arm64-v3.8|g" {} + +find . -name Dockerfile -exec sed -i \ + -e "s|opnfv/functest-core|${repo}/functest-core:arm64-latest|g" {} + +find . -name Dockerfile -exec sed -i \ + -e "s|opnfv/functest-tempest|${repo}/functest-tempest:arm64-latest|g" {} + +for dir in ${arm64_dirs}; do + (cd "${dir}" && docker build "${build_opts[@]}" \ + -t "${repo}/functest-${dir##**/}:arm64-latest" .) + docker push "${repo}/functest-${dir##**/}:arm64-latest" + [ "${dir}" != "docker/core" ] && + (docker rmi "${repo}/functest-${dir##**/}:arm64-latest" || true) done +[ ! -z "${arm64_dirs}" ] && + (docker rmi "${repo}/functest-core:arm64-latest" \ + multiarch/alpine:arm64-v3.8 || true) +find . -name Dockerfile -exec git checkout {} + exit $?