私はテラフォーム用のPythonラッパーを持っています.テラフォームは、渡された引数を何らかの形で誤解します. これを回避する方法はありますか?
#!/usr/bin/env python
import subprocess
args_echo = ["/bin/echo", "/home/vmindru/proj/tera/terraform",
"plan",
"-var foo=bar"]
args_terr = ["/home/vmindru/proj/tera/terraform",
"plan",
"-no-color",
"-var foo=bar"]
echo = subprocess.call(args_echo)
terr = subprocess.call(args_terr)
print echo, terr
__注: 単純なエコー (またはその他のバイナリ) を実行すると以下に観察される __ お尻は、すべての引数を正しく解釈します。何らかの理由で、terraform は引数 -var foo=bar を -var foo に分割し、おそらく bar に分割することを決定しました
vmindru@vmhodesk:/tmp/test2$ ./test.py
/home/vmindru/proj/tera/terraform plan -var foo=bar
flag provided but not defined: -var foo
Usage: terraform plan [options] [dir]
Generates an execution plan for Terraform.
This execution plan can be reviewed prior to running apply to get a
sense for what Terraform will do. Optionally, the plan can be saved to
a Terraform plan file, and apply can take this plan file to execute
this plan exactly.
Options:
-backup=path Path to backup the existing state file before
modifying. Defaults to the "-state-out" path with
".backup" extension. Set to "-" to disable backup.
-destroy If set, a plan will be generated to destroy all resources
managed by the given configuration and state.
-detailed-exitcode Return detailed exit codes when the command exits. This
will change the meaning of exit codes to:
0 - Succeeded, diff is empty (no changes)
1 - Errored
2 - Succeeded, there is a diff
-input=true Ask for input for variables if not directly set.
-module-depth=n Specifies the depth of modules to show in the output.
This does not affect the plan itself, only the output
shown. By default, this is -1, which will expand all.
-no-color If specified, output won't contain any color.
-out=path Write a plan file to the given path. This can be used as
input to the "apply" command.
-parallelism=n Limit the number of concurrent operations. Defaults to 10.
-refresh=true Update state prior to checking for differences.
-state=statefile Path to a Terraform state file to use to look
up Terraform-managed resources. By default it will
use the state "terraform.tfstate" if it exists.
-target=resource Resource to target. Operation will be limited to this
resource and its dependencies. This flag can be used
multiple times.
-var 'foo=bar' Set a variable in the Terraform configuration. This
flag can be set multiple times.
-var-file=foo Set variables in the Terraform configuration from
a file. If "terraform.tfvars" is present, it will be
automatically loaded if this flag is not specified.
0 1
vmindru@vmhodesk:/tmp/test2$