X-Git-Url: https://gerrit.opnfv.org/gerrit/gitweb?a=blobdiff_plain;f=build.sh;h=99a9b466fe8097b40a3ae66651b289f7717d097f;hb=b73ef5c67c1fb56589627f273bfe28a194630c42;hp=77ea98bebec4b5796bbb11c6b986bb310aa4b87f;hpb=4d944e52db2c2a39d2417006a9945b949170a916;p=functest.git diff --git a/build.sh b/build.sh index 77ea98beb..99a9b466f 100644 --- a/build.sh +++ b/build.sh @@ -3,19 +3,36 @@ set -e repo=${repo:-opnfv} -dirs="\ +amd64_dirs=${amd64_dirs-"\ docker/core \ docker/healthcheck \ docker/smoke \ docker/features \ -docker/components" +docker/components \ +docker/vnf \ +docker/parser \ +docker/restapi"} +arm64_dirs=${arm64_dirs-$(echo "${amd64_dirs}" | sed -e "s|docker/vnf||" \ + -e "s|docker/restapi||")} +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" {} + +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.7 || true) +find . -name Dockerfile -exec git checkout {} + -for dir in ${dirs}; do - (cd ${dir} && docker build -t "${repo}/functest-${dir##**/}" .) - docker push "${repo}/functest-${dir##**/}" +find . -name Dockerfile -exec sed -i -e "s|alpine:3.7|multiarch/alpine:arm64-v3.7|g" {} + +find . -name Dockerfile -exec sed -i -e "s|opnfv/functest-core|${repo}/functest-core: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.6 || true) +find . -name Dockerfile -exec git checkout {} + exit $?