-
Notifications
You must be signed in to change notification settings - Fork 307
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
Write a specification for unsatisfied task inputs. #359
Conversation
versions/development/SPEC.md
Outdated
* There is currently no way to supply a bubbled-up input in an outer workflow's | ||
call block. | ||
* Example: one cannot say call my_workflow as subworkflow | ||
`{ inputs: my_task.my_task_input=... }` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe this should be made allowed?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes maybe. But we should do that in another PR I think.
versions/development/SPEC.md
Outdated
* By default an engine only allows inputs that are specified in the input | ||
section of the top-level workflow. | ||
* An engine may optionally support supplying bubbled-up optional inputs, but | ||
this has to be explicitly enabled on the engine (via configuration, command | ||
line flags or otherwise). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I still feel it might be better to add some form of syntax in the WDL file itself. That way one would be able to see that there may be interesting nested inputs in the WDL files and, thus, that it would be good to use an engine which supports them.
In addition, a workflow might be written without the intention for the bubble-up behavior to be used. If someone then uses such a flag or configuration to allow for the bubble-up, they might be able to set optional inputs which will mess up the workflow.
An alternative to the last two points in the list:
- By default only inputs defined in the top-level workflow are made available to the user.
- The keyword
etc
must be added to a workflow's input section to enable the bubble-up behavior described above. Only if thisetc
keyword is present in the workflow's input section may an engine allow for this bubble-up behavior and an engine may choose not to support to feature at all.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The etc
keyword makes sense to me. However, why not just allow it in the workflow meta
section? This way, we don't need new syntax.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@DavyCats good points! @orodeh good suggestion! Setting it in the workflow seems indeed better than setting it in the engine, and using the meta section for this seems the most logical thing to do.
Something like:
meta {
bubbled-up-inputs: true
}
Except that I don't like the bubbled-up word. It is in the PR, but more on "a lack of a better term" basis.
How about nested inputs?
meta {
allow-nested-inputs: true
}
Or some other suggestions:
meta {
allow-hidden-inputs: true
allow-subworkflow-inputs: true
allow-extended-inputs: true
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure that the meta section is the appropriate place for this. The meta section is just a set of key-value pairs that hold no relevance to the execution of a workflow. It is intended to be a place where you might store contact information or a link to the documentation. This was also discussed (briefly) in #351.
This feels more like something that would fit in the runtime section, except that there is no runtime section for workflows right now.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
allow-nested-inputs
seems fine to me, though I wonder if using -
s might cause issues with the grammars.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Pinging @patmagee for the grammar question.
Well we could consider adding a runtime section for workflows, but that requires another spec/language change. (Which is why I wanted to set it engine-side) . Adding a runtime section could be useful, but there need to be other relevant things stored there. Having an entire runtime section for allow-nested-inputs
seems a bit ludicrous to me.
I think the meta section is quite appropriate: It states that this workflow has nice nested inputs. A user does not have to use them. I think it is more documentation than runtime information, since an engine does not have to support nested-inputs per se.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These are actually really great examples of something that can be added to the hints
section, and we leave it up to the engine to decide what to do. We tried to really trim down the runtime lock and make it the bare minimum requirements needed to run a workflow.
We already have the idea of "semi reserved" kw used in the hints section. These are hints that have similar meanings across all engines but do not need to be implemented.
I'd suggest doing something like:
hints {
allowNestedInputs: true
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@patmagee, yes, that seems to be the best section but in the PR for the hints section I only see it at the task
level. Will there also be a hints section at the the workflow level?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This doesn't feel like it quite matches the semantics of a "hint" to me to be honest.
A hint to me should mean "if an engine completely ignores this, it might miss out on some runtime optimization but the logical evaluation of the workflow should still be possible".
What we're talking about here is:
- a warning to users that their workflow might not work on all engines.
- a requirement to supporting engines that they should allow bubbled up inputs.
- a signal for engines which don't support this feature to quickly stop processing the workflow/task
I'd almost like to add a way to flag plugin
s or non-standard-features
or engine-requirements
. I know Ohad has a number of other ideas for features which would be really cool but tricky for Cromwell. A way to flag these high up in the context of a WDL file (perhaps even above the workflow scope) would be really nice.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
eg something like:
version 2.0
plugins {
bubbled-up-inputs,
streamable-input-files,
???
}
it's not 100% ideal because it allows engines to diverge, but at least it'd be obvious right at the top of the file whether your workflow will work with any particular engine (which would presumably be able to publish or otherwise indicate which features they support). It would also allow engines to "get out quickly" if they see required features which they didn't have.
I have joined @patmagee in trying to build a grammar for WDL with ANTRL4. My part is writing scala code that builds an AST from a WDL program (https://github.com/dnanexus-rnd/wdlTools). I now have a much better appreciation for the amount of work it takes to modify and maintain the grammar. Hence my reluctance to add additional syntax, unless we really need it. |
Given the feedback I coin the following proposal: If there is no additional use for a hints or runtime section for workflows, then we should settle on the meta block for harboring a key called If in due time the need arises for a runtime or hints section before WDL2.0 is released, we can always change this. If the need arises after WDL2.0 is released, we can deprecate (but still support) the use of allowNestedInputs in the meta section to provide a smooth transition. What do you think? If we are all in agreement that the |
Sounds good to me, thanks. |
@rhpvorderman I should have read further down before replying in thread! Is the idea that an engine could choose either to allow bubbling up only if this flag was set, or else to fail the workflow when it sees that flag? Your answer seems fine to me for now. The more general "how do we allow for diverging engine features" can be part of a future discussion. |
I think the engine should allow bubbling up. If it does not support bubbling up I think it should fail with a message, but only if bubbled-up namespaced inputs are actually used. Since all required inputs should be filled by the top-level workflow, this way all workflows can be run by all engines, regardless whether the flag is present or not. |
Co-Authored-By: DavyCats <davycats.dc@gmail.com>
I added the flag to the PR. I did not add any stuff about engines optionally supporting this feature yet. Do we want to specify this diverging behavior now, or can this wait for later since WDL2.0 is not released yet? |
Regarding diverging behavior, I see two viable stances that might be taken:
|
I propose we follow @cjllanwarne's suggestion and discuss diverging engine behavior in a future discussion. I think the PR is ready. Are there any points that need to be addressed on this PR before it gets into voting? |
Should voting be opened on this? There hasn't been any further discussion in a while. |
@patmagee Could you initiate the vote on this? It might be accepted or rejected, but it's getting a bit stale at the moment. I would do it myself if I had the label powers 😇. Thanks for your effort! |
@rhpvorderman can you please update the changelog.md :)? Once you do that, I can opn this up for voting |
@patmagee Done! |
👍 |
1 similar comment
👍 |
again with a further-qualified name. | ||
* Example: my_outer_workflow.my_workflow.my_task.my_task_input. | ||
* There is currently no way to supply a bubbled-up input in an outer workflow's | ||
call block. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not sure I understand this point. Does it contradict the previous one? I.e. the previous one seems to introduce an option, but this point seems to state it is not possible. Can you please clarify?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The first point is about the input json (or whatever other input format)
The outer workflow's call block is in the WDL code itself. When you call a workflow from inside a workflow. In that area there is currently no way to supply nested inputs.
thanks @rhpvorderman . Looks good to me 👍 |
Cromwell implementation pending in broadinstitute/cromwell#5523. I know this spec change does not generate a lot of buzz. However, it is important that it gets merged as a lot of the behavior it described was previously undefined. Cromwell, for example, allowed for calling tasks without supplying any inputs to the call block. These inputs could then be supplied by the inputs json of the workflow. This carries with it a lot of implicitness that makes workflows very hard to read. |
This has passed with a 3-0 vote. @rhpvorderman would you be able to rebase the changelog so that this can be merged Currently blocked by: broadinstitute/cromwell#5523 |
@patmagee done. Thanks |
This implements part of the spec change that handles inputs openwdl/wdl#359
@rhpvorderman This was implemented in cromwell 52, wasn't it? |
@DavyCats partially. |
versions/development/SPEC.md
Outdated
In this case, the inputs bubble up to become a nested input to the workflow | ||
instead. | ||
* Example: an unsupplied input might have the fully-qualified name | ||
`my_workflow.my_task.my_task_input.` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Period should go outside the backtick, I think
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for spotting this!
* By default an engine only allows inputs that are specified in the input | ||
section of the top-level workflow. | ||
* If a workflow is suitable for use with nested inputs it should be explicitly | ||
stated. This is done by setting `allowNestedInputs` to `true` in the meta |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
My problem with this is that things like allowNestedInputs
don't really belong in meta
- there's just no where else to put them. I am going to open a proposal to add a hints
section to workflow with the same semantics as it has in task. I think things like this more appropriately belong in hints than in meta.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think when designing the hints
section, I ultimately planned on having one in the workflow
as well. however it felt like a more natural transition to start with it in the task. In the lont term this is probably a good move. If we add the hints in 1.1, I feel like 2.0 can propogate the hints to the workflow
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree! Meta was always a bit of a "let's put it where it doesn't hurt" manoeuver.
Not having this feature proved to be a major hindrance in getting actual work done. But at least it is implemented in cromwell now, so it is at least possible to get work done until this feature lands.
If the hints proposal is landed I will rewrite this PR.
This is in v1.1 and will be propagated to development. |
This PR is a result of the discussion in #347 . This alternate PR was made because the scope shifted during the discussion.
These were some of the points made in the discussion:
This PR attempts to address all these points by:
Supporting bubbled-up inputs optionally is feasible in Cromwell thanks to how @cjllanwarne implemented the input calculation. I don't know about the other engines, but since it is optional, it should not be an extra burden.
Pinging @cjllanwarne , @mlin , @orodeh and @DavyCats as they brought up these points in the discussion.
EDIT: I also updated the example to reflect changes in the WDL spec so far.
Checklist