Merge "add loop to ensure DHCP ran"
[dcaegen2/platform/blueprints.git] / mvn-phase-lib.sh
1 #!/bin/bash
2
3 # ================================================================================
4 # Copyright (c) 2017 AT&T Intellectual Property. All rights reserved.
5 # ================================================================================
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
9 #
10 #     http://www.apache.org/licenses/LICENSE-2.0
11 #
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
17 # ============LICENSE_END=========================================================
18 #
19 # ECOMP is a trademark and service mark of AT&T Intellectual Property.
20
21
22 #MVN_PROJECT_MODULEID="$1"
23 #MVN_PHASE="$2"
24 #PROJECT_ROOT=$(dirname $0)
25
26 FQDN="${MVN_PROJECT_GROUPID}.${MVN_PROJECT_ARTIFACTID}"
27 if [ "$MVN_PROJECT_MODULEID" == "__" ]; then
28   MVN_PROJECT_MODULEID=""
29 fi
30
31 if [[ "$MVN_PROJECT_VERSION" == *SNAPSHOT ]]; then
32   echo "=> for SNAPSHOT artifact build"
33   MVN_DEPLOYMENT_TYPE='SNAPSHOT'
34 else
35   echo "=> for STAGING/RELEASE artifact build"
36   MVN_DEPLOYMENT_TYPE='STAGING'
37 fi
38 echo "MVN_DEPLOYMENT_TYPE is             [$MVN_DEPLOYMENT_TYPE]"
39
40
41 TIMESTAMP=$(date +%C%y%m%dT%H%M%S)
42
43 # expected environment variables
44 if [ -z "${MVN_NEXUSPROXY}" ]; then
45     echo "MVN_NEXUSPROXY environment variable not set.  Cannot proceed"
46     exit
47 fi
48 MVN_NEXUSPROXY_HOST=$(echo "$MVN_NEXUSPROXY" |cut -f3 -d'/' | cut -f1 -d':')
49 echo "=> Nexus Proxy at $MVN_NEXUSPROXY_HOST, $MVN_NEXUSPROXY"
50
51 if [ -z "$WORKSPACE" ]; then
52     WORKSPACE=$(pwd)
53 fi
54
55 if [ -z "$SETTINGS_FILE" ]; then
56     echo "SETTINGS_FILE environment variable not set.  Cannot proceed"
57     exit
58 fi
59
60
61
62 # mvn phase in life cycle
63 MVN_PHASE="$2"
64
65 echo "MVN_PROJECT_MODULEID is            [$MVN_PROJECT_MODULEID]"
66 echo "MVN_PHASE is                       [$MVN_PHASE]"
67 echo "MVN_PROJECT_GROUPID is             [$MVN_PROJECT_GROUPID]"
68 echo "MVN_PROJECT_ARTIFACTID is          [$MVN_PROJECT_ARTIFACTID]"
69 echo "MVN_PROJECT_VERSION is             [$MVN_PROJECT_VERSION]"
70 echo "MVN_NEXUSPROXY is                  [$MVN_NEXUSPROXY]"
71 echo "MVN_RAWREPO_BASEURL_UPLOAD is      [$MVN_RAWREPO_BASEURL_UPLOAD]"
72 echo "MVN_RAWREPO_BASEURL_DOWNLOAD is    [$MVN_RAWREPO_BASEURL_DOWNLOAD]"
73 MVN_RAWREPO_HOST=$(echo "$MVN_RAWREPO_BASEURL_UPLOAD" | cut -f3 -d'/' |cut -f1 -d':')
74 echo "MVN_RAWREPO_HOST is                [$MVN_RAWREPO_HOST]"
75 echo "MVN_RAWREPO_SERVERID is            [$MVN_RAWREPO_SERVERID]"
76 echo "MVN_DOCKERREGISTRY_SNAPSHOT is     [$MVN_DOCKERREGISTRY_SNAPSHOT]"
77 echo "MVN_DOCKERREGISTRY_PUBLIC is       [$MVN_DOCKERREGISTRY_PUBLIC]"
78 echo "MVN_DOCKERREGISTRY_RELEASE is      [$MVN_DOCKERREGISTRY_RELEASE]"
79
80 echo "MVN_PYPISERVER_SERVERID            [$MVN_PYPISERVER_SERVERID]"
81 echo "MVN_PYPISERVER_BASEURL is          [$MVN_PYPISERVER_BASEURL]"
82
83
84
85 clean_templated_files() 
86 {
87   TEMPLATE_FILES=$(find . -name "*-template")
88   for F in $TEMPLATE_FILES; do
89     F2=$(echo "$F" | sed 's/-template$//')
90     rm -f "$F2"
91   done
92 }
93 clean_tox_files() 
94 {
95   TOX_FILES=$(find . -name ".tox")
96   TOX_FILES="$TOX_FILES $(find . -name 'venv-tox')"
97   for F in $TOX_FILES; do
98     rm -rf "$F"
99   done
100 }
101
102 expand_templates() 
103 {
104   set +x
105   # set up env variables, get ready for template resolution
106   # NOTE: CCSDK artifacts do not distinguish REALESE vs SNAPSHOTs
107   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_platform_plugins_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.platform.plugins"
108   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_platform_plugins_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.platform.plugins"
109   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_platform_blueprints_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.platform.blueprints"
110   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_platform_blueprints_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.platform.blueprints"
111   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_storage_pgaas_debs_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.storage.pgaas/snapshots"
112   export ONAPTEMPLATE_RAWREPOURL_org_onap_ccsdk_storage_pgaas_debs_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.ccsdk.storage.pgaas/releases"
113
114   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2/releases"
115   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2/snapshots"
116   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_platform_plugins_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2.platform.plugins/releases"
117   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_platform_plugins_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2.platform.plugins/snapshots"
118   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_platform_blueprints_releases="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2.platform.blueprints/releases"
119   export ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2_platform_blueprints_snapshots="$MVN_RAWREPO_BASEURL_DOWNLOAD/org.onap.dcaegen2.platform.blueprints/snapshots"
120
121   export ONAPTEMPLATE_PYPIURL_org_onap_dcaegen2="${MVN_PYPISERVER_BASEURL}"
122
123   # docker registry templates are for poll, so use PUBLIC registry
124   export ONAPTEMPLATE_DOCKERREGURL_org_onap_dcaegen2_releases="$MVN_DOCKERREGISTRY_PUBLIC"
125   export ONAPTEMPLATE_DOCKERREGURL_org_onap_dcaegen2_snapshots="${MVN_DOCKERREGISTRY_PUBLIC}/snapshots"
126
127   # Mvn repo
128   export ONAPTEMPLATE_MVN_org_onap_dcaegen2_analytics_tca_snapshots="${MVN_NEXUSPROXY}/service/local/repositories/snapshots/content/org/onap/dcaegen2/analytics/tca"
129   export ONAPTEMPLATE_MVN_org_onap_dcaegen2_analytics_tca_staging="${MVN_NEXUSPROXY}/service/local/repositories/staging/content/org/onap/dcaegen2/analytics/tca"
130   export ONAPTEMPLATE_MVN_org_onap_dcaegen2_analytics_tca_releases="${MVN_NEXUSPROXY}/service/local/repositories/releases/content/org/onap/dcaegen2/analytics/tca"
131
132
133   export ONAPTEMPLATE_STANDARD_INPUTS_TYPES="  # standard inputs list
134   centos7image_id:
135     type: string
136   ubuntu1604image_id:
137     type: string
138   flavor_id:
139     type: string
140   security_group:
141     type: string
142   public_net:
143     type: string
144   private_net:
145     type: string
146   openstack: {}
147   keypair:
148     type: string
149   key_filename:
150     type: string
151   location_prefix:
152     type: string
153   location_domain:
154     type: string
155   codesource_url:
156     type: string
157   codesource_version:
158     type: string"
159
160
161   TEMPLATES=$(env |grep ONAPTEMPLATE | sed 's/=.*//' | sort -u)
162   if [ -z "$TEMPLATES" ]; then
163     echo "No template variables found!"
164     return 0
165   fi
166
167   TEMPLATE_FILES=$(find . -name "*-template")
168   for F in $TEMPLATE_FILES; do
169     F2=$(echo "$F" | sed 's/-template$//')
170     cp -p "$F" "$F2"
171     chmod u+w "$F2"
172    
173     echo "====> Resolving the following template from environment variables "
174     echo "$TEMPLATES"
175     for KEY in $TEMPLATES; do
176       VALUE1=$(eval 'echo "$'"$KEY"'"' | sed 1q)
177       VALUE2=$(eval 'echo "$'"$KEY"'"' | sed -e 's/\//\\\//g' -e 's/$/\\/' -e '$s/\\$//')
178       if [ -z "$VALUE2" ];then echo "WARNING WARNING WARNING: $KEY found with no expansion"; fi
179
180       echo "======> Resolving template $KEY to value $VALUE1 for file $F2"
181       sed -i "s/{{[[:space:]]*$KEY[[:space:]]*}}/$VALUE2/g" "$F2"
182     done
183   done
184   echo "====> Done template resolving"
185 }
186
187 test_templates()
188 {
189     # make certain that the type references exist
190     TMP=$(mktemp)
191     trap 'rm -f $TMP' 0 1 2 3 15
192
193     echo Verify that all of the import URLs are correct
194     find . -name '*-template' | sed -e 's/-template$//' |
195     while read file
196     do
197         egrep '^  - .?https?://' < $file
198     done  | awk '{print $2}' | sed -e 's/"//g' | sort -u |
199     while read url
200     do
201         curl -L -w '%{http_code}' -s -o /dev/null "$url" > $TMP
202         case $(< $TMP) in
203             2* ) ;;
204             * ) echo ">>>>>>>>>>>>>>>> $url not found <<<<<<<<<<<<<<<<" ;;
205         esac
206     done
207
208     echo Verify that the inputs are correct
209     PATH=$PATH:$PROJECT_ROOT/check-blueprint-vs-input/bin
210     find . -name '*-template' | sed -e 's/-template$//' |
211     while read blueprint
212     do
213         check-blueprint-vs-input -b $blueprint -i $PROJECT_ROOT/check-blueprint-vs-input/lib/sample-inputs.yaml || true
214     done |
215     sed -e 's/^/WARNING WARNING WARNING: /'
216 }
217
218
219 run_tox_test() 
220
221   set -x
222   CURDIR=$(pwd)
223   TOXINIS=$(find . -name "tox.ini")
224   for TOXINI in "${TOXINIS[@]}"; do
225     DIR=$(echo "$TOXINI" | rev | cut -f2- -d'/' | rev)
226     cd "${CURDIR}/${DIR}"
227     rm -rf ./venv-tox ./.tox
228     virtualenv ./venv-tox
229     source ./venv-tox/bin/activate
230     pip install --upgrade pip
231     pip install --upgrade tox argparse
232     pip freeze
233     tox
234     deactivate
235     rm -rf ./venv-tox ./.tox
236   done
237 }
238
239 build_wagons() 
240 {
241   rm -rf ./*.wgn venv-pkg
242   SETUPFILES=$(find . -name "setup.py")
243   
244   virtualenv ./venv-pkg
245   source ./venv-pkg/bin/activate
246   pip install --upgrade pip 
247   pip install wagon
248   
249   CURDIR=$(pwd)
250   for SETUPFILE in $SETUPFILES; do
251     PLUGIN_DIR=$(dirname "$SETUPFILE")
252     PLUGIN_NAME=$(grep 'name' "$SETUPFILE" | cut -f2 -d'=' | sed 's/[^0-9a-zA-Z\.]*//g')
253     PLUGIN_VERSION=$(grep 'version' "$SETUPFILE" | cut -f2 -d'=' | sed 's/[^0-9\.]*//g')
254
255     echo "In $PLUGIN_DIR, build plugin $PLUGIN_NAME, version $PLUGIN_VERSION"
256
257     wagon create --format tar.gz "${PLUGIN_DIR}"
258
259     PKG_FILE_NAMES=( "${PLUGIN_NAME}-${PLUGIN_VERSION}"*.wgn )
260     echo Built package: "${PKG_FILE_NAMES[@]}"
261     cd $CURDIR
262   done
263
264   deactivate
265   rm -rf venv-pkg
266 }
267
268
269 upload_raw_file() 
270 {
271   # Extract the username and password to the nexus repo from the settings file
272   USER=$(xpath -q -e "//servers/server[id='$MVN_RAWREPO_SERVERID']/username/text()" "$SETTINGS_FILE")
273   PASS=$(xpath -q -e "//servers/server[id='$MVN_RAWREPO_SERVERID']/password/text()" "$SETTINGS_FILE")
274   NETRC=$(mktemp)
275   echo "machine $MVN_RAWREPO_HOST login $USER password $PASS" > "$NETRC"
276
277   REPO="$MVN_RAWREPO_BASEURL_UPLOAD"
278
279   OUTPUT_FILE=$1
280   EXT=$(echo "$OUTPUT_FILE" | rev |cut -f1 -d '.' |rev)
281   if [ "$EXT" == 'yaml' ]; then
282     OUTPUT_FILE_TYPE='text/x-yaml'
283   elif [ "$EXT" == 'sh' ]; then
284     OUTPUT_FILE_TYPE='text/x-shellscript'
285   elif [ "$EXT" == 'gz' ]; then
286     OUTPUT_FILE_TYPE='application/gzip'
287   elif [ "$EXT" == 'wgn' ]; then
288     OUTPUT_FILE_TYPE='application/gzip'
289   else
290     OUTPUT_FILE_TYPE='application/octet-stream'
291   fi
292
293   # for multi module projects, the raw repo path must match with project name, not project + module
294   # FQDN is project + module
295   # GROUPID is project name
296   if [ "$MVN_PROJECT_ARTIFACTID" == "$MVN_PROJECT_MODULEID" ]; then
297     PROJECT_NAME=${MVN_PROJECT_GROUPID}
298   else
299     PROJECT_NAME=${FQDN}
300   fi
301   if [ "$MVN_DEPLOYMENT_TYPE" == 'SNAPSHOT' ]; then
302     SEND_TO="${REPO}/${PROJECT_NAME}/snapshots"
303   elif [ "$MVN_DEPLOYMENT_TYPE" == 'STAGING' ]; then
304     SEND_TO="${REPO}/${PROJECT_NAME}/releases"
305   else
306     echo "Unreconfnized deployment type, quit"
307     exit
308   fi
309   #if [ ! -z "$MVN_PROJECT_MODULEID" ]; then
310   #  SEND_TO="$SEND_TO/$MVN_PROJECT_MODULEID"
311   #fi
312   if [ ! -z "$2" ]; then
313     SEND_TO="$SEND_TO/$2"
314   fi
315
316   echo "Sending ${OUTPUT_FILE} to Nexus: ${SEND_TO}"
317   curl -vkn --netrc-file "${NETRC}" --upload-file "${OUTPUT_FILE}" -X PUT -H "Content-Type: $OUTPUT_FILE_TYPE" "${SEND_TO}/${OUTPUT_FILE}-${TIMESTAMP}"
318   curl -vkn --netrc-file "${NETRC}" --upload-file "${OUTPUT_FILE}" -X PUT -H "Content-Type: $OUTPUT_FILE_TYPE" "${SEND_TO}/${OUTPUT_FILE}"
319 }
320
321
322
323 upload_wagons_and_type_yamls()
324 {
325   SETUPFILES=$(find . -name "setup.py")
326
327   CURDIR=$(pwd)
328   for SETUPFILE in $SETUPFILES; do
329     PLUGIN_DIR=$(dirname "$SETUPFILE")
330     PLUGIN_NAME=$(grep 'name' "$SETUPFILE" | cut -f2 -d'=' | sed 's/[^0-9a-zA-Z\.]*//g')
331     PLUGIN_VERSION=$(grep 'version' "$SETUPFILE" | cut -f2 -d'=' | sed 's/[^0-9\.]*//g')
332     PLUGIN_VERSION_MAJOR=$(echo "$PLUGIN_VERSION" | cut -f1 -d'.')
333     PLUGIN_VERSION_MAJOR_MINOR=$(echo "$PLUGIN_VERSION" | cut -f1-2 -d'.')
334
335     echo "Found setup file in $PLUGIN_DIR, for plugin $PLUGIN_NAME version $PLUGIN_VERSION"
336
337     TYPEFILE_NAME=$(grep -R "package_name:[[:space:]]*${PLUGIN_NAME}" | cut -f1 -d ':')
338     if [ -z "$TYPEFILE_NAME" ]; then
339       echo "!!! No typefile found with matching package name $PLUGIN_NAME"
340       exit -1
341     fi
342     NEWFILENAME="${PLUGIN_NAME}"_types.yaml
343     if [ "$TYPEFILE_NAME" != "$NEWFILENAME" ]; then
344       echo "copy typefile to standard naming"
345       cp -f "$TYPEFILE_NAME" "$NEWFILENAME"
346     fi
347
348     TYPEFILE_PACKAGE_VERSION=$(grep -R 'package_version' $TYPEFILE_NAME |cut -f2 -d ':' |sed -r 's/\s+//g')
349     WAGONFILE_NAME=$(ls -1 $PLUGIN_NAME-$TYPEFILE_PACKAGE_VERSION-*.wgn)
350     if [ -z "$WAGONFILE_NAME" ]; then
351       echo "!!! No wagonfile found with matching package name and version as required in typefile: "
352       echo "    $TYPEFILE_NAME plugin $PLUGIN_NAME package version ${TYPEFILE_PACKAGE_VERSION}"
353       exit -1
354     fi
355
356     upload_raw_file "$NEWFILENAME" type_files/${PLUGIN_NAME}/${PLUGIN_VERSION_MAJOR}
357     upload_raw_file "$NEWFILENAME" type_files/${PLUGIN_NAME}/${PLUGIN_VERSION_MAJOR_MINOR}
358     upload_raw_file "${WAGONFILE_NAME}" "plugins/${PLUGIN_NAME}"
359    
360     rm -r $WAGONFILE_NAME
361     if [ "$TYPEFILE_NAME" != "$NEWFILENAME" ]; then
362       rm -f "$NEWFILENAME"
363     fi
364   done
365 }
366
367 upload_files_of_extension()
368 {
369   FILES=$(ls -1 ./*."$1")
370   for F in $FILES ; do
371     upload_raw_file "$F" "$2"
372   done
373 }
374
375
376 generate_pypirc_then_publish() 
377 {
378   set +x
379   USER=$(xpath -e "//servers/server[id='$MVN_PYPISERVER_SERVERID']/username/text()" "$SETTINGS_FILE")
380   PASS=$(xpath -e "//servers/server[id='$MVN_PYPISERVER_SERVERID']/password/text()" "$SETTINGS_FILE")
381
382   if [[ "$MVN_PYPISERVER_BASEURL" != */ ]]; then
383     MVN_PYPISERVER_BASEURL="${MVN_PYPISERVER_BASEURL}/"
384   fi
385  
386
387   cat > ~/.pypirc <<EOL
388 [distutils]
389 index-servers = 
390   $MVN_PYPISERVER_SERVERID
391  
392 [$MVN_PYPISERVER_SERVERID]
393 repository: $MVN_PYPISERVER_BASEURL
394 username: $USER
395 password: $PASS
396 EOL
397
398   # this may fail if a package of same version exists
399   python setup.py sdist register -r "$MVN_PYPISERVER_SERVERID" upload -r "$MVN_PYPISERVER_SERVERID"
400   set -x
401 }
402
403
404
405 build_and_push_docker()
406 {
407   IMAGENAME="onap/${FQDN}.${MVN_PROJECT_MODULEID}"
408   IMAGENAME=$(echo "$IMAGENAME" | sed -e 's/_*$//g' -e 's/\.*$//g')
409   IMAGENAME=$(echo "$IMAGENAME" | tr '[:upper:]' '[:lower:]')
410
411   # use the major and minor version of the MVN artifact version as docker image version
412   VERSION="${MVN_PROJECT_VERSION//[^0-9.]/}"
413   VERSION2=$(echo "$VERSION" | cut -f1-2 -d'.')
414
415   LFQI="${IMAGENAME}:${VERSION}-${TIMESTAMP}"
416   # build a docker image
417   docker build --rm -f ./Dockerfile -t "${LFQI}" ./
418
419   REPO=""
420   if [ $MVN_DEPLOYMENT_TYPE == "SNAPSHOT" ]; then
421      REPO=$MVN_DOCKERREGISTRY_SNASHOT
422   elif [ $MVN_DEPLOYMENT_TYPE == "STAGING" ]; then
423      # there seems to be no staging docker registry?  set to use SNAPSHOT also
424      REPO=$MVN_DOCKERREGISTRY_RELEASE
425   else
426      echo "Fail to determine DEPLOYMENT_TYPE"
427      REPO=$MVN_DOCKERREGISTRY_SNAPSHOT
428   fi
429   echo "DEPLOYMENT_TYPE is: $MVN_DEPLOYMENT_TYPE, repo is $REPO"
430
431   if [ ! -z "$REPO" ]; then
432     USER=$(xpath -e "//servers/server[id='$REPO']/username/text()" "$SETTINGS_FILE")
433     PASS=$(xpath -e "//servers/server[id='$REPO']/password/text()" "$SETTINGS_FILE")
434     if [ -z "$USER" ]; then
435       echo "Error: no user provided"
436     fi
437     if [ -z "$PASS" ]; then
438       echo "Error: no password provided"
439     fi
440     [ -z "$PASS" ] && PASS_PROVIDED="<empty>" || PASS_PROVIDED="<password>"
441     echo docker login "$REPO" -u "$USER" -p "$PASS_PROVIDED"
442     docker login "$REPO" -u "$USER" -p "$PASS"
443
444     if [ $MVN_DEPLOYMENT_TYPE == "SNAPSHOT" ]; then
445       REPO="$REPO/snapshots"
446     elif [ $MVN_DEPLOYMENT_TYPE == "STAGING" ]; then
447       # there seems to be no staging docker registry?  set to use SNAPSHOT also
448       #REPO=$MVN_DOCKERREGISTRY_RELEASE
449       REPO="$REPO"
450     else
451       echo "Fail to determine DEPLOYMENT_TYPE"
452       REPO="$REPO/unknown"
453     fi
454
455     OLDTAG="${LFQI}"
456     PUSHTAGS="${REPO}/${IMAGENAME}:${VERSION2}-${TIMESTAMP} ${REPO}/${IMAGENAME}:${VERSION2} ${REPO}/${IMAGENAME}:${VERSION2}-latest"
457     for NEWTAG in ${PUSHTAGS}
458     do
459       echo "tagging ${OLDTAG} to ${NEWTAG}"
460       docker tag "${OLDTAG}" "${NEWTAG}"
461       echo "pushing ${NEWTAG}"
462       docker push "${NEWTAG}"
463       OLDTAG="${NEWTAG}"
464     done
465   fi
466
467 }
468
469
470