What are the Slack Archives?
Itβs a history of our time together in the Slack Community! Thereβs a ton of knowledge in here, so feel free to search through the archives for a possible answer to your question.
Because this space is not active, you wonβt be able to create a new post or comment here. If you have a question or want to start a discussion about something, head over to our categories and pick one to post in! You can always refer back to a post from Slack Archives if needed; just copy the link to use it as a reference..
Hi, does someone know why the OMS doesn't execute transitions with `onEnter="true"` events automati
Hi,
does someone know why the OMS doesn't execute transitions with onEnter="true"
events automatically? I have this event:
<event name="auto cancel" onEnter="true" command="CrefoPay/Cancel" />
and such a transition:
<transition> <source>cancel call successful</source> <target>cancellation pending</target> <event>auto cancel</event> </transition>
I can trigger the transition manually from Zed; then it works and does what it should. But the oms:check-condition
never touches it. Why is this? What can be done about this?
Comments
-
Hi Gabriel!
I was facing a similar issue. Go check your database table
spy_oms_transition_log
for more details. There is one columnerror_message
which gives you more details about the error.0 -
Hi Martin - thanks, checked it just now, but there don't seem to be any errors logged. The error-related columns all have
null
as value.0 -
Okay, can you at least see that the command
CrefoPay/Cancel
is executed?0 -
Are you sure that your scheduler is running?
0 -
@U01LKKBK97T Yep. Same result (nothing) if I run the check-condition command manually.
0 -
@U01F1RQDKCY When triggered manually, yes. Otherwise no.
0 -
I'd suggest to debug manually. Stop the scheduler, and run the oms commands manually with debugging. Set your breakpoints inside your conditions and commands to see if they're getting called at all.
Assuming that you're using Docker, this should work:docker/sdk console scheduler:suspend docker/sdk console -x oms:check-condition docker/sdk console -x check-oms-timeouts
0 -
I'm using vagrant. Did that already. At first it seemed like the check-condition doesn't even consider transitions with events but now I see that further down in its code, onEnters are - theoretically - called separately. I'll check that in more detail and see what I find.
0 -
Buuut yeah, that doesn't help either, as its starting point is the same eventless-only stack of transitions.
0 -
If you check
\Spryker\Zed\Oms\Business\OrderStateMachine\OrderStateMachine::checkConditionsForProcess
, you can see that it already starts out, right on the first line, with$transitions = $process->getAllTransitionsWithoutEvent();
, and then derives all the rest from that. So it has no chance to find my transition with the onEnter event since it tries to filter it out ($orderItemsWithOnEnterEvent = $this->filterItemsWithOnEnterEvent($orderItems, $processes, $sourceStateBuffer);
) from a stack that never contained it to begin with.0 -
So, it seems I misunderstood something... apparently, it checks for onEnter events in the TARGET state. So what messed things up here was that the SOURCE state had event as well as condition. Since in the first half of the aforementioned method, it was looking explicitly for eventless transitions, it of course didn't find mine, didn't check it, didn't execute it - and neither could it do so in the second half, since there, it's looking for onEnter events in the TARGET state, so it didn't find it again, as the target state didn't have an event.
So I could solve it by including an intermediary state and moving the event there. The original source state now only has the check. Thus, the OMS is satisfied and can process everything correctly and automatically:
<state name="cancel received" reserved="false" />
<transition condition="CrefoPay/IsCanceledReceived"> <source>waiting for capture</source> <target>cancel received</target> </transition> <transition> <source>cancel received</source> <event>auto cancel</event> <target>canceled</target> </transition>
0
Categories
- All Categories
- 42 Getting Started & Guidelines
- 7 Getting Started in the Community
- 8 Additional Resources
- 7 Community Ideas and Feedback
- 77 Spryker News
- 937 Developer Corner
- 794 Spryker Development
- 90 Spryker Dev Environment
- 362 Spryker Releases
- 3 Oryx frontend framework
- 35 Propel ORM
- 68 Community Projects
- 3 Community Ideation Board
- 30 Hackathon
- 3 PHP Bridge
- 6 Gacela Project
- 27 Job Opportunities
- 3.2K π Slack Archives
- 116 Academy
- 5 Business Users
- 370 Docker
- 551 Slack General
- 2K Help
- 75 Knowledge Sharing
- 6 Random Stuff
- 4 Code Testing
- 33 Product & Business Questions
- 69 Spryker Safari Questions
- 50 Random