mirror of
https://github.com/hatchet-dev/hatchet.git
synced 2026-03-17 18:22:39 -05:00
* 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
52 lines
1.0 KiB
Ruby
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
|