Merge "[CORD-2848] Add helm-lint job"
diff --git a/jjb/cord/cord-xos-gui-unit.yaml b/jjb/cord/cord-xos-gui-unit.yaml
index 50885ab..f51e863 100644
--- a/jjb/cord/cord-xos-gui-unit.yaml
+++ b/jjb/cord/cord-xos-gui-unit.yaml
@@ -89,13 +89,16 @@
     project: xos-gui
 
     build-timeout: '10'
-    build-node: 'ubuntu16.04-basebuild-1c-1g'
+    build-node: '{build-node}'
 
-    stream:
+    # ideally this would be in defaults.yaml, but that doesn't work
+    supported_versions: &supported_versions
       - 'master'
       - 'cord-5.0'
       - 'cord-4.1'
       - 'cord-4.0'
 
+    stream: *supported_versions
+
     jobs:
       - 'cord-xos-gui-unit-{stream}'
diff --git a/jjb/defaults.yaml b/jjb/defaults.yaml
index aeb339d..f48a77e 100644
--- a/jjb/defaults.yaml
+++ b/jjb/defaults.yaml
@@ -16,6 +16,7 @@
     # Timeout in minutes
     # TODO deprecate this (should be project template specific)
     build-timeout: 360
+
     # TODO this should be the most common executor
     build-node: ubuntu16.04-basebuild-1c-1g
 
@@ -39,3 +40,4 @@
         -Djenkins
         -Dmaven.repo.local=/tmp/r
         -Dorg.ops4j.pax.url.mvn.localRepository=/tmp/r
+
diff --git a/jjb/helm-lint/helmlint.sh b/jjb/helm-lint/helmlint.sh
new file mode 100755
index 0000000..629bb34
--- /dev/null
+++ b/jjb/helm-lint/helmlint.sh
@@ -0,0 +1,46 @@
+#/usr/bin/env bash
+
+# Copyright 2018-present Open Networking Foundation
+#
+# 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.
+
+# helmlint.sh
+# run `helm lint` on all helm charts that are found
+
+set +e -u -o pipefail
+echo "helmlint.sh, using helm version: $(helm version -c --short)"
+
+fail_lint=0
+
+for chart in $(find . -name Chart.yaml -print) ; do
+
+  chartdir=$(dirname "${chart}")
+
+  # lint with values.yaml if it exists
+  if [ -f "${chartdir}/values.yaml" ]; then
+    helm lint --strict --values "${chartdir}/values.yaml" "${chartdir}"
+  else
+    helm lint --strict "${chartdir}"
+  fi
+
+  rc=$?
+  if [[ $rc != 0 ]]; then
+    fail_lint=1
+  fi
+done
+
+if [[ $fail_lint != 0 ]]; then
+  exit 1
+fi
+
+exit 0
diff --git a/jjb/helm-lint/heml-lint.yml b/jjb/helm-lint/heml-lint.yml
new file mode 100644
index 0000000..1f5e37a
--- /dev/null
+++ b/jjb/helm-lint/heml-lint.yml
@@ -0,0 +1,72 @@
+---
+# run `helm lint` on helm charts
+
+- job-template:
+    name: 'verify-helm-charts-{stream}'
+
+    git-url: '$GIT_URL/$GERRIT_PROJECT'
+    submodule-recursive: false
+
+    builders:
+      - shell: !include-raw-escape: helmlint.sh
+
+    properties:
+      - lf-infra-properties:
+          project: '{project}'
+          build-days-to-keep: '{build-days-to-keep}'
+
+    parameters:
+      - lf-infra-parameters:
+          project: '{project}'
+          branch: '{stream}'
+          stream: '{stream}'
+          lftools-version: '{lftools-version}'
+
+    wrappers:
+      - lf-infra-wrappers:
+          build-timeout: '{build-timeout}'
+          jenkins-ssh-credential: '{jenkins-ssh-credential}'
+
+    scm:
+      - lf-infra-gerrit-scm:
+          git-url: '{git-url}'
+          refspec: '$GERRIT_REFSPEC'
+          branch: '$GERRIT_BRANCH'
+          submodule-recursive: '{submodule-recursive}'
+          choosing-strategy: gerrit
+          jenkins-ssh-credential: '{jenkins-ssh-credential}'
+
+    triggers:
+      - gerrit:
+          server-name: '{gerrit-server-name}'
+          trigger-on:
+            - patchset-created-event:
+                exclude-drafts: true
+                exclude-trivial-rebase: false
+                exclude-no-code-change: true
+            - draft-published-event
+            - comment-added-contains-event:
+                comment-contains-value: '(?i)^.*recheck$'
+          projects:
+            - project-compare-type: PLAIN
+              project-pattern: '{project}'
+              branches:
+                - branch-compare-type: ANT
+                  branch-pattern: '**/{stream}'
+
+- project:
+    name: verify-helm-charts
+    project-name: verify-helm-charts
+
+    project: helm-charts
+
+    project-type: freestyle
+
+    build-timeout: '10'
+    build-node: '{build-node}'
+
+    stream:
+      - "master"
+
+    jobs:
+      - 'verify-helm-charts-{stream}'