mirror of
https://github.com/langgenius/dify.git
synced 2026-04-29 04:26:30 +08:00
test: tool
This commit is contained in:
parent
d3385a2715
commit
513a8655b1
@ -315,8 +315,9 @@ class ToolManager:
|
|||||||
|
|
||||||
for parameter in parameters:
|
for parameter in parameters:
|
||||||
# save tool parameter to tool entity memory
|
# save tool parameter to tool entity memory
|
||||||
value = ToolManager._init_runtime_parameter(parameter, workflow_tool.tool_configurations)
|
if parameter.form == ToolParameter.ToolParameterForm.FORM:
|
||||||
runtime_parameters[parameter.name] = value
|
value = ToolManager._init_runtime_parameter(parameter, workflow_tool.tool_configurations)
|
||||||
|
runtime_parameters[parameter.name] = value
|
||||||
|
|
||||||
# decrypt runtime parameters
|
# decrypt runtime parameters
|
||||||
encryption_manager = ToolParameterConfigurationManager(
|
encryption_manager = ToolParameterConfigurationManager(
|
||||||
@ -325,7 +326,9 @@ class ToolManager:
|
|||||||
provider_name=workflow_tool.provider_id,
|
provider_name=workflow_tool.provider_id,
|
||||||
provider_type=workflow_tool.provider_type,
|
provider_type=workflow_tool.provider_type,
|
||||||
)
|
)
|
||||||
runtime_parameters = encryption_manager.decrypt_tool_parameters(runtime_parameters)
|
|
||||||
|
if runtime_parameters:
|
||||||
|
runtime_parameters = encryption_manager.decrypt_tool_parameters(runtime_parameters)
|
||||||
|
|
||||||
tool_entity.runtime.runtime_parameters.update(runtime_parameters)
|
tool_entity.runtime.runtime_parameters.update(runtime_parameters)
|
||||||
return tool_entity
|
return tool_entity
|
||||||
|
|||||||
@ -29,7 +29,6 @@ class ToolNode(BaseNode):
|
|||||||
|
|
||||||
# get parameters
|
# get parameters
|
||||||
parameters = self._generate_parameters(variable_pool, node_data)
|
parameters = self._generate_parameters(variable_pool, node_data)
|
||||||
|
|
||||||
# get tool runtime
|
# get tool runtime
|
||||||
try:
|
try:
|
||||||
tool_runtime = ToolManager.get_workflow_tool_runtime(self.tenant_id, node_data, None)
|
tool_runtime = ToolManager.get_workflow_tool_runtime(self.tenant_id, node_data, None)
|
||||||
@ -41,7 +40,6 @@ class ToolNode(BaseNode):
|
|||||||
)
|
)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# TODO: user_id
|
|
||||||
messages = tool_runtime.invoke(self.user_id, parameters)
|
messages = tool_runtime.invoke(self.user_id, parameters)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return NodeRunResult(
|
return NodeRunResult(
|
||||||
@ -68,7 +66,7 @@ class ToolNode(BaseNode):
|
|||||||
return {
|
return {
|
||||||
k.variable:
|
k.variable:
|
||||||
k.value if k.variable_type == 'static' else
|
k.value if k.variable_type == 'static' else
|
||||||
variable_pool.get_variable_value(k.value) if k.variable_type == 'selector' else ''
|
variable_pool.get_variable_value(k.value_selector) if k.variable_type == 'selector' else ''
|
||||||
for k in node_data.tool_parameters
|
for k in node_data.tool_parameters
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -77,7 +75,12 @@ class ToolNode(BaseNode):
|
|||||||
Convert ToolInvokeMessages into tuple[plain_text, files]
|
Convert ToolInvokeMessages into tuple[plain_text, files]
|
||||||
"""
|
"""
|
||||||
# transform message and handle file storage
|
# transform message and handle file storage
|
||||||
messages = ToolFileMessageTransformer.transform_tool_invoke_messages(messages)
|
messages = ToolFileMessageTransformer.transform_tool_invoke_messages(
|
||||||
|
messages=messages,
|
||||||
|
user_id=self.user_id,
|
||||||
|
tenant_id=self.tenant_id,
|
||||||
|
conversation_id='',
|
||||||
|
)
|
||||||
# extract plain text and files
|
# extract plain text and files
|
||||||
files = self._extract_tool_response_binary(messages)
|
files = self._extract_tool_response_binary(messages)
|
||||||
plain_text = self._extract_tool_response_text(messages)
|
plain_text = self._extract_tool_response_text(messages)
|
||||||
|
|||||||
70
api/tests/integration_tests/workflow/nodes/test_tool.py
Normal file
70
api/tests/integration_tests/workflow/nodes/test_tool.py
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
import pytest
|
||||||
|
from core.app.entities.app_invoke_entities import InvokeFrom
|
||||||
|
|
||||||
|
from core.workflow.entities.variable_pool import VariablePool
|
||||||
|
from core.workflow.nodes.tool.tool_node import ToolNode
|
||||||
|
from models.workflow import WorkflowNodeExecutionStatus
|
||||||
|
|
||||||
|
"""
|
||||||
|
class ToolEntity(BaseModel):
|
||||||
|
provider_id: str
|
||||||
|
provider_type: Literal['builtin', 'api']
|
||||||
|
provider_name: str # redundancy
|
||||||
|
tool_name: str
|
||||||
|
tool_label: str # redundancy
|
||||||
|
tool_configurations: dict[str, ToolParameterValue]
|
||||||
|
|
||||||
|
class ToolNodeData(BaseNodeData, ToolEntity):
|
||||||
|
class ToolInput(VariableSelector):
|
||||||
|
variable_type: Literal['selector', 'static']
|
||||||
|
value: Optional[str]
|
||||||
|
|
||||||
|
@validator('value')
|
||||||
|
def check_value(cls, value, values, **kwargs):
|
||||||
|
if values['variable_type'] == 'static' and value is None:
|
||||||
|
raise ValueError('value is required for static variable')
|
||||||
|
return value
|
||||||
|
|
||||||
|
tool_parameters: list[ToolInput]
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
def test_tool_invoke():
|
||||||
|
pool = VariablePool(system_variables={}, user_inputs={})
|
||||||
|
pool.append_variable(node_id='1', variable_key_list=['123', 'args1'], value='1+1')
|
||||||
|
|
||||||
|
node = ToolNode(
|
||||||
|
tenant_id='1',
|
||||||
|
app_id='1',
|
||||||
|
workflow_id='1',
|
||||||
|
user_id='1',
|
||||||
|
user_from=InvokeFrom.WEB_APP,
|
||||||
|
config={
|
||||||
|
'id': '1',
|
||||||
|
'data': {
|
||||||
|
'title': 'a',
|
||||||
|
'desc': 'a',
|
||||||
|
'provider_id': 'maths',
|
||||||
|
'provider_type': 'builtin',
|
||||||
|
'provider_name': 'maths',
|
||||||
|
'tool_name': 'eval_expression',
|
||||||
|
'tool_label': 'eval_expression',
|
||||||
|
'tool_configurations': {},
|
||||||
|
'tool_parameters': [
|
||||||
|
{
|
||||||
|
'variable': 'expression',
|
||||||
|
'value_selector': ['1', '123', 'args1'],
|
||||||
|
'variable_type': 'selector',
|
||||||
|
'value': None
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
# execute node
|
||||||
|
result = node.run(pool)
|
||||||
|
|
||||||
|
assert result.status == WorkflowNodeExecutionStatus.SUCCEEDED
|
||||||
|
assert '2' in result.outputs['text']
|
||||||
|
assert result.outputs['files'] == []
|
||||||
Loading…
Reference in New Issue
Block a user