mirror of
https://github.com/hatchet-dev/hatchet.git
synced 2026-05-06 18:09:49 -05:00
a6650ab84c
* refactor: overloads for run methods, deprecate _no_wait flavors * refactor: same thing for run_many flavors * fix: use gather_max_concurrency for gathering run results * refactor: deprecate a bunch of stuff on the context and core hatchet client * refactor: runs client deprecations * refactor: add deprecation warning to go duration string durations * refactor: durable tasks must be async * chore: changelog * fix: copilot comments * fix: couple more * chore: rm `debug=True` from all the examples * chore: more debug params * fix: more deprecations * fix: more warnings * fix: non-utc timezones * chore: deprecate more internal stuff * fix: a bunch more internal-only stuff, remove non-v2 listener logic * fix: test * chore: make a bunch more things internal * feat: priority enum * refactor: top-level `types` directory * refactor: start reworking labels * fix: some type checker issues * fix: rm transform method in favor of instance method * fix: internal worker label types * fix: more types * refactor: finish labels * fix: labels * chore: gen * fix: rm internal glue pydantic model * fix: removed `owned_loop`, register workflows on worker start instead of init * fix: deprecate ctx getter in favor of property * refactor: more label cleanup, prepare to remove worker context * fix: more deprecations * refactor: get rid of a pydantic a few places we don't need validation * refactor: plan to remove `BulkPushEventOptions` * chore: changelog * chore: changelog * refactor: trigger types * fix: pydantic model default * fix: instrumentor types * refactor: add `seen_at` to event * refactor: remove some more protobuf types * fix: rm unneeded ts_to_iso * refactor: clean up more examples * fix: more warnings * chore: gen * chore: more warnings * fix: one more * fix: warning, namespace * fix: linters * fix: double import * fix: ugh, cursor * fix: clean up a bunch of suboptimal tests * fix: overload signatures * chore: gen * chore: revert opts change * chore: one more revert * feat: start reworking option passing to remove pydantic models * refactor: worker opt * fix: type cleanup * refactor: keep working out signature details * fix: changelog * fix: deprecate some streaming methods * fix: linters * fix: rebase * chore: rm some unused stuff * chore: rm more unused stuff * fix: rm more uses of `options` * fix: more deprecation warnings * fix: instrumentor wrapping * fix: add test for instrumentor signature * chore: deprecate upsert labels on the worker context thingy * fix: deprecate more stuff on the worker context * feat: add `worker_labels_dict` property * fix: label types for workers * chore: update changelog * fix: version * refactor: durable_eviction -> eviction_policy * fix: lint * fix: instrumentor not passing options properly * fix: un-remove * fix: priority * chore: version * fix: improve warning log
72 lines
1.6 KiB
Python
72 lines
1.6 KiB
Python
import asyncio
|
|
import random
|
|
import time
|
|
|
|
from pydantic import BaseModel
|
|
|
|
from hatchet_sdk import Context, Hatchet
|
|
|
|
|
|
class MockInput(BaseModel):
|
|
foo: str
|
|
|
|
|
|
class StepOutput(BaseModel):
|
|
random_number: int
|
|
|
|
|
|
class RandomSum(BaseModel):
|
|
sum: int
|
|
|
|
|
|
hatchet = Hatchet()
|
|
|
|
run_detail_test_workflow = hatchet.workflow(
|
|
name="RunDetailTest", input_validator=MockInput
|
|
)
|
|
|
|
|
|
@run_detail_test_workflow.task()
|
|
async def step1(input: MockInput, ctx: Context) -> StepOutput:
|
|
return StepOutput(random_number=random.randint(1, 100))
|
|
|
|
|
|
@run_detail_test_workflow.task()
|
|
async def cancel_step(input: MockInput, ctx: Context) -> None:
|
|
await ctx.aio_cancel()
|
|
for _ in range(10):
|
|
await asyncio.sleep(1)
|
|
|
|
|
|
@run_detail_test_workflow.task()
|
|
async def fail_step(input: MockInput, ctx: Context) -> None:
|
|
raise Exception("Intentional Failure")
|
|
|
|
|
|
@run_detail_test_workflow.task()
|
|
async def step2(input: MockInput, ctx: Context) -> StepOutput:
|
|
await asyncio.sleep(5)
|
|
return StepOutput(random_number=random.randint(1, 100))
|
|
|
|
|
|
@run_detail_test_workflow.task(parents=[step1, step2])
|
|
async def step3(input: MockInput, ctx: Context) -> RandomSum:
|
|
one = ctx.task_output(step1).random_number
|
|
two = ctx.task_output(step2).random_number
|
|
|
|
return RandomSum(sum=one + two)
|
|
|
|
|
|
@run_detail_test_workflow.task(parents=[step1, step3])
|
|
async def step4(input: MockInput, ctx: Context) -> dict[str, str]:
|
|
print(
|
|
"executed step4",
|
|
time.strftime("%H:%M:%S", time.localtime()),
|
|
input,
|
|
ctx.task_output(step1),
|
|
ctx.task_output(step3),
|
|
)
|
|
return {
|
|
"step4": "step4",
|
|
}
|