- Graceful shutdown based on sigterm handler
- Adding cross domain signal/child workflow creation support
- Adding open telemetry support so that open telemetry context is propagated to cadence-server
- Adding dynamic poller support for more efficient resource usage.
- Fix describe domain and update domain grpc calls to include domainConfiguration and replication configuration in response.
- Fix gRPC adapter for List APIs.
- Add gRPC channel to client options.
- Add gRPC compatibility layer.
- Add refresh tasks API to provide ability to refresh tasks on stuck workflows.
- Fix a bug for PollOnlyIfExecutorHasCapacity flag about pool size.
- Introduce experimental flag and add logic for capacity based polling.
- Add CadenceChangeVersion support.
- Allow using other tags in metric reporter.
- Add metric tag to differentiate long-poll and normal request.
- Fix identity for sticky worker.
- Improve contributing guide.
- Fix consistent query interface which caused overloading ambiguity with variable argument
- Support delay start for cron workflows
- Add memo and search attributes to child workflow
- Added feature flags to ship breaking chgit loganges without impacting old behavior.
- Add Health check API to worker and service interface.
- Replace sticky tasklist metrics scope with the same value.
- [New feature] Workflow Shadowing worker and tests. The new shadowing feature provides:
- WorkflowShadower to run integration tests to replay workflow traffic from local/test environment.
- ShadowingWorker to run worker
- [Breaking changes] Introduce new error type WorkflowAlreadyCompletedError in APIs SignalWorkflowExecution, CancelWorkflowExecution and TerminateWorkflowExecution.
- Add Java 11 support.
- Add binary checksum support.
- Add activity worker thread count metrics.
- Add all missing version marker before upsert searchattributes.
- [New feature] Activity Local Dispatch: Allows Cadence worker to dispatch activity tasks through local tunnel after ScheduleActivity decisions are made. This is a performance optimization to reduce activity scheduling efforts.
- Pass TaskListActivitiesPerSecond to activity worker and remove the limit.
- Add missing workflowtype and activitytype metric tags.
- [Breaking changes] Refactoring in Worker initialization path:
- Worker.Factory -> WorkerFactory
- Worker.FactoryOptions -> WorkerFactoryOptions
- PollerOptions.Builder -> PollerOptions.newBuilder
- SingleWorkerOptions.Builder -> SingleWorkerOptions.newBuilder
- Added WorkerOptions Builder
- WorkflowClient.newInstance(IWorkflowService, Domain, WorkflowClientOptions) -> WorkflowClient.newInstance(IWorkflowService, WorkflowClientOptions)
- WorkflowClientOptions.Builder -> WorkflowClientOptions.newBuilder
- Testing framework
- Fix activity end-to-end latency metric.
- Fix newProxyInstance with the correct class.
- Fix bug in worker.isSuspended().
- Improve worker start/shutdown logic.
- Improve retry logic.
- Fix race condition during serialization.
- Fix get raw history
- Improve signal processing error and log
- Fix replay error when querying workflow that contains activity retry
- Fix getVersion override when added new version
- Add async signal to untypedstub
- Fix RetryOptions.addDoNotRetry
- Add missing metrics from go client
- Fix a bug in setting retry expiration while getting history
- Fix start async return
- Added supports contextPropagators for localActivity
- Fix prometheus reporting issue
- Fix Promise.allOf should not block on empty input
- Misc: Added project directory to sourceItems path
- Add async start to untype stub
- Add wf type tag in decider metrics scope
- Fix WorkflowStub.fromTyped method
- Added missing fields to local activity task
- Honor user timeout for get workflow result
- Fix leak in Async GetWorkflowExecutionHistory
- Fix context timeout in execute workflow
- Fix a bug in build.gradle that prevented javadoc and sources from being published
- Add ParentClosePolicy to child workflows and also expose parent execution info for child workflows
- Add context propagation
- Fix various bugs around test workflow service and test mutable state implementation
- Use thrift IDLs from uber/cadence-idl repo as a submodule
- Various dependency updates including Docker base image and Gradle wrapper
- Miscellaneous bug fixes
- Add Upsert Search Attributes
- Support get search attributes inside workflow
- Cleanup threads created in signal method on decider close
- Fixed exception propagation from child workflows
- Add missing metrics and tags
- Add metrics for SCHEDULED_TO_STAR latency
- Support filtering query based on close status
- Documentation improvements
- Fix thread leak on non-deterministic error
- Support Search Attributes on Start workflow
- Make Worker.addWorkflowImplementationFactory method support 'options'
- Add saga class that helps user to implement saga pattern in Cadence
- Add activity tasklist rate limiter option to worker options
- Fix busy loop in local activity poller if there is no task
- Fix an issue in get history timeout
- Lock decider while processing
- Timer firing fix
- Local activities
- Make sure signals are applied in the same order as they appear in history
- Fix retry option without expiration in test env
- Maintain correct runID during reset for random ID generation
- Default retry policy for Cadence service API calls
- Change markers to use headers to serialize internal fields
- Miscellaneous stability and debuggability fixes
- Support Memo in visibility
- Fix getVersion without decision event
- Make NoopScope metric scope really a no-op operation
- Add some more fields in activity info
- Wire workflow id reuse policy in start workflow execution params
- Add missing metrics tags for activity and decision task processing
- Multiple fixes to get build and unit-tests passing when building cadence-java-client from Windows.
- Allow data converter to handle non-serializable throwables in the cause chain
- Update default long poll timeout to 2min to match server side config
- Fix deadlock in sticky decider cache eviction
- Fix cron schedule merge issue in child workflow option
- Fixed InternalServiceError Error message on continue_as_new
- Correctly calculate workflow e2e latency
- Exposing CancellationScope.run method
- Add TBase and TEnum type adapter for JsonDataConverter
- Cron child workflow
- Added support for SignalWithStart Service API
- Expose methods in TChannel service to allow user to add headers in Thrift request
- Added cron schedule support.
- Fix infinite retryer in activity and workflow worker due to non-retryable error.
- Fixed hanging on testEnv.close when testEnv was not started.
- Fix for NPE when method has base type return type like int.
- Fixed JsonDataConverter to correctly report non serializable exceptions.
- Added support for workflow and activity server side retries.
- Clean worker shutdown. Replaced Worker shutdown(Duration) with Worker shutdown, shutdownNow and awaitTermination.
- Fixed thread exhaustion with a large number of parallel async activities.
- Added RPC headers needed to enable sticky queries. Before this change queries did not used cached workflows.
- Requires minimum server release v0.4.0
- Introduced WorkerFactory and FactoryOptions
- Added sticky workflow execution, which is caching of a workflow object between decisions. It is enabled by default, to disable use FactoryOptions.disableStickyExecution property.
- Updated Thrift to expose new types of service exceptions: ServiceBusyError, DomainNotActiveError, LimitExceededError
- Added metric for corrupted signal as well as metrics related to caching and evictions.
- POJO workflow, child workflow, activity execution.
- Sync and Async workflow execution.
- Query and Signal workflow execution.
- Test framework.
- Metrics and Logging support in client.
- Side effects, mutable side effects, random uuid and workflow getVersion support.
- Activity heartbeat throttling.
- Deterministic retry of failed operation.