Enable NG-UI in CICD 43/9043/13
authorgarciadeblas <gerardo.garciadeblas@telefonica.com>
Mon, 8 Jun 2020 09:55:28 +0000 (09:55 +0000)
committergarciadeblas <gerardo.garciadeblas@telefonica.com>
Mon, 22 Jun 2020 14:35:28 +0000 (14:35 +0000)
Change-Id: I9b39ff161a32e9b559117c88d34264942e5d10e4
Signed-off-by: garciadeblas <gerardo.garciadeblas@telefonica.com>
docker/Makefile
docker/NG-UI/Dockerfile [new file with mode: 0644]
docker/NG-UI/Makefile [new file with mode: 0644]
docker/mk/Makefile.include
jenkins/ci-pipelines/ci_stage_3.groovy

index 6e6ae57..f5056b7 100644 (file)
@@ -1,5 +1,6 @@
 #
 #   Copyright 2017 Sandvine
+#   Copyright 2020 ETSI
 #
 #   Licensed under the Apache License, Version 2.0 (the "License");
 #   you may not use this file except in compliance with the License.
@@ -13,5 +14,5 @@
 #   See the License for the specific language governing permissions and
 #   limitations under the License.
 #
-SUBDIRS = MON NBI osmclient RO LCM light-ui POL Keystone
+SUBDIRS = MON NBI osmclient RO LCM light-ui POL Keystone NG-UI
 include mk/dirs.mk
diff --git a/docker/NG-UI/Dockerfile b/docker/NG-UI/Dockerfile
new file mode 100644 (file)
index 0000000..b781ec0
--- /dev/null
@@ -0,0 +1,52 @@
+# Copyright 2020 ETSI
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+#    http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+# implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+FROM ubuntu:18.04
+
+RUN apt-get update && apt-get install -y curl xz-utils gnupg2 \
+    && apt-get update && apt-get install -y apt-transport-https software-properties-common \
+    && curl -s https://deb.nodesource.com/gpgkey/nodesource.gpg.key | apt-key add - \
+    && echo "deb https://deb.nodesource.com/node_10.x xenial main" | tee -a /etc/apt/sources.list.d/nodesource.list \
+    && echo "deb-src https://deb.nodesource.com/node_10.x xenial main" | tee -a /etc/apt/sources.list.d/nodesource.list \
+    && apt-get update && apt-get install -y nodejs \
+    && apt-get install -y nginx
+
+ARG REPOSITORY_BASE=http://osm-download.etsi.org/repository/osm/debian
+ARG RELEASE=ReleaseSEVEN-daily
+ARG REPOSITORY_KEY=OSM%20ETSI%20Release%20Key.gpg
+ARG REPOSITORY=testing
+ARG NGUI_VERSION
+
+RUN curl ${REPOSITORY_BASE}/${RELEASE}/${REPOSITORY_KEY} | apt-key add -
+RUN add-apt-repository -y "deb ${REPOSITORY_BASE}/${RELEASE} ${REPOSITORY} NG-UI" && apt-get update
+
+RUN apt-get install -y osm-ngui${NGUI_VERSION} && \
+    rm -rf /var/lib/apt/lists/*
+
+WORKDIR /usr/share/osm-ngui
+RUN npm install
+# Building app.
+RUN npm run build
+RUN cp /usr/share/osm-ngui/nginx.conf /etc/nginx/sites-available/default
+#RUN cp /usr/share/osm-ngui/supervisor-app.conf /etc/supervisor/conf.d/
+
+EXPOSE 80
+
+HEALTHCHECK --start-period=130s --interval=10s --timeout=5s --retries=12 \
+  CMD curl --silent --fail localhost:80 || exit 1
+
+# Starting server.
+CMD ["nginx", "-g", "daemon off;"]
+
diff --git a/docker/NG-UI/Makefile b/docker/NG-UI/Makefile
new file mode 100644 (file)
index 0000000..0fb388b
--- /dev/null
@@ -0,0 +1,19 @@
+##
+# Copyright 2020 ETSI
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+#         http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+##
+
+include ../mk/Makefile.include
+
+MDG=$(shell basename $(CURDIR))
index e19c753..609c069 100644 (file)
@@ -1,3 +1,18 @@
+#
+#   Copyright 2020 ETSI
+#
+#   Licensed under the Apache License, Version 2.0 (the "License");
+#   you may not use this file except in compliance with the License.
+#   You may obtain a copy of the License at
+#
+#       http://www.apache.org/licenses/LICENSE-2.0
+#
+#   Unless required by applicable law or agreed to in writing, software
+#   distributed under the License is distributed on an "AS IS" BASIS,
+#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+#   See the License for the specific language governing permissions and
+#   limitations under the License.
+#
 TOPDIR=$(shell readlink -f .|sed -e 's/\/docker\/.*//')
 MKINCLUDE=$(TOPDIR)/docker/mk
 MKBUILD=$(TOPDIR)/docker/build
@@ -19,7 +34,7 @@ CONTAINER_NAME ?= $(LOWER_MDG)
 CMD_DOCKER_ARGS ?= -q
 DOCKER_ARGS     = $(CMD_DOCKER_ARGS)
 
-DEPS := MON IM LCM RO common osmclient devops NBI policy-module Keystone N2VC lightui
+DEPS := MON IM LCM RO common osmclient devops NBI policy-module Keystone N2VC lightui NG-UI
 
 DEPS_TARGETS = $(addprefix $(MKBUILD)/.dep_, $(DEPS))
 
@@ -54,6 +69,7 @@ build: $(MKBUILD) $(DEPS_TARGETS)
                    --build-arg DEVOPS_VERSION==$(shell cat $(MKBUILD)/.dep_devops) \
                    --build-arg N2VC_VERSION==$(shell cat $(MKBUILD)/.dep_N2VC) \
                    --build-arg LWUI_VERSION==$(shell cat $(MKBUILD)/.dep_lightui) \
+                   --build-arg NGUI_VERSION==$(shell cat $(MKBUILD)/.dep_NG-UI) \
                    $(DOCKER_ARGS) .
 
 clean:
index 153abcb..627db75 100644 (file)
@@ -135,7 +135,7 @@ node("${params.NODE}") {
             // grab all stable upstream builds based on the
 
             dir("${RELEASE}") {
-                def list = ["RO", "openvim", "osmclient", "IM", "devops", "MON", "N2VC", "NBI", "common", "LCM", "POL", "LW-UI"]
+                def list = ["RO", "openvim", "osmclient", "IM", "devops", "MON", "N2VC", "NBI", "common", "LCM", "POL", "LW-UI", "NG-UI"]
                 for (component in list) {
                     step ([$class: 'CopyArtifact',
                            projectName: "${component}${upstream_main_job}/${GERRIT_BRANCH}"])