[terraform] Disable input prompts during terraform init/plan/apply (#38842)
Per Hashicorp's [guidelines][1] for automated use of terraform CLI, this PR adds the `-input=false` option to all the commands executed in the module. If input is required, this causes a hard failure that will become a module failure. [1]: https://www.terraform.io/guides/running-terraform-in-automation.html
This commit is contained in:
parent
eebfa66c2b
commit
f428108845
1 changed files with 3 additions and 3 deletions
|
@ -133,7 +133,7 @@ import traceback
|
||||||
from ansible.module_utils.basic import AnsibleModule
|
from ansible.module_utils.basic import AnsibleModule
|
||||||
|
|
||||||
DESTROY_ARGS = ('destroy', '-no-color', '-force')
|
DESTROY_ARGS = ('destroy', '-no-color', '-force')
|
||||||
APPLY_ARGS = ('apply', '-no-color', '-auto-approve=true')
|
APPLY_ARGS = ('apply', '-no-color', '-input=false', '-auto-approve=true')
|
||||||
module = None
|
module = None
|
||||||
|
|
||||||
|
|
||||||
|
@ -159,7 +159,7 @@ def _state_args(state_file):
|
||||||
|
|
||||||
|
|
||||||
def init_plugins(bin_path, project_path):
|
def init_plugins(bin_path, project_path):
|
||||||
command = [bin_path, 'init']
|
command = [bin_path, 'init', '-input=false']
|
||||||
rc, out, err = module.run_command(command, cwd=project_path)
|
rc, out, err = module.run_command(command, cwd=project_path)
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
module.fail_json(msg="Failed to initialize Terraform modules:\r\n{0}".format(err))
|
module.fail_json(msg="Failed to initialize Terraform modules:\r\n{0}".format(err))
|
||||||
|
@ -169,7 +169,7 @@ def build_plan(bin_path, project_path, variables_args, state_file, plan_path=Non
|
||||||
if plan_path is None:
|
if plan_path is None:
|
||||||
f, plan_path = tempfile.mkstemp(suffix='.tfplan')
|
f, plan_path = tempfile.mkstemp(suffix='.tfplan')
|
||||||
|
|
||||||
command = [bin_path, 'plan', '-no-color', '-detailed-exitcode', '-out', plan_path]
|
command = [bin_path, 'plan', '-input=false', '-no-color', '-detailed-exitcode', '-out', plan_path]
|
||||||
command.extend(_state_args(state_file))
|
command.extend(_state_args(state_file))
|
||||||
|
|
||||||
rc, out, err = module.run_command(command + variables_args, cwd=project_path)
|
rc, out, err = module.run_command(command + variables_args, cwd=project_path)
|
||||||
|
|
Loading…
Reference in a new issue