03-04-2019 04:48 PM
I have a step with looping. I would like a post-expression to execute only if the step is done. Is there a step property for that?
Solved! Go to Solution.
03-04-2019 05:59 PM
So technically you cannot precondition the post-expression. However, you could use a conditional to execute your expression. Something like this:
(Str(Evaluate(Step.LoopWhileExpression)) == "True") ? (Locals.Foo = 5) : False
03-05-2019 11:21 AM - edited 03-05-2019 11:22 AM
jigg, I'm not sure I am following. I would need a conditional in the post expression, but how can I know if the step is about to exit?
The goal is to add results to a results array only if the step is completed. If looping is enabled, the post expression is executed multiple times, and then the results array has too many entries.
I can accomplish the same in 3 steps, which is a little clunky but works:
1. execute multiple numeric limit test.
2. add results to result array
Locals.results += { RunState.PreviousStep.Result.Measurement["measurement_name"].Data }
3. goto end with precondition: RunState.Sequence.Main["test_name"].Result.Status != "Passed"
03-05-2019 11:37 AM - edited 03-05-2019 11:37 AM
As an aside, I just realized I can get rid of the 3rd step by combining it with the 2nd. A statement expression can have a post action on a custom condition, so I can have it exit there if the multiple numeric limit test failed.
Hm, the post action step only gets triggered when the step is about to exit, even if looping is enabled. I wonder what triggers that ...
03-05-2019 11:44 AM
I'm not sure I follow your need. At first you simply asked how to procondition a post-expression and now you are wanting to do some stuff with the Multi-Numeric Step where you inject results into the measurement array?
On the looping properties there is a Record Result of Each Iteration checkbox. What is that set to. Uncheck it and it should just grab the last one.
03-05-2019 01:36 PM - edited 03-05-2019 01:47 PM
I am saving the results of the step into an array of numbers called Locals.results. This happens in the post expression every time the step is executed, regardless of whether the box to record the results of each iteration is checked. I don't want it to happen if the step is not about to exit.
If a step with looping enabled fails twice and then passes, Locals.results will have accumulated 3 sets of values. Since Locals.results will get converted to a row in a CSV file, it will end up with too many columns.
03-05-2019 02:24 PM
My bad. I assumed you were talking Locals.ResultList. I didn't realize you had made your own array called Locals.results.
So correct me if I'm wrong but you just want to capture the results from the last iteration into your array? If so then delete everything in the Post-Expression and then in your Post Actions check the Use Custom Condition box and place the following in there:
Locals.results += { RunState.PreviousStep.Result.Measurement["measurement_name"].Data }, Step.Result.Status == "Passed"
Expressions always evaluate to the last element in the list of expressions which are separated by commas.
Let me know if this will work for you.
03-05-2019 03:20 PM
Perfect. Exactly what I needed.