mirror of
https://github.com/hwchase17/langchain
synced 2024-11-06 03:20:49 +00:00
1e80113ac9
The timeout function comes in handy when you want to kill longrunning queries. The value sanitization removes all lists that are larger than 128 elements. The idea here is to remove embedding properties from results.
33 lines
1.3 KiB
Python
33 lines
1.3 KiB
Python
from langchain_community.graphs.neo4j_graph import value_sanitize
|
|
|
|
|
|
def test_value_sanitize_with_small_list():
|
|
small_list = list(range(15)) # list size > LIST_LIMIT
|
|
input_dict = {"key1": "value1", "small_list": small_list}
|
|
expected_output = {"key1": "value1", "small_list": small_list}
|
|
assert value_sanitize(input_dict) == expected_output
|
|
|
|
|
|
def test_value_sanitize_with_oversized_list():
|
|
oversized_list = list(range(150)) # list size > LIST_LIMIT
|
|
input_dict = {"key1": "value1", "oversized_list": oversized_list}
|
|
expected_output = {
|
|
"key1": "value1"
|
|
# oversized_list should not be included
|
|
}
|
|
assert value_sanitize(input_dict) == expected_output
|
|
|
|
|
|
def test_value_sanitize_with_nested_oversized_list():
|
|
oversized_list = list(range(150)) # list size > LIST_LIMIT
|
|
input_dict = {"key1": "value1", "oversized_list": {"key": oversized_list}}
|
|
expected_output = {"key1": "value1", "oversized_list": {}}
|
|
assert value_sanitize(input_dict) == expected_output
|
|
|
|
|
|
def test_value_sanitize_with_dict_in_list():
|
|
oversized_list = list(range(150)) # list size > LIST_LIMIT
|
|
input_dict = {"key1": "value1", "oversized_list": [1, 2, {"key": oversized_list}]}
|
|
expected_output = {"key1": "value1", "oversized_list": [1, 2, {}]}
|
|
assert value_sanitize(input_dict) == expected_output
|