#variant (2019-03)
Discuss variant (the “Universal CLI”) https://github.com/mumoshu/variant
Archive: https://archive.sweetops.com/variant/
2019-03-19
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
regarding https://github.com/mumoshu/variant/issues/51
it is helpful to include single tasks, but if I want to include a bunch of tasks with a single statement, what are the options (I didn’t check all the tests & code)?
@mumoshu
So that you can create a common/library variant commands to be versioned and reused. tasks: anothercmd: # Basically runs go-getter [github.com/foo/bar?ref=v0.1.0//dir](http://github.com/foo/bar?ref=v0.1.0//dir) /tmp/somewhere
and then inclu…
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
found this one - https://github.com/mumoshu/variant/issues/52 seems like this is it
So that you can create a common config file that is versioned and reused in various variant commands in divergent places. tasks: mytask: parameters: - name: config type: object script: | cat <&l… |
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
nope, that’s only for config files in fact
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
just import in the main file works OK:
...
import: variant_lib.yaml
...
good stuff!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
awesome to see you figured out about that!
yes, import
can be used for importing both single task or a set of tasks :)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
also - if you encouter any difficulty on writing your variant command, pls feel free to share an example code!
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
thanks! I believe this tool is going to save a lot of time for a lot of people!
I’m still going to figure out the differences between “inputs”, “options” & “parameters”
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
those are interchangeable, and parameters is the latest and recommended syntax! the former two will be eventually removed
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
I see, thanks for the explanation!
2019-03-20
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
is there any specific reason to separate config file & main Variantfile or config could be included in Variantfile file (as an option)?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@tolstikov you’re not using the #!
mode?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Geodesic is a cloud automation shell. It's the fastest way to get up and running with a rock solid, production grade cloud platform built on top of strictly Open Source tools. ★ this repo! h…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
to me this is the ideal invocation
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then the .
configs are quite nice
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
@Erik Osterman (Cloud Posse) probably my question was not clear
I’ve meant that I like the idea to keep everything related to Variant in a single file (including environment specific config files, a main config file, etc) for some specific projects, where some other people will participate (it can be Variantfile or !# file, etc).
It will be probably easier for these people to adopt to the new workflow (with Variant) when everything is in the one place (file).
Also, it will reduce “invasion” (only one new file instead of 2-3 files) to other people’s projects (where I only setup the CICD for example).
Please let me know if I’m not clear!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Personally, the Variantfile
approach was less appealing than writing a cli with variant
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for example, we write our cli called kopsctl
using the variant DSL
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and then as a cli tool, I want the configuration separate. that logical separation IMO makes it more manageable than keeping it all in the same script.
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
yes, it makes total sense in this context
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
but, I still can see some cases where Variantfile would be more appealing to some people
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
as for me only, I prefer the CLI approach as well
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok,
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
but still like to have some options
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
thanks for sharing your vision!
data:image/s3,"s3://crabby-images/dc995/dc9953c18a05aabfac39bcf27ac7d61bef5390c6" alt="Tim Malone avatar"
@Tim Malone has joined the channel
2019-03-21
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Yeah both use-cases make sense to me! From the author’s perspective, I’d say Variantfile
is an alternative to putting Makefile
in your project root. It isn’t intended to be reused by any other projects
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Makes sense….
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
./yourcmd
way, like kopsctl
, should be used whenever it is being reused in any way, like (1) imported from another variant command via import:
or (2) as a single executable binary
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Btw, for the latter, you can go build
your variant command like explained in https://github.com/mumoshu/variant#releasing-a-variant-made-command, or in a bit more sophisticated way https://github.com/mumoshu/variant/blob/master/examples/hello/hack/generate-maingo-struct#L1-L15.
Wrap up your bash scripts into a modern CLI today. Graduate to a full-blown golang app tomorrow. - mumoshu/variant
Wrap up your bash scripts into a modern CLI today. Graduate to a full-blown golang app tomorrow. - mumoshu/variant
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Fully static, unprivileged, self-contained, containers as executable binaries. - genuinetools/binctr
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This plus variant!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I have thought about how we could do this with geodesic
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So you can just run it with out even Docker installed
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Remember the problem you we’re trying to solve about installing all the deps of variant
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
In this model, you would have a dockerfile of deps, a variant entry point, and a compiled container exe
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
that sounds very interesting
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
fyi: if you don’t want the dependency to the bash installed on your machine: https://github.com/progrium/go-basher
Library for writing hybrid Go and Bash programs. Contribute to progrium/go-basher development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Dude! That’s awesome
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think that’s a step in the right direction
2019-03-22
2019-03-25
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
Hello guys, I wonder is it possible to pass the parent task parameter as an argument to the child?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
oh shh, sorry it worked when quoting opt1: '{{ get "test_param" }}'
. @mumoshu great tool btw, thank you.
data:image/s3,"s3://crabby-images/91017/910177adba94615aa40428c968883b16f580e2bd" alt="1000"
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
I’ve been playing with variant and in my case I feel like I’m missing toObject
template helper. Does anyone now how to treat the output of a task as an object? Is it possible in variant?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@dennybaa hey! you can define an parameter as type: object
so that any JSON-formatted stdout content can be parsed as object`
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
$ cat Variantfile
#!/usr/bin/env variant
tasks:
getjson:
script: |
echo '{"key1":1, "key2":2}'
test:
parameters:
- name: getjson
type: object
properties:
key1:
type: integer
key2:
type: integer
script: |
cat <<EOS
{{ get "getjson" | toYaml }}
EOS
$ variant test
variant ≫ starting task getjson
variant.getjson ≫ {"key1":1, "key2":2}
variant ≫ starting task test
key1: 1
key2: 2
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
btw, you can even source from/override the parameter value with a file:
$ cat my.json
{"foo":11,"bar":22}
$ variant test --getjson=my.json
variant ≫ starting task test
bar: 22
foo: 11
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
@mumoshu yup, I’ve bumped into it as well. However there is a correlating issue - “get” tasks can not have parameterized arguments. Correct me if I’m mistaken, please.
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
tasks:
key:
parameters:
- name: count
type: integer
default: 1
script: |
echo '["private", "public"]'
create:
options:
- name: key
required: true
script: |
echo {{ get "key" | toYaml }}
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@dennybaa you’d need to add type: object
for create
, and return a JSON object, not JSON array from the key
task
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
In fact I already use pattern as above. So I guess parameters should work, sorry. I see.
Yaml is not possible with type: object
?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
the point would be that you don’t need to explicitly parse json or yaml. type: object do that for you!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
would you mind sharing several example variantfiles you’ve tried, so that i can better get what you’re trying and rewrite them for you?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
Thank you very much ! It’s just something wasn’t working, but now after a day of trail with variant I feel much more confident. So I will try to brush the code up first and get back to you after and for refactoring advises.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
great!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@dennybaa i was in the impression that you wanted to (1) internally generate an parameterized array and (2) print the result as yaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
$ cat Variantfile2
#!/usr/bin/env variant
tasks:
myarray:
parameters:
- name: second
type: string
default: "public"
script: |
echo '["private", "{{get "second"}}"]'
print-json-array-as-yaml:
options:
- name: myarray
type: array
script: |
echo '{{ get "myarray" | toYaml }}'
$ variant Variantfile2 print-json-array-as-yaml
Variantfile2 ≫ starting task myarray
Variantfile2.myarray ≫ ["private", "public"]
Variantfile2 ≫ starting task print-json-array-as-yaml
- private
- public
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
@mumoshu why )?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
(cont) in that case the above may be of help…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
or for type: object
, i’d write something like:
$ cat Variantfile2
#!/usr/bin/env variant
tasks:
myobject:
parameters:
- name: second
type: string
default: "public"
script: |
echo '{"items":["private", "{{get "second"}}"]}'
print-json-object-as-yaml:
options:
- name: myobject
type: object
script: |
echo '{{ get "myobject" | toYaml }}'
which produces:
$ variant Variantfile2 print-json-object-as-yaml
Variantfile2 ≫ starting task myobject
Variantfile2.myobject ≫ {"items":["private", "public"]}
Variantfile2 ≫ starting task print-json-object-as-yaml
items:
- private
- public
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
I was just trying to say that now I realize that parameterization actually works as well as object. So I should give them a better touch)
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
@mumoshu here it’s what I’m trying to do
tasks:
key:
parameters:
- name: count
type: integer
default: 1
script: |
echo '0: ["private", "public"]'
create:
options:
- name: key
type: object
required: true
script: |
echo '{{ get "key" | toYaml }}'
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
what do you want to use count
for?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
tasks:
key:
description: Generates eos key-pair(s)
parameters:
- name: count
description: Number of key-pairs to create
type: integer
default: 1
runner:
image: eosio/eos
command: bash
args: [-c]
script: |
{{- range $i, $e := until (.count) }}
pair=$(cleos create key --to-console | sed 's/.*: //' | sed ':a;N;$!ba;s/\n/", "/g')
printf "{{ $i }}: [\"%s\"]\n" "$pair"
{{- end }}
create:
description: Creates a keypair yaml file
options:
- name: key
type: object
required: true
script: |
cat <<EOF
{{ get "key" | toYaml }}
EOF
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
This is the real one ^
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
first one is a simplification
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
seems like you want to internally generate a YAML data and print it, right?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
yes so far yes. But I’m going to process that data
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
ah
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
so the data is not sucked by create…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
then i have to go back to yout original question.. you can’t map yaml
string to type object
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
you need to use json
as the internal data format
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
later print it as yaml by pipeing it to toYaml
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
toYaml
is for marshalling objects to YAML, not for parsing YAML data into objects
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
that I was saying yaml can not be passed as type: obeject
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
the point would be that you don’t need to explicitly parse json or yaml. type: object do that for you!
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
can we make it possible too?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
Imagine I want to load file a.yml
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
But first we need to generate that data too… (
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
while this kind of stuff works
tasks:
key:
parameters:
- name: count
type: integer
default: 1
script: |
echo '{"items": ["private", "public"]}'
create:
options:
- name: key
type: object
required: true
script: |
echo '{{ index (get "key") "items" }}'
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
yep, you are correct
that I was saying yaml can not be passed as type: obeject
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
probably. we need to settle on a configuration syntax for that tho
can we make it possible too?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@dennybaa is it possible for you to use jq, so that you can convert it to json before outputting?
yq is a portable command-line YAML processor. Contribute to mikefarah/yq development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
script: |
bash <<EOC | yq r -j -
{{- range $i, $e := until (.count) }}
pair=$(cleos create key --to-console | sed 's/.*: //' | sed ':a;N;$!ba;s/\n/", "/g')
printf "{{ $i }}: [\"%s\"]\n" "$pair"
{{- end }}
EOC
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
@mumoshu yup, i’m aware of yq bro of jq. Surely it’s possible, though it’s not likely to use option in general.
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
If we refer to containers, it will be a no go to inject yet another binary into them…
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
i slightly agree with u i used to think similarly, but started giving up because i can’t complete everything with just variant(of course?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
In my case personal case I have a customized container… i can install yq, jq In other cases I’m pretty sure possibility to feed yaml as object should exist. This will allow users to build interesting tools
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
agreed
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
it isn’t actually a bad idea to add yaml->object conversion for variant params
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
as it doesn’t add additional binary size to variant…
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
but started giving up because i can’t complete everything with just variant(of course?
I believe the grade of your integration issues is above one I can now imagine
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
tasks:
key:
description: Generates eos key-pair(s)
parameters:
- name: count
description: Number of key-pairs to create
type: integer
default: 1
output:
format: yaml
script: |
{{- range $i, $e := until (.count) }}
pair=$(cleos create key --to-console | sed 's/.*: //' | sed ':a;N;$!ba;s/\n/", "/g')
printf "{{ $i }}: [\"%s\"]\n" "$pair"
{{- end }}
maybe it’s a matter of adding output.format
to the task definition?
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
i don’t think it’s needed… better just raw understanding of json or yaml as object, since we don not introduce any syntax or functions (toObject, fromYaml, fromJson )…
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
anyways. json is a subset of yaml, so I bet just one line of code should be changed somewhere where this conversion happens)
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
aha, good point. i was implicitly forced to consider other formats like toml, jsonnet, that might be feature-requested in the future
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@dennybaa variant v0.27.0 has been published with this feature: type: object
parameter sourced from a task output in YAML
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Wrap up your bash scripts into a modern CLI today. Graduate to a full-blown golang app tomorrow. - mumoshu/variant
data:image/s3,"s3://crabby-images/81333/8133316a6e26462f04e5ff2cd734913e422c9058" alt="dennybaa avatar"
wow. amazing !
2019-03-26
2019-03-27
data:image/s3,"s3://crabby-images/0f8a1/0f8a1ac55b88e517fb5cf7a31192ce19a3419fe6" alt="ldlework avatar"
@ldlework has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
set the channel topic: https://github.com/mumoshu/variant
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
@loren has joined the channel
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
@oscarsullivan_old has joined the channel
2019-03-28
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Any clue why I get this error when following the tutorial?
⧉ sandbox
✓ (-sandbox-admin) variant ⨠ cat myfirstcommand
#!/usr/bin/variant
tasks:
bar:
script: |
echo "dude"
foo:
parameters:
- name: bar
type: string
description: "the bar"
- name: environment
type: string
default: "heaven"
script: |
echo "Hello {{ get "bar" }} you are in the {{ get "environment" }}"
⧉ sandbox
✓ (-sandbox-admin) variant ⨠ which variant
/usr/bin/variant
⧉ sandbox
✓ (-sandbox-admin) variant ⨠ ./myfirstcommand
Error: unknown command "./myfirstcommand" for "myfirstcommand"
Run 'myfirstcommand --help' for usage.
Unexpected type of error *errors.errorString: unknown command "./myfirstcommand" for "myfirstcommand"
ls -la
-rwxrwxr-x 1 oscar oscar 308 Mar 28 13:21 myfirstcommand
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
oops I missed the ls -la
, but yes that’s already been run
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
-rwxrwxr-x 1 oscar oscar 308 Mar 28 13:21 myfirstcommand
data:image/s3,"s3://crabby-images/b82ef/b82efa31774b02e0495c3fd9593957af087dfba0" alt="Joe Presley avatar"
@Joe Presley has joined the channel
2019-03-29
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@oscarsullivan_old Try running any
of the defined tasks by specifying the name like ./myfirstcommand foo
!
I guess - you’d expected to see the command’s help when it was run without any args, right?
I think it’s currently failing, by design, because you have no root with script
defined. I can make variant just print the help instead, though.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@mumoshu I think printing help would make sense in this case
2019-03-30
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
alright. will address it soon. thx!