feat(api): Explicitly define version method for all BaseNode subclasses (#21443)

This PR addresses issue #21441 by implementing explicit `version` method definitions for all `BaseNode` subclasses to improve code maintainability.

### Changes

Added explicit `version` method definitions for all `BaseNode` subclasses:

- `QuestionClassifierNode`
- `KnowledgeRetrievalNode` 
- `AgentNode`

Added comprehensive test suite to validate:

1. All subclasses of `BaseNode` have explicitly defined `version` method
2. All subclasses have required `_node_type` property
3. The `(node_type, node_version)` combination is unique across all subclasses
This commit is contained in:
QuantumGhost
2025-06-24 20:27:22 +08:00
committed by GitHub
parent f668d89621
commit 501d3b6203
4 changed files with 48 additions and 0 deletions

View File

@@ -0,0 +1,36 @@
from core.workflow.nodes.base.node import BaseNode
from core.workflow.nodes.enums import NodeType
# Ensures that all node classes are imported.
from core.workflow.nodes.node_mapping import NODE_TYPE_CLASSES_MAPPING
_ = NODE_TYPE_CLASSES_MAPPING
def _get_all_subclasses(root: type[BaseNode]) -> list[type[BaseNode]]:
subclasses = []
queue = [root]
while queue:
cls = queue.pop()
subclasses.extend(cls.__subclasses__())
queue.extend(cls.__subclasses__())
return subclasses
def test_ensure_subclasses_of_base_node_has_node_type_and_version_method_defined():
classes = _get_all_subclasses(BaseNode) # type: ignore
type_version_set: set[tuple[NodeType, str]] = set()
for cls in classes:
# Validate that 'version' is directly defined in the class (not inherited) by checking the class's __dict__
assert "version" in cls.__dict__, f"class {cls} should have version method defined (NOT INHERITED.)"
node_type = cls._node_type
node_version = cls.version()
assert isinstance(cls._node_type, NodeType)
assert isinstance(node_version, str)
node_type_and_version = (node_type, node_version)
assert node_type_and_version not in type_version_set
type_version_set.add(node_type_and_version)