Uh oh!
There was an error while loading. Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork 143
Open
Description
A way to join the results from multiple stages to a single function fusing the results into the positional args of the target function.
Thinking something like this could work, let me know if you think it's worth cleaning up/documenting and writing all the tests for:
fromtypingimportIterable, Callableimportinspectfromreturns.resultimportSuccess, Failure, Resultdeffuse(results: Iterable[Result], target: Callable) ->Result: """Fuse the results from multiple containers into the args for a target function. Args: results (Iterable[Result]): The results from multiple container functions. target (Callable): The target function that receives the arguments. """successes, failures, invalid= [], [], [] forresinresults: matchres: caseSuccess(value): successes.append(value) caseFailure(error): failures.append(error) case _: invalid.append(res) ifinvalid: returnFailure(ValueError(f"Input args are not all Result types: {invalid}")) iffailures: returnFailure(ValueError(f"Not all results are Success: {failures}")) expected_args=len(inspect.signature(target).parameters) iflen(successes) !=expected_args: returnFailure( ValueError( f"Expected {expected_args} args for `{target.__name__}`, but got {len(successes)}" ) ) try: returntarget(*successes) exceptExceptionase: returnFailure(e)Using this basic case function here:
defadd(a, b) ->Result[int, str]: ifa>0: returnSuccess(a+b) returnFailure(f"Err: expected `a` > 0. Got `a`= {a}.")Usage:
Happy path all args are expected
fuse([Success(1), Success(3)], add)output:
<Success: 4> Returns failure if some exist
fuse([Success(3), Failure("Err: expected `a` > 0. Got `a`= -2.")], add)output:
<Failure: Not all results are Success: ['Err: expected `a` > 0. Got `a`= -2.']> Catch all the failures and report them all (avoiding solving one issue then finding another)
fuse([Failure("Err: expected `a` > 0. Got `a`= -2."), Failure("Err: expected `a` > 0. Got `a`= -2.")], add)output:
<Failure: Not all results are Success: ['Err: expected `a` > 0. Got `a`= -2.', 'Err: expected `a` > 0. Got `a`= -2.']> Catch when someone is passing in a non Result type:
fuse([1, Failure("Err: expected `a` > 0. Got `a`= -2.")], add)output:
<Failure: Input args are not all Result types: [1]> catch if not given the right number of args:
fuse([Success(1)], add)output:
<Failure: Expected 2 args for `add`, but got 1> catch overall exceptions just in case:
fuse([Success(1), Success("1")], add)output
<Failure: unsupported operand type(s) for +: 'int' and 'str'> Metadata
Metadata
Assignees
Labels
No labels