Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add afterScenarioOutline & karate.scenarioOutline #2636

Merged
merged 4 commits into from
Jan 3, 2025

Conversation

OwenK2
Copy link
Contributor

@OwenK2 OwenK2 commented Dec 19, 2024

Description

This PR adds a karate.scenarioOutline variable that is accessable from within all Scenario Outlines and after hooks. It contains metadata about the outline which may be useful. This PR also adds a new after hook that can be define via:

* configure afterScenarioOutline = function() {...}

This after hook runs at the end of a Scenario Outline after the final afterScenario hook has run.

* match karate.scenario.exampleIndex == <num>

# Confirm scenarioOutline result
* match karate.scenarioOutline ==
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the whole PR looks good and I will definitely merge.

one question - is it really necessary to have a new scenarioOutline API, won't the existing scenario suffice ?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could put it in with karate.scenario but I feel like it's weird to store information about other scenarios in there. I think I prefer karate.scenarioOutline but I can change it to whatever you think is best.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the way I look at it is at run time, only scenarios exist. some scenarios happen to originate from scenario outlines. does that make sense ?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah that makes sense, I definitely learned that the code is structured that way as well. Maybe the karate.scenario object can have an outline section when it originates from a Scenario Outline and it can include some/all of the same data I currently put into karate.scenarioOutline?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

since exampleTableIndex is added to ScenarioResult.java won't that be sufficient ? if exampleIndex is not -1 it means it originated from an outline. and you can check exampleTableIndex for your requirement. I'm still not sure how you can identify if something is the last example

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No worries totally understand the context switching. I don't think there is any way to iterate over the scenario results in karate.feature. I think karate.feature just contains high level metadata like description, title, etc...

Yeah there is no absolute need to update the system of record immediately. But it is kind of fun to watch it update realtime :) Our old method was to write files with the results and combine them at the very end of the suite. This is fine but it leads to lots of files and if we want to cancel the suite the system of record is not updated. So this really is just an enhancement. I can see value in providing the karate.scnarioOutline metadata but ultimately this is your project so I will respect whatever your final decision is.

Also one thing I forgot to mention is that in order to update the correct test in the system of record we have to keep track of an API ID. Currently this API ID is just defined as a karate variable in each Scenario, so we would lose these IDs in the afterFeature if there were multiple scenarios. We have a pretty large test suite so it would be infeasible for us make any large scale change to switch to afterFeature

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

acknowledged. let me think over this a bit

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@OwenK2 I'm thinking that we should introduce a new afterScenarioOutline hook that may be much cleaner. I can see this also being useful for the @setup tag that has proven very useful - and being adopted more by teams. I would consider adding this to the Java hook - RuntimeHook

that said - I'm not yet able to figure when to call this hook and how to detect that the last scenario in an outline-batch has completed - and have this work even under parallel execution.

my current guess is here: https://github.com/karatelabs/karate/blob/v1.5.0/karate-core/src/main/java/com/intuit/karate/core/FeatureRuntime.java#L197 - where you can see a synchronize on the feature result. so perhaps we can add intelligence within that synchronize to a) see if we are part of an outline and b) see if all other scenarios in that outline are already in the feature-result.

let me know what you think. if we go down this path - I agree that we need a new data-structure like you did already that returns an array of results for a given scenario-outline.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ptrthomas This all sounds great to me, I will take a stab at it.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I followed your recommendations and got something working. Did some basic testing. Please let me know what you think when you get a chance. Thanks!

@@ -101,13 +104,13 @@ public List<Scenario> getScenarios(FeatureRuntime fr) {
if (selectedForExecution) {
Table table = examples.getTable();
if (table.isDynamic()) {
Scenario scenario = toScenario(table.getDynamicExpression(), -1, table.getLineNumberForRow(0), examples.getTags());
Scenario scenario = toScenario(table.getDynamicExpression(), examples.getIndex(), -1, table.getLineNumberForRow(0), examples.getTags());
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

so following up from my previous comment - suggest since in this loop we know how many examples and example tables are there - we will be able to emit an extra boolean if this is the last scenario selected for execution within an outline

if that solves your current ask - I would just do that, as I really don't see a need for tracking counts of examples and tables :|

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sounds good I can definitely make that simplification. What about the scenarioResults though? What do you feel would be the best way to get that information from an API perspective.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For now I just removed the table index code in 6e84b5d. Didn't want to push too far ahead before we finalized something.

@OwenK2 OwenK2 changed the title Add karate.scenarioOutline metadata Add afterScenarioOutline & karate.scenarioOutline Dec 24, 2024
@@ -61,6 +61,20 @@ public int compareTo(ScenarioResult sr) {
return scenario.getExampleIndex() - sr.scenario.getExampleIndex();
}

@Override
public boolean equals(Object obj) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

not to self: add hashCode also

/*
* The MIT License
*
* Copyright 2022 Karate Labs Inc.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nts: update date

/*
* The MIT License
*
* Copyright 2022 Karate Labs Inc.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nts: update date

@@ -213,6 +227,27 @@ public Map<String, Object> toKarateJson() {
return map;
}

// Paired down information for use in karate.scenarioOutline
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nts: pared

@ptrthomas ptrthomas merged commit 849b05a into karatelabs:develop Jan 3, 2025
3 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants