Salt State Rendering:我能看到Jinja阶段的输出吗?

Mic*_*les 4 salt-stack

题:

在尝试解析为 YAML 之前,有没有办法查看 Jinja 阶段的输出?

背景:

我试图调试一个 Salt 问题,在那里我收到了这个错误:

local:
Data failed to compile:
----------
Rendering SLS ':test.sls' failed: mapping values are not allowed in this context
Run Code Online (Sandbox Code Playgroud)

不是很有帮助:没有行号?什么是“映射值”?等等。

问题归结为这样的事情:

{%- for x in [1, 2] -%}
Test {{ x }}:
  cmd.run:
    - name: echo Test {{ x }}
{%- endfor -%}
Run Code Online (Sandbox Code Playgroud)

经验丰富的 Salt 人员会认识到我弄乱了空格,因此 Jinja 产生了以下输出:

Test 1:
  cmd.run:
    - name: echo Test 1 Test 2:
  cmd.run:
    - name: echo Test 2
Run Code Online (Sandbox Code Playgroud)

然而,在一组复杂的状态中发现没有关于问题发生在哪里的信息,甚至没有明确描述问题是什么,这令人沮丧。

在调试过程中,我了解到您可以使用 获取 YAML 树slsutil.renderer,如下所示:

% salt-call --local slsutil.renderer `pwd`/test.sls 'jinja'

local:
    ----------
    Test 1:
        ----------
        cmd.run:
            |_
              ----------
              name:
                  echo Test 1
    Test 2:
        ----------
        cmd.run:
            |_
              ----------
              name:
                  echo Test 2
Run Code Online (Sandbox Code Playgroud)

但这当然要求 YAML 有效。那么,在评估 Jinja 之后,但在 Salt 尝试将其解析为 YAML 之前,如何让 Salt 像上面的第三个片段一样输出模板?

Mic*_*les 5

哦,哇,当我重新审视这个时,我学到了一些新东西。我相信答案是cp.get_template

测试文件:

% cat test.sls

{%- for x in [1, 2] -%}
Test {{ x }}:
  cmd.run:
    - name: echo Test {{ x }}
{%- endfor -%}
Run Code Online (Sandbox Code Playgroud)

现在cp.get_template渲染 Jinja 并显示原始输出:

% salt-call --local cp.get_template `pwd`/test.sls /dev/stdout

Test 1:
  cmd.run:
    - name: echo Test 1Test 2:
  cmd.run:
    - name: echo Test 2
local:
    /dev/stdout
Run Code Online (Sandbox Code Playgroud)