-
Notifications
You must be signed in to change notification settings - Fork 787
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
8e15b44
commit 700c361
Showing
3 changed files
with
52 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
from metaflow.plugins import STEP_DECORATORS | ||
|
||
from metaflow.tests.flows import NewLinearFlow | ||
from metaflow.tests.step_counter import StepCounter | ||
|
||
STEP_DECORATORS.append(StepCounter) | ||
|
||
|
||
class StepCounterFlow(NewLinearFlow): | ||
"""Example flow that can receive `--with step_counter` from the CLI | ||
In order for `--with my_decorator` to work on the CLI, `my_decorator` needs to added to `STEP_DECORATORS`, as above. | ||
I don't know of a good way to accomplish that other than making a trivial flow (`StepCounterFlow` here) that just | ||
mixes in the target flow (`NewLinearFlow`) in a file that appends the decorator (`StepCounter`) to `STEP_DECORATORS. | ||
TODO: formalize an API for registering step- and flow-decorators without having to define a new flow like this. | ||
""" | ||
|
||
pass |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
from metaflow.decorators import StepDecorator | ||
|
||
|
||
class StepCounter(StepDecorator): | ||
name = "step_counter" | ||
|
||
def task_post_step( | ||
self, step_name, flow, graph, retry_count, max_user_code_retries | ||
): | ||
if not hasattr(flow, "step_count"): | ||
flow.step_count = 0 | ||
flow.step_count += 1 | ||
print("step count: %d" % flow.step_count) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
from metaflow.tests.flows.step_counter_flow import StepCounterFlow | ||
from metaflow.tests.utils import run | ||
|
||
|
||
def test_step_count(): | ||
flow = StepCounterFlow | ||
data = run( | ||
flow, | ||
args=( | ||
"run", | ||
"--with", | ||
"step_counter", | ||
), | ||
) | ||
assert data == { | ||
"a": 111, | ||
"b": 222, | ||
"checked": True, | ||
"step_count": 5, | ||
} |