Search in sources :

Example 1 with ActivityCancelledException

use of com.uber.cadence.client.ActivityCancelledException in project cadence-client by uber-java.

the class ActivityExecutionContextImpl method recordActivityHeartbeat.

/**
 * @throws CancellationException
 * @see ActivityExecutionContext#recordActivityHeartbeat(Object)
 */
@Override
public void recordActivityHeartbeat(Object details) throws ActivityCompletionException {
    // TODO: call service with the specified minimal interval (through @ActivityExecutionOptions)
    // allowing more frequent calls of this method.
    RecordActivityTaskHeartbeatRequest r = new RecordActivityTaskHeartbeatRequest();
    r.setTaskToken(task.getTaskToken());
    byte[] serialized = dataConverter.toData(details);
    r.setDetails(serialized);
    RecordActivityTaskHeartbeatResponse status;
    try {
        status = service.RecordActivityTaskHeartbeat(r);
        if (status.isCancelRequested()) {
            throw new ActivityCancelledException(task);
        }
    } catch (EntityNotExistsError e) {
        throw new ActivityNotExistsException(task, e);
    } catch (BadRequestError e) {
        throw new ActivityCompletionFailureException(task, e);
    } catch (TException e) {
        log.warn("Failure heartbeating on activityID=" + task.getActivityId() + " of Workflow=" + task.getWorkflowExecution(), e);
    // Not rethrowing to not fail activity implementation on intermittent connection or Cadence errors.
    }
}
Also used : ActivityNotExistsException(com.uber.cadence.client.ActivityNotExistsException) TException(org.apache.thrift.TException) ActivityCancelledException(com.uber.cadence.client.ActivityCancelledException) RecordActivityTaskHeartbeatResponse(com.uber.cadence.RecordActivityTaskHeartbeatResponse) ActivityCompletionFailureException(com.uber.cadence.client.ActivityCompletionFailureException) RecordActivityTaskHeartbeatRequest(com.uber.cadence.RecordActivityTaskHeartbeatRequest) EntityNotExistsError(com.uber.cadence.EntityNotExistsError) BadRequestError(com.uber.cadence.BadRequestError)

Example 2 with ActivityCancelledException

use of com.uber.cadence.client.ActivityCancelledException in project cadence-client by uber-java.

the class POJOActivityTaskHandler method mapToActivityFailure.

private ActivityTaskHandler.Result mapToActivityFailure(ActivityTask task, Throwable failure) {
    if (failure instanceof Error) {
        throw (Error) failure;
    }
    if (failure instanceof ActivityCancelledException) {
        throw new CancellationException(failure.getMessage());
    }
    RespondActivityTaskFailedRequest result = new RespondActivityTaskFailedRequest();
    failure = CheckedExceptionWrapper.unwrap((Exception) failure);
    result.setReason(failure.getClass().getName());
    result.setDetails(dataConverter.toData(failure));
    return new ActivityTaskHandler.Result(null, result, null, null);
}
Also used : ActivityCancelledException(com.uber.cadence.client.ActivityCancelledException) CancellationException(java.util.concurrent.CancellationException) ActivityCancelledException(com.uber.cadence.client.ActivityCancelledException) CancellationException(java.util.concurrent.CancellationException) InvocationTargetException(java.lang.reflect.InvocationTargetException) RespondActivityTaskFailedRequest(com.uber.cadence.RespondActivityTaskFailedRequest)

Example 3 with ActivityCancelledException

use of com.uber.cadence.client.ActivityCancelledException in project cadence-client by uber-java.

the class ManualActivityCompletionClientImpl method recordHeartbeat.

@Override
public void recordHeartbeat(Object details) throws CancellationException {
    if (taskToken != null) {
        RecordActivityTaskHeartbeatRequest request = new RecordActivityTaskHeartbeatRequest();
        request.setDetails(dataConverter.toData(details));
        request.setTaskToken(taskToken);
        RecordActivityTaskHeartbeatResponse status = null;
        try {
            status = service.RecordActivityTaskHeartbeat(request);
            if (status.isCancelRequested()) {
                throw new ActivityCancelledException();
            }
        } catch (EntityNotExistsError e) {
            throw new ActivityNotExistsException(e);
        } catch (TException e) {
            throw new ActivityCompletionFailureException(e);
        }
    } else {
        throw new UnsupportedOperationException("Heartbeating by id is not implemented by Cadence service yet.");
    }
}
Also used : ActivityNotExistsException(com.uber.cadence.client.ActivityNotExistsException) TException(org.apache.thrift.TException) ActivityCancelledException(com.uber.cadence.client.ActivityCancelledException) RecordActivityTaskHeartbeatResponse(com.uber.cadence.RecordActivityTaskHeartbeatResponse) ActivityCompletionFailureException(com.uber.cadence.client.ActivityCompletionFailureException) RecordActivityTaskHeartbeatRequest(com.uber.cadence.RecordActivityTaskHeartbeatRequest) EntityNotExistsError(com.uber.cadence.EntityNotExistsError)

Aggregations

ActivityCancelledException (com.uber.cadence.client.ActivityCancelledException)3 EntityNotExistsError (com.uber.cadence.EntityNotExistsError)2 RecordActivityTaskHeartbeatRequest (com.uber.cadence.RecordActivityTaskHeartbeatRequest)2 RecordActivityTaskHeartbeatResponse (com.uber.cadence.RecordActivityTaskHeartbeatResponse)2 ActivityCompletionFailureException (com.uber.cadence.client.ActivityCompletionFailureException)2 ActivityNotExistsException (com.uber.cadence.client.ActivityNotExistsException)2 TException (org.apache.thrift.TException)2 BadRequestError (com.uber.cadence.BadRequestError)1 RespondActivityTaskFailedRequest (com.uber.cadence.RespondActivityTaskFailedRequest)1 InvocationTargetException (java.lang.reflect.InvocationTargetException)1 CancellationException (java.util.concurrent.CancellationException)1