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"
+ }
+ }
+ }
+ }
+}