Merge "Add Rally GnocchiResource scenarios"
[functest.git] / build.sh
1 #!/bin/bash
2
3 set -e
4
5 repo=${REPO:-opnfv}
6 amd64_dirs=${amd64_dirs-"\
7 docker/core \
8 docker/healthcheck \
9 docker/smoke \
10 docker/features \
11 docker/components \
12 docker/vnf \
13 docker/parser"}
14 arm64_dirs=${arm64_dirs-${amd64_dirs}}
15 build_opts=(--pull=true --no-cache --force-rm=true)
16
17 find . -name Dockerfile -exec sed -i \
18     -e "s|opnfv/functest-core|${repo}/functest-core:amd64-latest|g" {} +
19 for dir in ${amd64_dirs}; do
20     (cd "${dir}" &&
21         docker build "${build_opts[@]}" \
22             -t "${repo}/functest-${dir##**/}:amd64-latest" .)
23         docker push "${repo}/functest-${dir##**/}:amd64-latest"
24     [ "${dir}" != "docker/core" ] &&
25         (docker rmi "${repo}/functest-${dir##**/}:amd64-latest" || true)
26 done
27 [ ! -z "${amd64_dirs}" ] &&
28     (docker rmi "${repo}/functest-core:amd64-latest" alpine:3.7 || true)
29 find . -name Dockerfile -exec git checkout {} +
30
31 find . -name Dockerfile -exec sed -i \
32     -e "s|alpine:3.7|multiarch/alpine:arm64-v3.7|g" {} +
33 find . -name Dockerfile -exec sed -i \
34     -e "s|opnfv/functest-core|${repo}/functest-core:arm64-latest|g" {} +
35 for dir in ${arm64_dirs}; do
36     (cd "${dir}" && docker build "${build_opts[@]}" \
37         -t "${repo}/functest-${dir##**/}:arm64-latest" .)
38     docker push "${repo}/functest-${dir##**/}:arm64-latest"
39     [ "${dir}" != "docker/core" ] &&
40         (docker rmi "${repo}/functest-${dir##**/}:arm64-latest" || true)
41 done
42 [ ! -z "${arm64_dirs}" ] &&
43     (docker rmi "${repo}/functest-core:arm64-latest" \
44         multiarch/alpine:arm64-v3.7 || true)
45 find . -name Dockerfile -exec git checkout {} +
46
47 exit $?