blob: ab4b147c05544e1d50d804a5fc0e9aa2a4119443 [file] [log] [blame]
beierlm85dc2392021-04-14 13:51:53 -04001#!/bin/bash
2#######################################################################################
3# Copyright ETSI Contributors and Others.
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
14# implied.
15# See the License for the specific language governing permissions and
16# limitations under the License.
17#######################################################################################
18
beierlme7646252022-01-13 10:53:08 -050019APT_PROXY=""
beierlm85dc2392021-04-14 13:51:53 -040020DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
21HTTPDDIR="$( cd "${HOME}/snap/qhttp/common" &> /dev/null && pwd )"
veleza05f3d9e2021-11-22 11:26:50 +000022HTTPPORT=8000
beierlm85dc2392021-04-14 13:51:53 -040023KUBECFG="~/.osm/microk8s-config.yaml"
24NO_CACHE=""
25OPENSTACKRC="/var/snap/microstack/common/etc/microstack.rc"
26REGISTRY="localhost:32000"
27ROOTDIR="$( cd "${DIR}/../../" &> /dev/null && pwd)"
Mark Beierl7cb878a2023-01-24 21:17:42 -050028DEVEL_TAG="devel"
David Garciaf0014df2021-06-16 10:37:34 +020029OSM_TESTS_IMAGE_TAG="devel"
beierlm85dc2392021-04-14 13:51:53 -040030
31function check_arguments(){
32 while [ $# -gt 0 ] ; do
33 case $1 in
34 --debug) set -x ;;
beierlme7646252022-01-13 10:53:08 -050035 --apt-proxy) APT_PROXY="$2" && shift ;;
Mark Beierl7cb878a2023-01-24 21:17:42 -050036 --devel-tag) DEVEL_TAG="$2" && shift ;;
beierlm85dc2392021-04-14 13:51:53 -040037 --help | -h) show_help && exit 0 ;;
38 --httpddir) HTTPDIR="$2" && shift;;
39 --install-local-registry) 'install_local_registry' ;;
40 --install-microstack) 'install_microstack' ;;
41 --install-qhttpd) INSTALL_HTTPD='install_qhttpd' ;;
42 --kubecfg) KUBECFG="$2" && shift ;;
43 --module) TARGET_MODULE="$2" && shift;;
44 --no-cache) NO_CACHE="--no-cache" ;;
45 --openstackrc) OPENSTACKRC="$2" && shift ;;
46 --registry) REGISTRY="$2" && shift;;
47 --robot-local-mounts) ROBOT_LOCAL=YES ;;
48 --run-tests) TESTS=YES ;;
David Garciaf0014df2021-06-16 10:37:34 +020049 --vim-vca) VIM_VCA="$2" && shift;;
50 --osm-tests-image-tag) OSM_TESTS_IMAGE_TAG="$2" && shift;;
beierlm85dc2392021-04-14 13:51:53 -040051 stage-2) STAGE_2='stage_2 ${TARGET_MODULE}' ;;
52 stage-3) STAGE_3='stage_3 ${TARGET_MODULE}' ;;
53 registry-push) REGISTRY_PUSH='local_registry_push ${TARGET_MODULE}' ;;
54 install-osm) INSTALL_OSM='install_osm' ;;
55 start-robot) START_ROBOT='start_robot' ;;
56 update-install) UPDATE_INSTALL='update_osm_module ${TARGET_MODULE}'
57 REGISTRY_PUSH='local_registry_push ${TARGET_MODULE}' ;;
58 *) echo "Unknown option $1"
59 show_help
60 exit 1;;
61 esac
62 shift
63 done
64}
65
66function show_help() {
67 cat << EOF
68Usage: $0 [OPTIONS]
69Perform a local build and potential installation of OSM from sources, using the
70same process as Jenkins.
71
72OPTIONS:
73 --help display this help message
beierlme7646252022-01-13 10:53:08 -050074 --apt-proxy provide an apt proxy to docker build steps
beierlm85dc2392021-04-14 13:51:53 -040075 --debug enable set -x for this script
beierlme7646252022-01-13 10:53:08 -050076 --install-local-registry install and enable Microk8s local registry on port 32000
beierlm85dc2392021-04-14 13:51:53 -040077 --install-microstack install Microstack and configure to run robot tests
78 --install-qhttpd install QHTTPD as an HTTP server on port ${HTTPPORT}
79 --kubecfg path to kubecfg.yaml (uses Charmed OSM by default)
80 --no-cache do not use any cache when building docker images
81 --module only build this comma delimited list of modules
82 --openstackrc path to Openstack RC file (uses Microstack by default)
83 --registry use this alternate docker registry
84 --run-tests run stage 2 tests
David Garciaf0014df2021-06-16 10:37:34 +020085 --vim-vca name of the a vca registered in OSM to use in the VIM account
86 --osm-tests-image-tag tag to be used in the osm/tests docker image
beierlm85dc2392021-04-14 13:51:53 -040087 stage-2 run the stage 2 build
88 stage-3 run the stage 3 build
89 registry-push push to the local registry
90 install-osm perform full installation of Charmed OSM from registry
91 start-robot start the Robot test container and leave you at prompt
92 update-install update Charmed OSM with new module container
garciadeblas9f5e6d62022-04-22 10:20:08 +020093
94A typical use could be the following:
95
96Let's assume that we have different repos cloned in the folder workspace:
97
98 cd workspace
99 git clone https://osm.etsi.org/gerrit/osm/devops
100 git clone https://osm.etsi.org/gerrit/osm/NBI
101 git clone https://osm.etsi.org/gerrit/osm/LCM
102 git clone "https://osm.etsi.org/gerrit/osm/RO
103 git clone "https://osm.etsi.org/gerrit/osm/common
104 git clone "https://osm.etsi.org/gerrit/osm/IM
105 git clone "https://osm.etsi.org/gerrit/osm/N2VC
106
107First we install a light HTTP server to serve the artifacts:
108
109 devops/tools/local-build.sh --install-qhttpd
110
111Then we generate the artifacts (debian packages) for the different repos: common, IM, N2VC, RO, LCM, NBI
112
113 devops/tools/local-build.sh --module common,IM,N2VC,RO,LCM,NBI stage-2
114
115Then new docker images are generated locally with the tag "devel" (e.g.: opensourcemano/lcm:devel):
116
117 devops/tools/local-build.sh --module RO,LCM,NBI stage-3
118
119Finally, the deployment of OSM will have to be updated to use the new docker images.
120
beierlm85dc2392021-04-14 13:51:53 -0400121EOF
122}
123
David Garciaf0014df2021-06-16 10:37:34 +0200124function print_section() {
125 echo "$@"
126}
127
beierlm85dc2392021-04-14 13:51:53 -0400128function install_local_registry() {
129 sudo snap install microk8s --classic
130 microk8s status --wait-ready
131 microk8s.enable registry
132}
133
134function install_microstack() {
135 sudo snap install microstack --devmode --edge
beierlm6535de32021-06-30 08:05:37 -0400136 sudo snap set microstack config.network.ports.dashboard=8080
beierlm85dc2392021-04-14 13:51:53 -0400137 sudo microstack.init --auto --control
138
139 sudo snap alias microstack.openstack openstack
140 . /var/snap/microstack/common/etc/microstack.rc
141
beierlm6535de32021-06-30 08:05:37 -0400142 for i in $(microstack.openstack security group list | awk '/default/{ print $2 }'); do
143 microstack.openstack security group rule create $i --protocol icmp --remote-ip 0.0.0.0/0
144 microstack.openstack security group rule create $i --protocol tcp --remote-ip 0.0.0.0/0
beierlm85dc2392021-04-14 13:51:53 -0400145 done
146
beierlm6535de32021-06-30 08:05:37 -0400147 microstack.openstack network create --enable --no-share osm-ext
148 microstack.openstack subnet create osm-ext-subnet --network osm-ext --dns-nameserver 8.8.8.8 \
beierlm85dc2392021-04-14 13:51:53 -0400149 --subnet-range 172.30.0.0/24
beierlm6535de32021-06-30 08:05:37 -0400150 microstack.openstack router create external-router
151 microstack.openstack router add subnet external-router osm-ext-subnet
152 microstack.openstack router set --external-gateway external external-router
beierlm85dc2392021-04-14 13:51:53 -0400153
154 curl -L https://github.com/cirros-dev/cirros/releases/download/0.3.5/cirros-0.3.5-x86_64-disk.img \
beierlm6535de32021-06-30 08:05:37 -0400155 | microstack.openstack image create --public --container-format=bare \
beierlm85dc2392021-04-14 13:51:53 -0400156 --disk-format=qcow2 cirros-0.3.5-x86_64-disk.img
157 curl https://cloud-images.ubuntu.com/xenial/current/xenial-server-cloudimg-amd64-disk1.img \
beierlm6535de32021-06-30 08:05:37 -0400158 | microstack.openstack image create --public --container-format=bare \
beierlm85dc2392021-04-14 13:51:53 -0400159 --disk-format=qcow2 ubuntu16.04
160 curl https://cloud-images.ubuntu.com/xenial/current/xenial-server-cloudimg-amd64-disk1.img \
beierlm6535de32021-06-30 08:05:37 -0400161 | microstack.openstack image create --public --container-format=bare \
beierlm85dc2392021-04-14 13:51:53 -0400162 --disk-format=qcow2 US1604
163 curl https://cloud-images.ubuntu.com/bionic/current/bionic-server-cloudimg-amd64.img \
beierlm6535de32021-06-30 08:05:37 -0400164 | microstack.openstack image create --public --container-format=bare \
beierlm85dc2392021-04-14 13:51:53 -0400165 --disk-format=qcow2 ubuntu18.04
166 curl https://cloud-images.ubuntu.com/focal/current/focal-server-cloudimg-amd64.img \
beierlm6535de32021-06-30 08:05:37 -0400167 | microstack.openstack image create --public --container-format=bare \
beierlm85dc2392021-04-14 13:51:53 -0400168 --disk-format=qcow2 ubuntu20.04
169}
170
171function install_qhttpd() {
172 sudo snap install qhttp
garciadeblas9f5e6d62022-04-22 10:20:08 +0200173 EXISTING_PID=$(ps auxw | grep "http.server $HTTPPORT" | grep -v grep | awk '{print $2}')
beierlm85dc2392021-04-14 13:51:53 -0400174 if [ ! -z $EXISTING_PID ] ; then
175 kill $EXISTING_PID
176 fi
Mark Beierl7cb878a2023-01-24 21:17:42 -0500177 nohup qhttp -p ${HTTPPORT} &
beierlm85dc2392021-04-14 13:51:53 -0400178}
179
180function stage_2() {
David Garciaf0014df2021-06-16 10:37:34 +0200181 print_section "Performing Stage 2"
garciadeblasd5029932022-11-25 14:46:38 +0100182 MODULES="common devops IM LCM MON N2VC NBI NG-UI NG-SA osmclient PLA POL RO tests"
beierlm85dc2392021-04-14 13:51:53 -0400183 if [ ! -z ${1} ] ; then
184 POSSIBLE_MODULES=$(echo ${1} | sed "s/,/ /g")
185 for MODULE in ${POSSIBLE_MODULES}; do
186 if ! echo "${MODULES}" | grep -q "${MODULE}" ; then
187 echo "Unknown stage 2 module ${MODULE}"
188 echo "Must be one of ${MODULES}"
189 exit 1
190 fi
191 done
192 MODULES=${POSSIBLE_MODULES}
193 else
David Garciaf0014df2021-06-16 10:37:34 +0200194 print_section "Cleaning HTTP Directory for full build"
beierlm85dc2392021-04-14 13:51:53 -0400195 rm -fv ${HTTPDDIR}/*.deb
196 fi
197
198 for MODULE in ${MODULES} ; do
199 cd "${ROOTDIR}"
200 if [ ! -d ${MODULE} ] ; then
201 echo "Directory ${ROOTDIR}/${MODULE} does not exist"
202 exit 1
203 fi
David Garciaf0014df2021-06-16 10:37:34 +0200204 print_section "Building ${MODULE}"
beierlm85dc2392021-04-14 13:51:53 -0400205 cd ${MODULE}
206 find . -name '*.deb' -exec rm -v {} \;
beierlme7646252022-01-13 10:53:08 -0500207
208 BUILD_ARGS=""
209 if [ ! -z $APT_PROXY ] ; then
210 BUILD_ARGS="${BUILD_ARGS}--build-arg APT_PROXY=${APT_PROXY} "
211 fi
212 docker build ${NO_CACHE} ${BUILD_ARGS} -t ${MODULE,,}-stage2 .
beierlm85dc2392021-04-14 13:51:53 -0400213
214 STAGES="stage-build.sh"
215 if [ ! -z $TESTS ] ; then
216 STAGES="stage-test.sh ${STAGES}"
217 fi
218 for STAGE in $STAGES ; do
Mark Beierl482fcb02023-02-17 21:07:41 +0000219 docker run -i \
beierlm85dc2392021-04-14 13:51:53 -0400220 -v "$(pwd):/build" \
221 -w /build \
222 ${MODULE,,}-stage2 \
223 bash -c "groupadd -o -g $(id -g) -r $USER ;
224 useradd -o -u $(id -u) -d /build -r -g $USER $USER ;
225 runuser $USER -c devops-stages/${STAGE}"
226 if [ $? -ne 0 ] ; then
David Garciaf0014df2021-06-16 10:37:34 +0200227 print_section "Failed to build ${MODULE}"
beierlm85dc2392021-04-14 13:51:53 -0400228 exit 1
229 fi
230 done
Mark Beierl7cb878a2023-01-24 21:17:42 -0500231 for file in `find . -name '*.deb'` ; do
232 name=`basename ${file} | cut -d_ -f1`;
233 rm -v ~/snap/qhttp/common/${name}*
234 cp -v $file ~/snap/qhttp/common/${name}_$(date "+%H%M%S").deb
235 rm -v $file
236 done
beierlm85dc2392021-04-14 13:51:53 -0400237 done
238}
239
240function _find_module_dockerfile() {
241 cd "${ROOTDIR}/devops/docker"
242 MODULES=`find . -name Dockerfile -printf '%h\n' |sed 's|\./||' |sort |tr '\n' ' '`
243 if [ ! -z ${1} ] ; then
244 POSSIBLE_MODULES=$(echo ${1} | sed "s/,/ /g")
245 for MODULE in ${POSSIBLE_MODULES}; do
246 if ! echo "${MODULES}" | grep -q "${MODULE}" ; then
247 echo "Unknown stage 3 module ${MODULE}"
248 echo "Must be one of ${MODULES}"
249 exit 1
250 fi
251 done
252 echo ${POSSIBLE_MODULES}
253 else
254 echo ${MODULES}
255 fi
256}
257
258function stage_3() {
David Garciaf0014df2021-06-16 10:37:34 +0200259 print_section "Performing Stage 3"
beierlm85dc2392021-04-14 13:51:53 -0400260 MODULES=$(_find_module_dockerfile $1)
261 BUILD_ARGS=""
beierlme7646252022-01-13 10:53:08 -0500262 if [ ! -z $APT_PROXY ] ; then
263 BUILD_ARGS="${BUILD_ARGS}--build-arg APT_PROXY=${APT_PROXY} "
264 fi
265
beierlm85dc2392021-04-14 13:51:53 -0400266 HOSTIP=$(ip -4 addr show docker0 | grep -Po 'inet \K[\d.]+')
267 for file in ~/snap/qhttp/common/*.deb ; do
268 file=`basename ${file}`
Mark Beierl7cb878a2023-01-24 21:17:42 -0500269 name=`echo ${file} | cut -d_ -f1 | sed "s/-/_/g" | sed "s/.deb//"`;
beierlm85dc2392021-04-14 13:51:53 -0400270 name=${name^^}_URL
271 BUILD_ARGS="${BUILD_ARGS}--build-arg ${name}=http://$HOSTIP:${HTTPPORT}/$file "
272 echo Added ${name} as http://$HOSTIP:${HTTPPORT}/$file
273 done
274
275 for MODULE in ${MODULES} ; do
276 cd "${ROOTDIR}/devops/docker"
277 if [ ! -d ${MODULE} ] ; then
Mark Beierl482fcb02023-02-17 21:07:41 +0000278 echo "Directory ${ROOTDIR}/devops/docker/${MODULE} does not exist"
beierlm85dc2392021-04-14 13:51:53 -0400279 exit 1
280 fi
David Garciaf0014df2021-06-16 10:37:34 +0200281 print_section "Building ${MODULE}"
beierlm85dc2392021-04-14 13:51:53 -0400282 cd ${MODULE}
283 MODULE=${MODULE,,}
Mark Beierl7cb878a2023-01-24 21:17:42 -0500284 docker build ${NO_CACHE} -t opensourcemano/${MODULE}:${DEVEL_TAG} ${BUILD_ARGS} .
beierlm85dc2392021-04-14 13:51:53 -0400285 if [ $? -ne 0 ] ; then
David Garciaf0014df2021-06-16 10:37:34 +0200286 print_section "Failed to build ${MODULE}"
beierlm85dc2392021-04-14 13:51:53 -0400287 exit 1
288 fi
289 done
290}
291
292function local_registry_push() {
David Garciaf0014df2021-06-16 10:37:34 +0200293 print_section "Pushing to local registry"
beierlm85dc2392021-04-14 13:51:53 -0400294 cd "${ROOTDIR}/devops/docker"
295 MODULES=`find . -name Dockerfile -printf '%h\n' |sed 's|\./||' |sort |tr '\n' ' '`
296 if [ ! -z ${1} ] ; then
297 POSSIBLE_MODULES=$(echo ${1} | sed "s/,/ /g")
298 for MODULE in ${POSSIBLE_MODULES}; do
299 echo "${MODULE}"
300 if ! echo "${MODULES}" | grep -q "${MODULE}" ; then
301 echo "Unknown stage 3 module ${MODULE}"
302 echo "Must be one of ${MODULES}"
303 exit 1
304 fi
305 done
306 MODULES=${POSSIBLE_MODULES}
307 fi
308 for MODULE in ${MODULES} ; do
309 MODULE=${MODULE,,}
Mark Beierl7cb878a2023-01-24 21:17:42 -0500310 docker tag opensourcemano/${MODULE}:${DEVEL_TAG} ${REGISTRY}/opensourcemano/${MODULE}:${DEVEL_TAG}
311 docker push ${REGISTRY}/opensourcemano/${MODULE}:${DEVEL_TAG}
beierlm85dc2392021-04-14 13:51:53 -0400312 done
313}
314
315function install_osm() {
316 cd "${ROOTDIR}/devops/installers"
317 VCA=""
318 if juju controllers 2>/dev/null| grep osm-vca ; then
319 VCA="--vca osm-vca"
320 fi
Mark Beierl7cb878a2023-01-24 21:17:42 -0500321 ./charmed_install.sh --registry localhost:32000 --tag ${DEVEL_TAG} ${VCA}
beierlm85dc2392021-04-14 13:51:53 -0400322}
323
324function start_robot() {
325 mkdir -p "${ROOTDIR}/tests/local"
326 cd "${ROOTDIR}/tests/local"
327
328 . ${OPENSTACKRC}
329
330 # Workaround for microstack auth URL
331 if [ ${OPENSTACKRC} == "/var/snap/microstack/common/etc/microstack.rc" ] ; then
332 export OS_AUTH_URL=${OS_AUTH_URL}/v3
333 fi
334
335 export OSM_HOSTNAME=$(juju config -m osm nbi site_url | sed "s/http.*\?:\/\///"):443
336 export PROMETHEUS_HOSTNAME=$(juju config -m osm prometheus site_url | sed "s/http.*\?:\/\///")
337 export PROMETHEUS_PORT=80
338 export JUJU_PASSWORD=`juju gui 2>&1 | grep password | awk '{print $2}'`
David Garciaf0014df2021-06-16 10:37:34 +0200339 export HOSTIP=$(echo $PROMETHEUS_HOSTNAME | sed "s/prometheus.//" | sed "s/.nip.io//")
beierlm85dc2392021-04-14 13:51:53 -0400340
341 rm robot-systest.cfg
342 for line in `env | grep "^OS_" | sort` ; do echo $line >> robot-systest.cfg ; done
343 cat << EOF >> robot-systest.cfg
344VIM_TARGET=osm
345VIM_MGMT_NET=osm-ext
346ENVIRONMENTS_FOLDER=environments
347PACKAGES_FOLDER=/robot-systest/osm-packages
348OS_CLOUD=openstack
349LC_ALL=C.UTF-8
350LANG=C.UTF-8
351EOF
352
353 cat << EOF > robot.etc.hosts
354127.0.0.1 localhost
David Garciaf0014df2021-06-16 10:37:34 +0200355${HOSTIP} prometheus.${HOSTIP}.nip.io nbi.${HOSTIP}.nip.io
beierlm85dc2392021-04-14 13:51:53 -0400356EOF
357 cat << EOF > clouds.yaml
358clouds:
359 openstack:
360 auth:
361 auth_url: $OS_AUTH_URL
362 project_name: $OS_PROJECT_NAME
363 username: $OS_USERNAME
364 password: $OS_PASSWORD
365 user_domain_name: $OS_USER_DOMAIN_NAME
366 project_domain_name: $OS_PROJECT_DOMAIN_NAME
367EOF
368
369 VIM_AUTH_URL=$(osm vim-show osm | grep vim_url | awk '{print $4}' | tr -d \")
David Garciaf0014df2021-06-16 10:37:34 +0200370 if [[ ! -z ${VIM_AUTH_URL} && "$OS_AUTH_URL" != "${VIM_AUTH_URL}" ]] ; then
beierlm85dc2392021-04-14 13:51:53 -0400371 echo "Deleting existing VIM osm as auth URLs have changed"
372 osm vim-delete osm
373 fi
374
375 if ! osm vim-show osm &> /dev/null ; then
376 echo "Creating VIM osm"
David Garciaf0014df2021-06-16 10:37:34 +0200377 if [ -v VIM_VCA ]; then
378 VCA_OPT="--vca $VIM_VCA"
379 fi
380 osm vim-create --name osm $VCA_OPT --user "$OS_USERNAME" --password "$OS_PASSWORD" \
beierlm85dc2392021-04-14 13:51:53 -0400381 --auth_url "$OS_AUTH_URL" --tenant "$OS_USERNAME" --account_type openstack \
382 --config='{use_floating_ip: True,
383 management_network_name: osm-ext}'
384 fi
385
386 if [ ! -z $ROBOT_LOCAL ] ; then
387 LOCAL_MOUNT_1="/robot-systest/lib"
388 LOCAL_MOUNT_2="/robot-systest/resources"
389 LOCAL_MOUNT_3="/robot-systest/testsuite"
390 else
391 LOCAL_MOUNT_1="/tmp/lib"
392 LOCAL_MOUNT_2="/tmp/resources"
393 LOCAL_MOUNT_3="/tmp/testsuite"
394 fi
395
396 mkdir -p reports
397
398 docker run -ti --entrypoint /bin/bash \
399 --env OSM_HOSTNAME=${OSM_HOSTNAME} \
400 --env PROMETHEUS_HOSTNAME=${PROMETHEUS_HOSTNAME} \
401 --env PROMETHEUS_PORT=${PROMETHEUS_PORT} \
402 --env JUJU_PASSWORD=${JUJU_PASSWORD} \
403 --env HOSTIP=${HOSTIP} \
404 --env-file robot-systest.cfg \
405 -v "$(pwd)/robot.etc.hosts":/etc/hosts \
406 -v ~/.osm/microk8s-config.yaml:/root/.kube/config \
407 -v "$(pwd)/clouds.yaml":/etc/openstack/clouds.yaml \
veleza05f3d9e2021-11-22 11:26:50 +0000408 -v "${HOME}/snap/qhttp/common"/robot-systest/reports \
409 -v "${HOME}/snap/qhttp/common:"/robot-systest/conformance-tests/reports \
beierlm85dc2392021-04-14 13:51:53 -0400410 -v "${ROOTDIR}/tests/robot-systest/lib":${LOCAL_MOUNT_1} \
411 -v "${ROOTDIR}/tests/robot-systest/resources":${LOCAL_MOUNT_2} \
412 -v "${ROOTDIR}/tests/robot-systest/testsuite":${LOCAL_MOUNT_3} \
David Garciaf0014df2021-06-16 10:37:34 +0200413 opensourcemano/tests:$OSM_TESTS_IMAGE_TAG
beierlm85dc2392021-04-14 13:51:53 -0400414}
415
416function update_osm_module() {
417 MODULES=$(_find_module_dockerfile $1)
418 for MODULE in ${MODULES} ; do
419 MODULE=${MODULE,,}
420 echo "Updating ${MODULE}"
Mark Beierl7cb878a2023-01-24 21:17:42 -0500421 juju attach-resource ${MODULE} ${MODULE}-image=localhost:32000/opensourcemano/${MODULE}:${DEVEL_TAG}
beierlm85dc2392021-04-14 13:51:53 -0400422 done
423}
424
425if [ "$0" != "$BASH_SOURCE" ]; then
426
427 _osm_local_build()
428 {
429 OPTIONS=$(show_help | sed '0,/^OPTIONS:$/d' | awk '{print $1}')
430 COMPREPLY=($(compgen -W "${OPTIONS}" -- "${COMP_WORDS[-1]}"))
431 }
432
433 THIS_SCRIPT="$(basename ${BASH_SOURCE[0]})"
434 echo "Setting up bash completion for ${THIS_SCRIPT}"
435 complete -F _osm_local_build "${THIS_SCRIPT}"
436else
437 check_arguments $@
438
439 eval "${INSTALL_HTTPD}"
440 eval "${INSTALL_LOCAL_REGISTRY}"
441 eval "${INSTALL_MICROSTACK}"
442 eval "${STAGE_2}"
443 eval "${STAGE_3}"
444 eval "${REGISTRY_PUSH}"
445 eval "${INSTALL_OSM}"
446 eval "${UPDATE_INSTALL}"
447 eval "${START_ROBOT}"
448fi