Skip to content

Releases: temporalio/sdk-typescript

1.11.3

17 Oct 22:07
Compare
Choose a tag to compare

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

25 Sep 17:38
Compare
Choose a tag to compare

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

Dependencies

Thanks

1.11.1

16 Aug 19:58
Compare
Choose a tag to compare

Bug Fixes

  • [client] Reexport WorkflowExecutionAlreadyStartedError from @temporalio/client (#1498)

1.11.0

16 Aug 19:58
Compare
Choose a tag to compare

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 SlotSuppliers, 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)

1.10.3

24 Jul 19:45
Compare
Choose a tag to compare

Bug Fixes

  • [worker] Don't fail Worker on Activity Task decode failures (#1473)

v1.10.2

16 Jul 18:24
Compare
Choose a tag to compare

Bug Fixes

  • [worker] Fix clients being created without prefixed metric meter (#1465)
  • [workflow] Don't propagate cancellation from non-cancellable scopes to children (#1466)
  • Update dependencies (#1467)

v1.10.1

27 May 13:05
Compare
Choose a tag to compare

What changed

  • On Linux, restored compatibility with GLIBC 2.18+ on both x64 and arm64 architectures.

v1.10.0

21 May 20:00
Compare
Choose a tag to compare

Important updates

  • 💥 Support for Node.js 14 and older GLIBC releases has been dropped. As announced previously, TS SDK v1.9 was the last minor release to support Node.js 14.

    Going forward, the TypeScript SDK requires:

    • Node.js 16.15 or more recent;
    • GLIBC 2.35 or more recent (update: we restored compatibility with GLIBC 2.18 in v1.10.1)
  • 💥 Support for Node.js 16 will soon be dropped. TS SDK v1.10 will be the last minor release to support Node.js 16. TS SDK v1.11 will require Node 18 or higher.

    Node.js 14 officially reached end-of-life on April 30th, 2023, and Node.js 16 reached end-of-life on September 11th, 2023 (see Node.js release schedule). We strongly encourage everyone to take immediate action in updating their deployments to supported versions of Node.js to ensure continued compatibility and receive the latest features and security updates.

Features

  • [client] Both Connection and NativeConnection now accept an apiKey option, making it easier to connect to Temporal Cloud and other Temporal servers that use bearer token authentication (#1385), as well as HTTP CONNECT Proxy (#1411, thanks to @brendan-myers for his help on getting this started 🙏).

  • [client] The startdelay Workflow option is no longer experimental (#1379). Thanks @tlafano 🙏.

  • [core] Core can now be configured to emit duration metrics as either seconds or milliseconds, as well as to include unit suffixes in metric names (#1383).

  • [worker] Add taskQueue and logSource metadata attributes on all log messages emitted inside the context of a worker. These attributes are there make is easier to diagnose some low level issues, as well as allow implementing fine-grained filtering of messages (eg. show DEBUG level messages for user-code, but only WARN for messages from the worker) (#1391).

Bug Fixes

  • [client] Bring gRPC retry options in line with other SDKs (#1368). Thanks to @chronos-tachyon 🙏.

  • [worker] Unreference timer created in parseWorkflowCode (#1370). Thanks @jhecking 🙏.

  • On POSIX systems, stdout and stderr are now properly inherited by ephemeral servers (e.g. TestWorkflowEnvironment.createLocal() and TestWorkflowEnvironment.createTimeSkipping()), making it easier to diagnose issues while creating a test environment (#1394).

  • @grpc/grpc-js has been updated to 1.10.x (#1388). It had previously been pinned to 1.7.3 to avoid multiple bugs and incompatibilities introduced in grpc-js 1.8.0. We have since reviewed these changes and confirmed that there is no longer any reason to refrain form updating that dependency.

  • bundler: Webpack output is now recorded as a single log entry, and color are disabled if output is not being sent to the console (#1414). Thanks @ikonst 🙏.

  • MockActivityEnvironment no longer causes initialization of the Runtime (#1401).

  • [common] Improve error messages for failureConverters (#1373).

  • [doc] Fix comment on default maxConcurrentActivityTaskPolls value (#1374) Thanks @taonic 🙏.

v1.9.3

23 Feb 23:20
Compare
Choose a tag to compare

Bug fixes

  • Fix deprecated patch removal when no subsequent command (temporalio/sdk-core#671).
  • Fix incorrect ordering of a query execution that could happen if new workflow tasks came in while there were buffered queries (temporalio/sdk-core#673).
  • Fix a possibility of sending local activity marker after the Workflow Task Complete command (temporalio/sdk-core#678).
  • Wait for activity completes to reach server before shutdown (temporalio/sdk-core#681).
  • Update protobuf definitions to work with the new EVENT_TYPE_WORKFLOW_EXECUTION_UPDATE_REQUESTED event (temporalio/sdk-core#677).
  • Fix a regression regarding gRPC incoming message limit due to a behavior change in tonic 0.9.0.

Documentation

  • Avoid doctype reexports canonicalization issue (#1354)

Miscellaneous Tasks

  • Add test for module property mutation isolation (#1356)

v1.9.1

08 Feb 00:10
4d87689
Compare
Choose a tag to compare

Bug Fixes

  • [worker] Fix prometheus and otel regressions (#1345)
  • Fix devDependencies in some of the SDK packages where file URLs were used instead of version numbers.

Documentation

  • Add note on custom conveters and bundleWorkflowCode (#1338)
  • Fix sort order + snipsync examples issue (#1341)
  • [worker] Update webpack error doc link in worker/bundler.ts (#1344)
  • Explain the purpose of updateId (#1318)

Features

  • [worker] Add a workflow metadata query (#1319)