-
-
Notifications
You must be signed in to change notification settings - Fork 637
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support declaring non-string (bool, maps, slices, etc) variables #140
Comments
I have met this limitaruon as well. With some effort, I believe not only Boolean, but also array and numeric values could be supported as static values. Unfortunantly maps would probably be of the table because the syntax for dynamic variables is: vars:
myvar:
sh: cat myfile.txt For our own use cases, we ended up sticking with string values rather than fixing it (we wanted maps and Boolean). |
Hi @philippgille, As said by @smyrman, there's a syntax conflict with the That said, I agree this would be very useful. This is slightly related to #82 |
Well, there is no conflict for Booleans, numbers and arrays. vars:
myvar: <string, bool, number or array> We can expand that with an explicit vars:
myvar:
value: <any yaml value> Implementation wise, at least these changes must be made: Change the Var typeLine 32 in 309cfb1
To use type Var struct {
Value interface{} `yaml:"value"`
Sh string `yaml:"sh"`
} Replace ToStringMapLine 18 in 309cfb1
To return a map of func (vs Vars) Resolve() (m map[string]interface{}) {
....
} Change UnmarshalYAMLLine 38 in 309cfb1
To highlight the last point: vars:
myvar:
value: "$I am not a command" vars:
myvar: "$echo 'I am a command'" From there, there will be lots of follow up changes. If you are interested in doing a PR @philippgille, that would be nice. If not, I suspect it will be fixed eventually. What's your views @andreynering? |
PS! The same should off-course work the same way for the |
@smyrman Yeah, I think that's the right way of doing this. Thanks for the suggestion! |
@andreynering I just briefly evaluated this tool as an alternative to make. It looks very promising! Thank you for your effort. What would be a really appreciated feature is to handle variables of type map (or any other complex type). In our case we have a set of variables that should change values depending on if you are deploying to dev, stage, prod etc. Looking up the values for the current deploy environment in a map would be very neat! Meanwhile, is there another approach you can use to build up a map like structure as a workaround? Like using a pipe-sign to build up a multi-line string? Are there parsing utilities included that can fetch the values from a text-representation of a map? Perhaps not pretty. Any other suggestion? |
Hi @pettervondolwitz, Indeed I plan to support non-string variables. It's just a matter of finding free time to do so. For now I don't have any workaround in mind, but maybe if you explain better your use case, with examples, I can help a bit. |
A slightly simplified description would be the following. Let's say we want to orchestrate deployment to three different environments. Taskvars.yml could look something like below: TARGETS:
DEV:
ACCOUNT: 11111111111
AWS_REGION: us-west-1
BASE_FQDN: dev.acme.com
STAGE:
ACCOUNT: 22222222222
AWS_REGION: us-west-2
BASE_FQDN: stage.acme.com
PROD:
ACCOUNT: 33333333333
AWS_REGION: eu-west-1
BASE_FQDN: acme.com Then in the Taskfile.yml we would like to point out the current target environment somehow. By setting a variable perhaps if using the current capabilities of this project and then extracting the relevant account number by using a go template:
where "DEV" represents the current environment. Not sure the syntax is correct here but something like the above. Applying the same type of logic to different environments when deploying should be a fairly common use case. The yaml-file above needs to be more complex in our case, i.e. including additional maps/arrays at a deeper level but if a generic support is added for any complex yaml-variable then this would not present a problem I guess. |
Here are two workarounds you could use (using only one variable in the examples to keep it short): In TARGET__DEV__ACCOUNT: "11111111111"
TARGET__STAGE__ACCOUNT: "22222222222"
TARGET__PROD__ACCOUNT: "22222222222" In version: "2"
tasks:
deploy:
desc: "deply all targets"
deps:
- deploy-dev
- deploy-stage
- deploy-prod
deploy-dev:
desc: "deply dev target"
cmds:
- task: _deploy
vars:
ACCOUNT: '{{.TARGET__DEV__ACCUOUNT}}'
deploy-stage:
desc: "deply stage target"
cmds:
- task: _deploy
vars:
ACCOUNT: '{{.TARGET__STAGE__ACCUOUNT}}'
deploy-prod:
desc: "deply prod target"
cmds:
- task: _deploy
vars:
ACCOUNT: '{{.TARGET__PROD__ACCUOUNT}}'
_deploy:
cmds:
- 'command {{.ACCOUNT}}' Alternatively, you could use a folder structure:
Let each of them include the same ACCOUNT: "11111111111" |
@smyrman Thank you for your suggestions! I think flatten out as you suggest in the first example would be to messy since the real use case is much more involved with maps in maps etc. I will see if we can use your second approach though. Also the first example was a good inspiration on how you can go about similar tasks. |
I was planning a task that created a series of web site base files in a directory per site and was expecting to use a YAML dict object for each site. From this discussion it seems the best way for now would be to have a sitename1/Taskvars.yml, sitename2/Taskvars.yml style folder structure and a generic 'site' task that reads those? |
Yes, I belie for now, that's a feasible solution. Otherwise it's attempting a PR at the suggested solution above: #140 (comment) |
Is there any progress on this? I would also like to ask if there is any suggested way for handling arrays/list in vars? We see them in almost every our Makefile, so looking for a suggested/best way to use them |
@nick4fake You basically have to encode your data as some form of string and decode it at the use-site. Depending on the nature of your data you may be able to go with something like a comma-separated string, but in the general case your best bet is probably the fromJson/toJson functions. |
@treykasada Yeah, that's something we've figured out (using JSON and jq), though I was thinking about a cleaner solution |
Hey all. v3.33.0 of Task was just released including experimental support for any type of variable! Please check out the "Any Variables" experiment docs for details. I'm going to close this since the experiment is being tracked in #1415. Please feel free to leave your feedback and ideas over there. Thanks! |
@pd93 -- can one specify a default for bools? If one uses the recommended way to provide overridable defaults in Taskfiles
it of course stringifies the var such that the nicer style |
@mattavos This is a limitation of templating. The output will always be a string. You can use Not sure what you're trying to do in your snippet. A boolean will always default to Also, please avoid using a closed issue to ask questions as it notifies everyone who was subscribed. It is better to open a new discussion or join our discord for support. |
When writing the
Taskfile.yml
many people probably write it like any other yaml, which means values likefalse
is a boolean, as the yaml spec says: http://yaml.org/type/bool.htmlBut it turns out to be used as string and when using the template language it's actually
"false"
. This is bad for{{if .SOME_VAR}}
for example, which doesn't work, so you have to write{{if eq "true" .SOME_VAR}}
for example, or even a much longer expression given the valid forms of a bool in the spec (e.g. "no", "NO", "No", n", ...).Note: I found the same issue in a different Go repository: concourse/concourse#294
Unfortunately they only link to a Pivotal tracker and the link is 404, so I don't know if and how they dealt with this issue.
If you explicitly don't want to adhere to the yaml spec (and of course there might be good reasons for it), this behaviour should at least be mentioned in the documentation. Currently the "Variables" section doesn't do this: https://taskfile.org/#/usage?id=variables
Example Taskfile, created with
task --init
and then customized:The output is:
task Version: Commit
309cfb14995ec511546726ab607d53c55c803d0f
OS: Ubuntu 14.04
The text was updated successfully, but these errors were encountered: