From 32e12cf72af189ee28499a338ffdceab2c5fbdfc Mon Sep 17 00:00:00 2001 From: Gabriel Luiz Freitas Almeida Date: Mon, 1 Jul 2024 19:25:56 -0300 Subject: [PATCH] refactor: move langflow api tests into integration tests (#2469) --- tests/integration/langflow.py | 88 +++++++++++++++++++++++++++++ tests/test_endpoints.py | 101 ---------------------------------- tests/unit/test_loading.py | 15 +---- 3 files changed, 90 insertions(+), 114 deletions(-) create mode 100644 tests/integration/langflow.py diff --git a/tests/integration/langflow.py b/tests/integration/langflow.py new file mode 100644 index 000000000000..8b83bc1ca3f0 --- /dev/null +++ b/tests/integration/langflow.py @@ -0,0 +1,88 @@ +from uuid import uuid4 + +import pytest +from fastapi import status +from fastapi.testclient import TestClient + +from langflow.graph.schema import RunOutputs +from langflow.initial_setup.setup import load_starter_projects +from langflow.load import run_flow_from_json + + +@pytest.mark.api_key_required +def test_run_flow_with_caching_success(client: TestClient, starter_project, created_api_key): + flow_id = starter_project["id"] + headers = {"x-api-key": created_api_key.api_key} + payload = { + "input_value": "value1", + "input_type": "text", + "output_type": "text", + "tweaks": {"parameter_name": "value"}, + "stream": False, + } + response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) + assert response.status_code == status.HTTP_200_OK + data = response.json() + assert "outputs" in data + assert "session_id" in data + + +@pytest.mark.api_key_required +def test_run_flow_with_caching_invalid_flow_id(client: TestClient, created_api_key): + invalid_flow_id = uuid4() + headers = {"x-api-key": created_api_key.api_key} + payload = {"input_value": "", "input_type": "text", "output_type": "text", "tweaks": {}, "stream": False} + response = client.post(f"/api/v1/run/{invalid_flow_id}", json=payload, headers=headers) + assert response.status_code == status.HTTP_404_NOT_FOUND + data = response.json() + assert "detail" in data + assert f"Flow identifier {invalid_flow_id} not found" in data["detail"] + + +@pytest.mark.api_key_required +def test_run_flow_with_caching_invalid_input_format(client: TestClient, starter_project, created_api_key): + flow_id = starter_project["id"] + headers = {"x-api-key": created_api_key.api_key} + payload = {"input_value": {"key": "value"}, "input_type": "text", "output_type": "text", "tweaks": {}} + response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) + assert response.status_code == status.HTTP_422_UNPROCESSABLE_ENTITY + + +@pytest.mark.api_key_required +def test_run_flow_with_invalid_tweaks(client, starter_project, created_api_key): + headers = {"x-api-key": created_api_key.api_key} + flow_id = starter_project["id"] + payload = { + "input_value": "value1", + "input_type": "text", + "output_type": "text", + "tweaks": {"invalid_tweak": "value"}, + } + response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) + assert response.status_code == status.HTTP_200_OK + + +@pytest.mark.api_key_required +def test_run_with_inputs_and_outputs(client, starter_project, created_api_key): + headers = {"x-api-key": created_api_key.api_key} + flow_id = starter_project["id"] + payload = { + "input_value": "value1", + "input_type": "text", + "output_type": "text", + "tweaks": {"parameter_name": "value"}, + "stream": False, + } + response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) + assert response.status_code == status.HTTP_200_OK, response.text + + +@pytest.mark.noclient +@pytest.mark.api_key_required +def test_run_flow_from_json_object(): + """Test loading a flow from a json file and applying tweaks""" + _, projects = zip(*load_starter_projects()) + project = [project for project in projects if "Basic Prompting" in project["name"]][0] + results = run_flow_from_json(project, input_value="test", fallback_to_env_vars=True) + assert results is not None + assert all(isinstance(result, RunOutputs) for result in results) diff --git a/tests/test_endpoints.py b/tests/test_endpoints.py index 510d4a428ac0..d1c72f938fd7 100644 --- a/tests/test_endpoints.py +++ b/tests/test_endpoints.py @@ -640,22 +640,6 @@ def test_successful_run_with_input_type_any(client, starter_project, created_api ), any_input_outputs -@pytest.mark.api_key_required -def test_run_with_inputs_and_outputs(client, starter_project, created_api_key): - headers = {"x-api-key": created_api_key.api_key} - flow_id = starter_project["id"] - payload = { - "input_value": "value1", - "input_type": "text", - "output_type": "text", - "tweaks": {"parameter_name": "value"}, - "stream": False, - } - response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) - assert response.status_code == status.HTTP_200_OK, response.text - # Validate the response structure and content - - def test_invalid_flow_id(client, created_api_key): headers = {"x-api-key": created_api_key.api_key} flow_id = "invalid-flow-id" @@ -666,88 +650,3 @@ def test_invalid_flow_id(client, created_api_key): response = client.post(f"/api/v1/run/{flow_id}", headers=headers) assert response.status_code == status.HTTP_404_NOT_FOUND, response.text # Check if the error detail is as expected - - -@pytest.mark.api_key_required -def test_run_flow_with_caching_success(client: TestClient, starter_project, created_api_key): - flow_id = starter_project["id"] - headers = {"x-api-key": created_api_key.api_key} - payload = { - "input_value": "value1", - "input_type": "text", - "output_type": "text", - "tweaks": {"parameter_name": "value"}, - "stream": False, - } - response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) - assert response.status_code == status.HTTP_200_OK - data = response.json() - assert "outputs" in data - assert "session_id" in data - - -@pytest.mark.api_key_required -def test_run_flow_with_caching_invalid_flow_id(client: TestClient, created_api_key): - invalid_flow_id = uuid4() - headers = {"x-api-key": created_api_key.api_key} - payload = {"input_value": "", "input_type": "text", "output_type": "text", "tweaks": {}, "stream": False} - response = client.post(f"/api/v1/run/{invalid_flow_id}", json=payload, headers=headers) - assert response.status_code == status.HTTP_404_NOT_FOUND - data = response.json() - assert "detail" in data - assert f"Flow identifier {invalid_flow_id} not found" in data["detail"] - - -@pytest.mark.api_key_required -def test_run_flow_with_caching_invalid_input_format(client: TestClient, starter_project, created_api_key): - flow_id = starter_project["id"] - headers = {"x-api-key": created_api_key.api_key} - payload = {"input_value": {"key": "value"}, "input_type": "text", "output_type": "text", "tweaks": {}} - response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) - assert response.status_code == status.HTTP_422_UNPROCESSABLE_ENTITY - - -# @pytest.mark.api_key_required -# def test_run_flow_with_session_id(client, starter_project, created_api_key): -# headers = {"x-api-key": created_api_key.api_key} -# flow_id = starter_project["id"] -# payload = { -# "input_value": "value1", -# "input_type": "text", -# "output_type": "text", -# "session_id": "test-session-id", -# } -# response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) -# assert response.status_code == status.HTTP_404_NOT_FOUND -# data = response.json() -# assert {"detail": "Session test-session-id not found"} == data - - -# def test_run_flow_with_invalid_session_id(client, starter_project, created_api_key): -# headers = {"x-api-key": created_api_key.api_key} -# flow_id = starter_project["id"] -# payload = { -# "input_value": "value1", -# "input_type": "text", -# "output_type": "text", -# "session_id": "invalid-session-id", -# } -# response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) -# assert response.status_code == status.HTTP_404_NOT_FOUND -# data = response.json() -# assert "detail" in data -# assert f"Session {payload['session_id']} not found" in data["detail"] - - -@pytest.mark.api_key_required -def test_run_flow_with_invalid_tweaks(client, starter_project, created_api_key): - headers = {"x-api-key": created_api_key.api_key} - flow_id = starter_project["id"] - payload = { - "input_value": "value1", - "input_type": "text", - "output_type": "text", - "tweaks": {"invalid_tweak": "value"}, - } - response = client.post(f"/api/v1/run/{flow_id}", json=payload, headers=headers) - assert response.status_code == status.HTTP_200_OK diff --git a/tests/unit/test_loading.py b/tests/unit/test_loading.py index a3138f22c0f1..acaf0a61d469 100644 --- a/tests/unit/test_loading.py +++ b/tests/unit/test_loading.py @@ -1,8 +1,8 @@ import pytest + from langflow.graph import Graph -from langflow.graph.schema import RunOutputs from langflow.initial_setup.setup import load_starter_projects -from langflow.load import load_flow_from_json, run_flow_from_json +from langflow.load import load_flow_from_json @pytest.mark.noclient @@ -30,14 +30,3 @@ def test_load_flow_from_json_object(): loaded = load_flow_from_json(project) assert loaded is not None assert isinstance(loaded, Graph) - - -@pytest.mark.noclient -@pytest.mark.api_key_required -def test_run_flow_from_json_object(): - """Test loading a flow from a json file and applying tweaks""" - _, projects = zip(*load_starter_projects()) - project = [project for project in projects if "Basic Prompting" in project["name"]][0] - results = run_flow_from_json(project, input_value="test", fallback_to_env_vars=True) - assert results is not None - assert all(isinstance(result, RunOutputs) for result in results)