Add pipeline to deploy k8s deployments

Change-Id: Id4d82fffff3c5d26c470ad2dd87ea23731b88d4c
diff --git a/deploy-k8s-deployments.groovy b/deploy-k8s-deployments.groovy
new file mode 100644
index 0000000..e9b1b9b
--- /dev/null
+++ b/deploy-k8s-deployments.groovy
@@ -0,0 +1,34 @@
+def common = new com.mirantis.mk.Common()
+def salt = new com.mirantis.mk.Salt()
+
+targetExpression = TARGET_MINIONS ? TARGET_MINIONS : "E@kvm01.*"
+
+node() {
+    def master = salt.connection(SALT_URL)
+    common.infoMsg("Enforcing kubernetes state..")
+    stage("Update k8s control") {
+        salt.enforceState(
+            master,
+            ['expression': targetExpression, 'type': 'compound'],
+            ['kubernetes.control'],
+            true
+        )
+    }
+    stage("Update components") {
+        common.info("Setting up components..")
+        out = salt.cmdRun(
+            master,
+            ['expression': targetExpression, 'type': 'compound'],
+            '/bin/bash -c \'find /srv/kubernetes/ -type d | grep -v jobs | while read i; do ls $i/*.yml &>/dev/null && (set -x; hyperkube kubectl apply -f $i || echo Command failed; set +x); done; jobs=$(hyperkube kubectl get jobs -o name); find /srv/kubernetes/jobs -type f -name "*.yml" | while read i; do name=$(grep "name:" $i | head -1 | awk "{print $NF}"); echo $jobs|grep $name >/dev/null || (set -x; hyperkube kubectl apply -f $i || echo Command failed; set +x);done\''
+        )
+        for (entry in out['return']) {
+            for (node in entry) {
+                if (node.value =~ /Command failed/) {
+                    error("$node.key: $node.value")
+                } else {
+                    println "$node.key: $node.value"
+                }
+            }
+        }
+    }
+}