From 8cb7b0b1378c6735894080eb276eb90b2e2d5ca4 Mon Sep 17 00:00:00 2001 From: Anders Schwartz Date: Mon, 5 Feb 2024 16:47:49 -0500 Subject: [PATCH] docs: add tip for parsing JSON formatted outputs from `command`s (#2120) ## Description: add tip for parsing JSON formatted outputs from `command`s ## Is this change user facing? YES ## References (if applicable): Closes: #2088 --- .../starlark-reference/exec-recipe.md | 41 +++++++++++++++++++ 1 file changed, 41 insertions(+) diff --git a/docs/docs/api-reference/starlark-reference/exec-recipe.md b/docs/docs/api-reference/starlark-reference/exec-recipe.md index eceb143fcd..580643695f 100644 --- a/docs/docs/api-reference/starlark-reference/exec-recipe.md +++ b/docs/docs/api-reference/starlark-reference/exec-recipe.md @@ -34,6 +34,47 @@ If you are trying to run a complex `command` with `|`, you should prefix the com be rewritten as `command = ["/bin/sh", "-c", "echo a | grep a"]`. Not doing so makes everything after the `echo` as args of that command, instead of following the behavior you would expect from a shell. ::: +:::tip +If the executed command returns a proper `JSON` formatted data structure, it's necessary to pass the output through `jq`'s `fromjson` function to enable `jq` to parse the input. +For more information on `jq`'s built-in methods, plese refer to `jq`'s documentation. The following is an example of how to parse the json formatted output using `jq` syntax: + +Example: +``` +def run(plan, args={}): + plan.add_service( + name = "service", + config = ServiceConfig( + image = "alpine", + entrypoint = ["/bin/sh", "-c", "sleep infinity"], + ) + ) + cmd = ''' echo '{"key": "value"}' ''' + result = plan.exec( + service_name = "service", + recipe = ExecRecipe( + command = ["/bin/sh", "-c", cmd], + extract = { + "example_reference_key": "fromjson | .key" # <----- Notice the use of `fromjson` + } + ), + ) + plan.print(result["output"]) + plan.print(result["extract.example_reference_key"]) +``` + +will output: +``` +> print msg="{{kurtosis:1f60460f3eee4036af01b41fc2ecddc0:output.runtime_value}}" +{"key": "value"} + + +> print msg="{{kurtosis:1f60460f3eee4036af01b41fc2ecddc0:extract.example_reference_key.runtime_value}}" +value +``` + +::: + + [exec-reference]: ./plan.md#exec [wait-reference]: ./plan.md#wait