Pablo Estrada created BEAM-14387:
------------------------------------
Summary: DirectRunner does not update reference to
currentRestriction when running in SDF
Key: BEAM-14387
URL: https://issues.apache.org/jira/browse/BEAM-14387
Project: Beam
Issue Type: Bug
Components: runner-direct
Reporter: Pablo Estrada
I have an SDF implementation that looks like so:
{code:java}
class MyRestrictionTracker {
MyRestriction restriction;
currentRestriction() { return restriction; }
tryClaim(MyPosition position) {
this.restriction = new MyRestriction(position)
}
}{code}
I ran this on the DirectRunner, and the restriction would never advance: It
would get stuck on the very first value.
I also ran this on DataflowRunner, and the problem did not exist there: This
ran fine.
I was able to fix this on the DirectRunner (it works well on Dataflow as well)
by changing the restriction to be mutable. Something like this:
{code:java}
class MyRestrictionTracker {
MyRestriction restriction;
currentRestriction() { return restriction; }
tryClaim(MyPosition position) {
this.restriction.position = position;
}
}{code}
This looks like an execution issue with SDF on DirectRunner: The DirectRunner
is likely storing a reference to `currentRestriction()` and never updating it
as it runs.
I'm happy to fix this on the DirectRunner - I would just like to find pointers
: )
--
This message was sent by Atlassian Jira
(v8.20.7#820007)