Expand my Community achievements bar.

Join us for the Adobe Campaign Community Q&A Coffee Break on 30th September at 8 am PT with Campaign experts Arthur Lacroix and Sandra Hausmann.
SOLVED

Workflow getting paused without error.

Avatar

Level 2

Hi ACC Friends,

My Recurring Campaign workflow getting into paused state and in the journal ,i am seeing below warning.

02/20/2023 5:46:02 AM Automatically resuming workflow 82678309 (number of consecutive times: 1).

 

at the end of workflow, we are calling stop method using queryDef (xtk.workflow.Stop(wf.@id)) .

And this issue not happening with every workflow, most of our recurring workflow running fine with above method, but few of them getting paused with above warning no other error.

Does anyone know why this warning is throwing in the workflow?

 

Thanks!!!

@ParthaSarathy @Shubham_Goyal__ @_Manoj_Kumar_ @david--garcia @Craig_Thonis @Denis_Bozonnet @akshaaga 

 

 

1 Accepted Solution

Avatar

Correct answer by
Level 2

Hi @Sukrity_Wadhwa  ,

I had implemented different solution. did not try Manoj's, solution 
using sqlExec("UPDATE Xtkworkflow SET istate ='"+20+"' WHERE iWorkflowId ='"+instance.id+"'");

Our requirement was marked that workflow finished intensely.

 

Thanks!!

Pradyumn 

View solution in original post

21 Replies

Avatar

Community Advisor

Share the whole script.

Avatar

Employee Advisor

Hi @Prady12,

The warning message suggests that your workflow (number 82678309) was paused and then automatically resumed by the system, with one previous occurrence of this happening.

Without more information, it is difficult to pinpoint the exact cause of the pause.

Regarding the warning message, it is the normal behavior of the system to automatically resume a paused workflow after a certain amount of time. This is usually done to prevent the workflow from pausing indefinitely or 

The "xtk.workflow.Stop()" method is used to stop the workflow from running further. However, if the workflow is already in a paused state, calling this method may not have any effect.

To further diagnose the issue, we would need to have the complete logs and detailed error messages. 

Avatar

Level 2

Prady12_0-1676950812238.png

Hi @akshaaga , please find above few more logs, as the workflow getting in paused state at end activity where we had written the JS code to Finish the workflow forcefully.  And end activity task is also in pending state:

Prady12_1-1676951014465.png

 

However, if the workflow is already in a paused state, calling this method may not have any effect?--> are you saying that if the workflow in pause state , calling xtk.workflow.Stop(wf.@id) method , will make any change in the workflow state ?

 

Avatar

Employee Advisor

Hi @Prady12 ,

Based on the additional information you provided, it looks like the workflow is getting paused at the end activity where you are calling a custom JavaScript code to finish the workflow forcefully, and the end activity task is also in a pending state. Regarding your question about the xtk.workflow.Stop() method, if the workflow is already in a paused state, calling this method will not have any effect on the state of the workflow.

In other words, calling xtk.workflow.Stop(wf.@id) will not resume a paused workflow or change its state from paused to another state.

Avatar

Level 2

Hi @akshaaga  , you got the logic correct, but we can stop the workflow by calling Stop method, even though workflow is in paused state.

 

So this statement is false for my caseIn other words, calling xtk.workflow.Stop(wf.@id) will not resume a paused workflow or change its state from paused to another state. 

Avatar

Employee Advisor

Hi @Prady12 ,

 

That's right. The xtk.workflow.Stop() method can be used to stop a workflow even if it is in a paused state.

When the xtk.workflow.Stop() method is called, it will terminate the workflow and set its status to "stopped." This is useful in situations where you want to forcefully stop a workflow that is not progressing or is causing issues. In your case, if the workflow is already paused and you call xtk.workflow.Stop(wf.@id), it should terminate the workflow and set its status to "stopped." However, keep in mind that if the root cause of the pause is not addressed, the workflow may still encounter the same issue again if it is restarted.

Avatar

Level 2

Yes , that's what i am trying to understand, why some of the workflow getting into paused state instead of Finish state. When we call  xtk.workflow.Stop() method.

Avatar

Employee Advisor

@Prady12 ,

When you call the xtk.workflow.Stop() method, it will stop the current workflow execution and put it in a paused state. The reason for this behavior is to allow the user to intervene manually and resolve any issues that caused the workflow to stop.

For example, if the workflow is trying to access a resource that is unavailable, you may need to fix the resource or update the workflow configuration to point to a valid resource.

Once the issue is resolved or the manual intervention is completed, the user can resume the workflow execution using the xtk.workflow.Resume() method.

At this point, the workflow will continue from the point where it was paused and proceed to the finish state once all steps have been completed successfully.

Avatar

Community Advisor

Hello @Prady12 ,

 

Sometimes the xtk.workflow.stop does not work within the same workflow.

 

Use these two methods:

xtk.workflow.Stop(wf.@id);
xtk.workflow.Kill(wf.@id)

     Manoj
     Find me on LinkedIn

Avatar

Level 2

Hi @_Manoj_Kumar_  so are you recommending to use Kill method instead of Stop ?

Avatar

Community Advisor

Hello @Prady12 

 

I am not sure what else is happening in your workflow. But if you want to stop the workflow and STOP is not working, then Kill will stop the workflow.

 

I have used this in one of my use cases where the workflow was started on demand with Start and was stopped/killed at the end of the workflow.


     Manoj
     Find me on LinkedIn

Avatar

Community Advisor

Kill is used for the unconditional stop, which is commonly used when the workflow fails to stop normally.


     Manoj
     Find me on LinkedIn

Avatar

Level 2

Thanks for suggestion @_Manoj_Kumar_  , i will try test kill method . 

Avatar

Level 2

Hi @_Manoj_Kumar_  , I had tried to use Kill method instead of Stop , but it did not stop the workflow.

yes, it's true Kill is used for the unconditional stop, It worked when i called it from different workflow. But within same workflow Kill did not work for me. It was kept on running based on the value set for option variable (NmsOperation_LimitConcurrency) .

 

 

Avatar

Community Advisor

Hello @Prady12,

 

Which activity are you using before this javascript function? Try adding a wait of 5 minutes before stopping/killing the WF.


     Manoj
     Find me on LinkedIn

Avatar

Community Advisor

NmsOperation_LimitConcurrency represents the number of workflows you can run simultaneously. it should not let you stop the WF.


     Manoj
     Find me on LinkedIn

Avatar

Level 2

Hi @_Manoj_Kumar_ , i am calling JS function at end the workflow in End Activity (advanced tab) .

Avatar

Community Advisor

Hello @Prady12 

 

Here is the solution:

 

Please create a new workflow. Let's call it a workflow stopper. It will start with an external signal and then a javascript code.

In this Javascript activity, add the following code.

xtk.workflow.Stop(vars.wfid);
xtk.workflow.Kill(vars.wfid)

 

Now in your the workflow that you want to stop:

Call this stopper workflow by the postevent and pass the current workflow id as a variable.

xtk.workflow.PostEvent("INERTNAL_NAME_OF_STOPPER_WORKFLOW", "signal", "", <variables wfid={wf.@id} />, false) 

 

Let me know if that works for you.


     Manoj
     Find me on LinkedIn

Avatar

Administrator

Hi @Prady12,

Was @_Manoj_Kumar_'s solution helpful to resolve your query? In case it was helpful, then kindly choose it as the 'Correct Reply'. If not and you still need more help, then do let us know.

Thanks!



Sukrity Wadhwa

Avatar

Correct answer by
Level 2

Hi @Sukrity_Wadhwa  ,

I had implemented different solution. did not try Manoj's, solution 
using sqlExec("UPDATE Xtkworkflow SET istate ='"+20+"' WHERE iWorkflowId ='"+instance.id+"'");

Our requirement was marked that workflow finished intensely.

 

Thanks!!

Pradyumn