Releases: temporalio/sdk-typescript
1.11.6
[1.11.6] - 2025-01-08
Features
-
Introduce Update-with-Start (#1585)
-
Aside from Update-with-Start, all Workflow Update APIs are no longer experimental (#1590)
-
[
client
] Addclient.workflow.count
high level API (#1573, thanks to @THardy98) -
[
workflow
] ExposeAbortController
to the worker sandbox (#1576, thanks to @lukeramsden) -
[
workflow
] Propagate OpenTelemetry context when scheduling local activities (#1577, thanks to @THardy98)
Misc
- Thanks to @GSmithApps for doc improvements (#1591)
1.11.5
Noteworthy Changes
-
Normalize construction of user facing enums (#1534)
All user-facing enums have been revisited to be more in line with usual TypeScript conventions, rather than sticking to Temporal's Protobuf enum definitions.
In short, that means:
- No more redundant prefixes on enum values;
- No more
UNSPECIFIED
values — TypeScript'sundefined
already means that; - Enum types are now string unions, and users may choose to provide the string value directly.
For example:
await startChild(sleep, { - parentClosePolicy: ParentClosePolicy.PARENT_CLOSE_POLICY_ABANDON, + parentClosePolicy: ParentClosePolicy.ABANDON, /* or even */ + parentClosePolicy: 'ABANDON', });
Built-time compatibility is preserved for enum values that existed before. For example, code using
ParentClosePolicy.PARENT_CLOSE_POLICY_ABANDON
will still compile, but a deprecation will be reported.💥 Compile-time backward compatibility is only preserved for enums that were imported from user facing packages, such as
@temporalio/common
,@temporalio/client
and@temporalio/workflow
. Enum definitions imported directly from the@temporalio/proto
package may no longer compile.
Features
-
Add experimental support for user-implementable Slot Supplier. (#1553, temporalio/sdk-core#838, temporalio/sdk-core#842)
-
Add support for Workflow ID conflict policy. (#1490)
-
Expose classes
TextEncoder
andTextDecoder
inside of the Workflow sandbox. (#1562, kudo to @lukeramsden) -
The OpenTelemetry Interceptor now adds correlation metadata on emitted logs from Workflow and Activity context loggers. (#1565)
-
The OpenTelemetry Interceptor now passes the tracing metadata on signals. (#1449, kudo to @iravid)
-
[
client
] Add utility functionsisGrpcDeadlineError
andisGrpcCancelledError
. (#1548)
Bug Fixes
-
[
worker
] Fix memory leak on non-existant activity (#1563) -
[
activity
] Abort reason is now an instance ofCancellationFailure
(#1561, kudo to @ikonst) -
[
worker
] Ensure Resource Tuner always hand out a minimum of one slot for sticky and not sticky Workflow Task pollers (temporalio/sdk-core#835)
Docs
Miscellaneous Tasks
1.11.4
1.11.3
Bug Fixes
- [
worker
] Gracefully shut down Worker on unexpected errors (#1539) - [
worker
] Avoid a spurious error if Worker receives SIGINT while already shutting down (#1547)
Features
- [
Schedule
] Support query for listing schedules (#1535, Kudos to @nikhilbhatia08 🙏) - [
client
] :test: Add experimental support for Cloud Operations API (#1538)
1.11.2
Important ⚠️ ⚠️ ⚠️
- This release fixes a bug in 1.11.0 and 1.11.1 that may result in Workflows failing to replay with the very same code.
We urge users who are already using v1.11.0 or v1.11.1 to promptly upgrade to this release.
Bug Fixes
- [
workflow
] Workflow Activation Encoder was discarding SDK flags (#1530) - [
core
] Respect gRPC timeouts on get wf execution history (temporalio/sdk-core#812) - [
core
] Attempt to address unusal rpc cancellation error (temporalio/sdk-core#811) - [
core
] Fix legacy query failure replying (temporalio/sdk-core#809) - [
core
] Fix possible NDEs caused by LAs & immediate cancels resolving in different order upon replay (temporalio/sdk-core#808) - [
workflow
] Fix potential incoherencies in Workflow Activation Jobs ordering (#1513, temporalio/sdk-core#789) - [
core
] Include Search Attribute updates made in-workflow when continuing as new (temporalio/sdk-core#797) - [
core
] Add basic validation on Activity Tasks (temporalio/sdk-core#795) - [
core
] Do not send queries after we would fail WFT (temporalio/sdk-core#792)
Dependencies
Thanks
- Thanks to Ilya Priven for multiple docs improvements (#1507, #1525, #1527, #1524).
1.11.1
1.11.0
Bug Fixes
- Fix flakes in Worker Tuner and Workflow Update tests (#1463)
- [
workflow
] Don't propagate cancellation from non-cancellable scopes to children (#1429) - [
worker
] Don't fail Worker on Activity Task decode failures (port from #1473) (#1477) - [
ci
] Enable file-based persistence on dev server for stress tests (#1480) - [
workflow
] Fix cancel-before-started abandon activity (#1487) - [
doc
] Docs were no longer being built and deployed in CI (#1494) - [
workflow
] Process all activation jobs as a single batch (#1488)
Documentation
- Clarify some drawbacks of ephemeral servers, and other minor fixes (#1478)
Features
Resource-based Worker Auto-tuning (EXPERIMENTAL)
Experimental support for worker tuning has been added along with an implementation for auto-tuning based on available
resources. WorkerOptions
now has a tuner
field that can be set to a WorkerTuner
. This is composed of SlotSupplier
s, of which currently FixedSize
and ResourceBased
are available. ResourceBased
tuners change the number of available slots dynamically based on resource usage. For some examples of initializing the worker tuner, see here.
At some point the SlotSupplier
interface will be manually implementable, but only fixed-size and resource-based slot suppliers are currently supported. Custom slot suppliers will appear in the future.
This SDK API is experimental and may change in incompatible ways in the future.
- [
workflow
] Unify GRPC::CANCELED and DEADLINE_EXCEEDED in an SDK Timeout exception for Update (#1452) - [
workflow
] Expose updateId to update handlers (#1450) - [
workflow
] Add upsert memo command (#1321)
Miscellaneous Tasks
- Bump GHA runner for stress tests (#1492)
Client
- Make gRPC INTERNAL status retryable (#1455)