Files
hatchet/examples/ruby/sticky_workers/worker.rb
Gabe Ruttner 7875d78057 Feat: Official Ruby SDK (#3004)
* feat: initial ruby sdk

* fix: run listener

* fix: scope

* feat: rest feature clients

* fix: bugs

* fix: concurrent register

* fix: tests and ergonomics

* docs: all of them

* chore: lint

* feat: add RBS

* feat: add GitHub Actions workflow for Ruby SDK with linting, testing, and publishing steps

* chore: lint

* refactor: simplify load path setup for Hatchet REST client and remove symlink creation

* fix: cert path

* fix: test

* fix: blocking

* fix: ensure Hatchet client is only initialized once across examples

* fix: tests

* remove: unused example

* fix: bubble up errors

* test: skip flaky for now

* remove: lifespans

* fix: durable context bugs

* fix: bulk replay

* fix: tests

* cleanup: generate tooling

* fix: integration test

* chore: lint

* release: 0.1.0

* chore: remove python comments

* refactor: remove OpenTelemetry configuration and related unused options

* fix: default no healthcheck

* chore: lockfile

* feat: register as ruby

* chore: lint

* chore: update py/ts apis to include ruby

* chore: docs pass

* chore: lint

* chore: generate

* chore: cleanup

* chore: generate examples

* tests: add e2e tests

* tests: cache examples dependencies

* fix: namespace

* fix: namespace

* fix: namespaces

* chore:lint

* fix: improve cancellation workflow polling logic and add error handling

* revert: py/ts versions
2026-02-15 14:32:15 -08:00

52 lines
1.0 KiB
Ruby

# frozen_string_literal: true
require "hatchet-sdk"
HATCHET = Hatchet::Client.new(debug: true) unless defined?(HATCHET)
# > StickyWorker
STICKY_WORKFLOW = HATCHET.workflow(
name: "StickyWorkflow",
# Specify a sticky strategy when declaring the workflow
sticky: :soft
)
STEP1A = STICKY_WORKFLOW.task(:step1a) do |input, ctx|
{ "worker" => ctx.worker.id }
end
STEP1B = STICKY_WORKFLOW.task(:step1b) do |input, ctx|
{ "worker" => ctx.worker.id }
end
# > StickyChild
STICKY_CHILD_WORKFLOW = HATCHET.workflow(
name: "StickyChildWorkflow",
sticky: :soft
)
STICKY_WORKFLOW.task(:step2, parents: [STEP1A, STEP1B]) do |input, ctx|
ref = STICKY_CHILD_WORKFLOW.run_no_wait(
options: Hatchet::TriggerWorkflowOptions.new(sticky: true)
)
ref.result
{ "worker" => ctx.worker.id }
end
STICKY_CHILD_WORKFLOW.task(:child) do |input, ctx|
{ "worker" => ctx.worker.id }
end
def main
worker = HATCHET.worker(
"sticky-worker", slots: 10, workflows: [STICKY_WORKFLOW, STICKY_CHILD_WORKFLOW]
)
worker.start
end
main if __FILE__ == $PROGRAM_NAME