The condition that includes it is satisfied, and it is included. The first task
runs (the stat to check for a file). This causes the second task to skip, since
"st.stat.exists == False" is not so (i.e. don't run if the file exists).
However, then the rest of the tasks in that file are skipped as well, even
though they have no "when" conditional on them.
Footnote: I know I don't have to do the stat check before the get_url. I had
named a file wrong, and get_url was failing, and I wasn't understanding the
error message, thus the stat call. But it did bring up this odd behavior that
I would still like to understand.
The first thing it does is another stat, which is stored in 'st'. In this case,
'st.stat.exists == False' is false, because the file is there, which mean it
skipped the download. Once I removed the 'when' in the above gist, it
properly processed the file. It *SEEMED* the 'when' in the gist was affecting
the rest of the steps in the gist.
OK, so the condition for the include was satisfied, which means for each step
in the file should have the condition satisfied.
Are you saying because I used the same var in both places, the *second* use of
'st' is used to evaluate the 'when' condition that is implicitly applied to
all the included steps? That sounds like a scoping problem, if so.
Registered variables are stored on a per-host basis, and thus are always visible to the host when it’s compiling its variables. So it’s not really a scoping problem, as it’s not tied to the include. Now, if you passed the variable in as a parameter to the include, it would in fact limit the scope to that include.
OK, that makes sense. First part of the confusion came because I didn't
realize Ansible eval'ed the 'when' condition for each step of the include.
Probably didn't remember reading that in the docs.
As for the scoping, to be sure I'm understanding:
The "outer" file creates a var called 'st' and uses it in the 'when' to include
<file>.
<file> has a step which registers its result in 'st' (and changes the value in
this case).
The outer file then re-evaluates the 'st' var (which is the *same* var), sees
the condition is no longer true, and skips the rest of the steps.
That's actually kind of handy...the included file could short-circuit its own
execution if it changed the value of the var used in the 'when'.
Much thanks to you and Brian for your patience in walking me through this!