Пример #1
0
def test_flow_view_from_flow_id_where_clause(monkeypatch):
    post = MagicMock(return_value={"data": {"flow": [FLOW_DATA_1]}})
    monkeypatch.setattr("prefect.client.client.Client.post", post)

    FlowView.from_flow_id(flow_id="id-1")

    assert ('flow(where: { id: { _eq: "id-1" } })'
            in post.call_args[1]["params"]["query"])
Пример #2
0
def test_flow_view_query_for_flow_uses_where_in_query(monkeypatch):
    post = MagicMock(return_value={"data": {"flow": [FLOW_DATA_1]}})
    monkeypatch.setattr("prefect.client.client.Client.post", post)

    FlowView._query_for_flow(where={"foo": {"_eq": "bar"}})

    assert ('flow(where: { foo: { _eq: "bar" } })'
            in post.call_args[1]["params"]["query"])
Пример #3
0
def test_flow_view_from_flow_group_id_where_and_order_clauses(monkeypatch):
    post = MagicMock(return_value={"data": {"flow": [FLOW_DATA_1]}})
    monkeypatch.setattr("prefect.client.client.Client.post", post)

    FlowView.from_flow_group_id(flow_group_id="flow-group-id-1")

    assert ('where: { flow_group_id: { _eq: "flow-group-id-1" } }'
            in post.call_args[1]["params"]["query"])
    assert "order_by: { created: desc }" in post.call_args[1]["params"][
        "query"]
Пример #4
0
def test_flow_view_from_flow_name_where_and_order_clauses(monkeypatch):
    post = MagicMock(return_value={"data": {"flow": [FLOW_DATA_1]}})
    monkeypatch.setattr("prefect.client.client.Client.post", post)

    FlowView.from_flow_name(flow_name="name-1")

    assert ('where: { name: { _eq: "name-1" }, archived: { _eq: false } }'
            in post.call_args[1]["params"]["query"])
    assert "order_by: { created: desc }" in post.call_args[1]["params"][
        "query"]
Пример #5
0
def test_flow_view_handles_extra_and_missing_fields_in_serialized_flows():
    flow_data = FLOW_DATA_1.copy()
    serialized = flow_data["serialized_flow"]
    serialized["extra_field"] = "foo"  # extra data
    serialized.pop("parameters")  # missing data
    flow_view = FlowView._from_flow_data(flow_data)
    assert isinstance(flow_view.flow, Flow)
Пример #6
0
def test_flow_view_query_for_flow_includes_all_required_data(monkeypatch):
    graphql = MagicMock(return_value={"data": {"flow": [FLOW_DATA_1]}})
    monkeypatch.setattr("prefect.client.client.Client.graphql", graphql)

    FlowView._query_for_flow(where={})

    query_dict = graphql.call_args[0][0]
    selection_set = query_dict["query"]["flow(where: {})"]
    assert selection_set == {
        "id": True,
        "settings": True,
        "run_config": True,
        "serialized_flow": True,
        "flow_group": {"labels"},
        "name": True,
        "archived": True,
        "project": {"name"},
        "core_version": True,
        "storage": True,
    }
Пример #7
0
def test_flow_view_from_returns_instance(patch_post, from_method):
    patch_post({"data": {"flow": [FLOW_DATA_1]}})

    if from_method == "flow_id":
        flow = FlowView.from_flow_id("id-1")
    elif from_method == "flow_data":
        # Note the post patch will not be used since there is no query here
        flow = FlowView._from_flow_data(FLOW_DATA_1)

    assert flow.flow_id == "id-1"
    assert flow.serialized_flow == FLOW_DATA_1["serialized_flow"]
    assert flow.flow == Flow("flow-1")
    assert flow.name == "name-1"
    assert flow.settings == {"key-1": "value-1"}
    assert flow.flow_group_labels == ["label-1"]
    assert isinstance(flow.run_config, UniversalRun)
    assert flow.run_config.env == {"ENV-1": "VAL-1"}
    assert flow.archived is False
    assert flow.project_name == "project-1"
    assert flow.core_version == "0.0.0"
    assert isinstance(flow.storage, Local)
    assert flow.storage.stored_as_script is True
    assert flow.storage.path == "fake-path-1.py"
Пример #8
0
from prefect.cli.run import load_json_key_values, run

FAILURE_LOCAL_STDOUT = """
Retrieving local flow... Done
Running flow locally...
Flow run failed!
""".lstrip()

TEST_FLOW_VIEW = FlowView(
    flow_id="flow-id",
    name="flow-name",
    settings={"key": "value"},
    run_config=UniversalRun(env={"ENV": "VAL"}),
    flow=Flow("flow"),
    serialized_flow=Flow("flow").serialize(),
    archived=False,
    project_name="project",
    flow_group_labels=["label"],
    core_version="0.0.0",
    storage=LocalStorage(stored_as_script=True, path="fake-path.py"),
)

SUCCESS_FLOW_RUN_VIEW = FlowRunView(
    flow_run_id="flow-run-id",
    name="flow-run-name",
    flow_id="flow-id",
    state=Success(message="state-1"),
    states=[],
    parameters={"param": "value"},
    context={"foo": "bar"},
Пример #9
0
def test_flow_view_query_for_flow_unpacks_result_singleton(patch_post):
    patch_post({"data": {"flow": [1]}})

    assert FlowView._query_for_flow(where={}) == 1
Пример #10
0
def test_flow_view_query_for_flow_errors_on_multiple_flows(patch_post):
    patch_post({"data": {"flow": [1, 2]}})

    with pytest.raises(ValueError, match=r"multiple \(2\) flows"):
        FlowView._query_for_flow(where={})
Пример #11
0
def test_flow_view_query_for_flow_raises_when_not_found(patch_post):
    patch_post({"data": {"flow": []}})

    with pytest.raises(ValueError,
                       match="No results found while querying for flows"):
        FlowView._query_for_flow(where={})
Пример #12
0
def test_flow_view_query_for_flow_raises_bad_responses(patch_post):
    patch_post({})

    with pytest.raises(ValueError,
                       match="bad result while querying for flows"):
        FlowView._query_for_flow(where={})
Пример #13
0
def test_flow_view_handles_null_run_config():
    flow_data = FLOW_DATA_1.copy()
    flow_data["run_config"] = None
    flow_view = FlowView._from_flow_data(flow_data)
    assert flow_view.run_config is None