aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpmikus <pmikus@cisco.com>2021-07-26 12:54:58 +0000
committerPeter Mikus <pmikus@cisco.com>2021-07-26 12:58:30 +0000
commit493f139cfd5ad9eff786e8730a106ca567939ad2 (patch)
tree2b7c945f73b7142d8aeb6d65d1ebe56e7a608099
parent779d17e72198090ea212f11937a00711f0962738 (diff)
Infra: Terraform add ansible plugin init
+ Manual override Signed-off-by: pmikus <pmikus@cisco.com> Change-Id: If296d28dc3eaa023c935a0887a14ac10e83076ba (cherry picked from commit b27f2c7cbfe08712a00959c8cc6a2f618a25b3e7)
-rw-r--r--resources/libraries/bash/function/terraform.sh113
1 files changed, 113 insertions, 0 deletions
diff --git a/resources/libraries/bash/function/terraform.sh b/resources/libraries/bash/function/terraform.sh
new file mode 100644
index 0000000000..29a2177bd6
--- /dev/null
+++ b/resources/libraries/bash/function/terraform.sh
@@ -0,0 +1,113 @@
+#!/usr/bin/env bash
+
+# Copyright (c) 2021 Cisco and/or its affiliates.
+# 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.
+
+set -exuo pipefail
+
+
+function terraform_apply () {
+
+ # Run terraform apply command to prepare topology.
+ #
+ # Variable read:
+ # - ${CSIT_DIR} - CSIT main directory, where terraform modules are located.
+ # - ${NODENESS} - Node multiplicity of desired testbed.
+ # - ${FLAVOR} - Node flavor string, see common.sh
+
+ set -exuo pipefail
+
+ if ! installed terraform; then
+ die "Please install terraform!"
+ fi
+
+ pushd "${CSIT_DIR}"/fdio.infra.terraform || die "Pushd failed!"
+ pushd "${NODENESS}_${FLAVOR}_c5n" || die "Pushd failed!"
+ export TF_LOG=INFO
+ terraform apply -auto-approve || die "Failed to run terraform apply!"
+ popd || die "Popd failed!"
+ popd || die "Popd failed!"
+}
+
+function terraform_destroy () {
+
+ # Run terraform destroy command to prepare module.
+ #
+ # Variable read:
+ # - ${CSIT_DIR} - CSIT main directory, where terraform modules are located.
+ # - ${NODENESS} - Node multiplicity of desired testbed.
+ # - ${FLAVOR} - Node flavor string, see common.sh
+
+ set -exuo pipefail
+
+ if ! installed terraform; then
+ die "Please install terraform!"
+ fi
+
+ pushd "${CSIT_DIR}"/fdio.infra.terraform || die "Pushd failed!"
+ pushd "${NODENESS}_${FLAVOR}_c5n" || die "Pushd failed!"
+ export TF_LOG=INFO
+ terraform destroy -auto-approve || die "Failed to run terraform destroy!"
+ popd || die "Popd failed!"
+ popd || die "Popd failed!"
+}
+
+
+function terraform_init () {
+
+ # Run terraform init command to prepare module.
+ #
+ # Variable read:
+ # - ${CSIT_DIR} - CSIT main directory, where terraform modules are located.
+ # - ${NODENESS} - Node multiplicity of desired testbed.
+ # - ${FLAVOR} - Node flavor string, see common.sh
+
+ set -exuo pipefail
+
+ if ! installed terraform; then
+ die "Please install terraform!"
+ fi
+
+ pushd "${CSIT_DIR}"/fdio.infra.terraform || die "Pushd failed!"
+ pushd "${NODENESS}_${FLAVOR}_c5n" || die "Pushd failed!"
+ export TF_LOG=INFO
+ terraform init || die "Failed to run terraform init!"
+
+ plugin_url="https://github.com/radekg/terraform-provisioner-ansible/"
+ plugin_url+="releases/download/v2.5.0/"
+ plugin_url+="terraform-provisioner-ansible-linux-amd64_v2.5.0"
+ plugin_dir="${HOME}/.terraform.d/plugins/"
+ plugin_path+="${plugin_dir}terraform-provisioner-ansible-linux-amd64_v2.5.0"
+
+ mkdir -p "${plugin_dir}" || die "Failed to create dir!"
+ wget -O "${plugin_path}" "${plugin_url}" || die "Failed to download plugin!"
+
+ popd || die "Popd failed!"
+ popd || die "Popd failed!"
+}
+
+
+function installed () {
+
+ # Check if the given utility is installed. Fail if not installed.
+ #
+ # Arguments:
+ # - ${1} - Utility to check.
+ # Returns (implicitly):
+ # - 0 - If command is installed.
+ # - 1 - If command is not installed.
+
+ set -exuo pipefail
+
+ command -v "${1}"
+}