You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
276 lines
9.5 KiB
276 lines
9.5 KiB
6 months ago
|
import os
|
||
|
from datetime import datetime
|
||
|
|
||
|
import pytest
|
||
|
|
||
|
from swarms.structs.base_structure import BaseStructure
|
||
|
|
||
|
|
||
|
class TestBaseStructure:
|
||
|
def test_init(self):
|
||
|
base_structure = BaseStructure(
|
||
|
name="TestStructure",
|
||
|
description="Test description",
|
||
|
save_metadata=True,
|
||
|
save_artifact_path="./test_artifacts",
|
||
|
save_metadata_path="./test_metadata",
|
||
|
save_error_path="./test_errors",
|
||
|
)
|
||
|
|
||
|
assert base_structure.name == "TestStructure"
|
||
|
assert base_structure.description == "Test description"
|
||
|
assert base_structure.save_metadata is True
|
||
|
assert base_structure.save_artifact_path == "./test_artifacts"
|
||
|
assert base_structure.save_metadata_path == "./test_metadata"
|
||
|
assert base_structure.save_error_path == "./test_errors"
|
||
|
|
||
|
def test_save_to_file_and_load_from_file(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
file_path = os.path.join(tmp_dir, "test_file.json")
|
||
|
|
||
|
data_to_save = {"key": "value"}
|
||
|
base_structure = BaseStructure()
|
||
|
|
||
|
base_structure.save_to_file(data_to_save, file_path)
|
||
|
loaded_data = base_structure.load_from_file(file_path)
|
||
|
|
||
|
assert loaded_data == data_to_save
|
||
|
|
||
|
def test_save_metadata_and_load_metadata(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_metadata_path=tmp_dir)
|
||
|
|
||
|
metadata = {"name": "Test", "description": "Test metadata"}
|
||
|
base_structure.save_metadata(metadata)
|
||
|
loaded_metadata = base_structure.load_metadata()
|
||
|
|
||
|
assert loaded_metadata == metadata
|
||
|
|
||
|
def test_log_error(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_error_path=tmp_dir)
|
||
|
|
||
|
error_message = "Test error message"
|
||
|
base_structure.log_error(error_message)
|
||
|
|
||
|
log_file = os.path.join(tmp_dir, "TestStructure_errors.log")
|
||
|
with open(log_file) as file:
|
||
|
lines = file.readlines()
|
||
|
assert len(lines) == 1
|
||
|
assert lines[0] == f"{error_message}\n"
|
||
|
|
||
|
def test_save_artifact_and_load_artifact(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_artifact_path=tmp_dir)
|
||
|
|
||
|
artifact = {"key": "value"}
|
||
|
artifact_name = "test_artifact"
|
||
|
base_structure.save_artifact(artifact, artifact_name)
|
||
|
loaded_artifact = base_structure.load_artifact(artifact_name)
|
||
|
|
||
|
assert loaded_artifact == artifact
|
||
|
|
||
|
def test_current_timestamp(self):
|
||
|
base_structure = BaseStructure()
|
||
|
current_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
|
||
|
timestamp = base_structure._current_timestamp()
|
||
|
assert timestamp == current_time
|
||
|
|
||
|
def test_log_event(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_metadata_path=tmp_dir)
|
||
|
|
||
|
event = "Test event"
|
||
|
event_type = "INFO"
|
||
|
base_structure.log_event(event, event_type)
|
||
|
|
||
|
log_file = os.path.join(tmp_dir, "TestStructure_events.log")
|
||
|
with open(log_file) as file:
|
||
|
lines = file.readlines()
|
||
|
assert len(lines) == 1
|
||
|
assert (
|
||
|
lines[0] == f"[{base_structure._current_timestamp()}]"
|
||
|
f" [{event_type}] {event}\n"
|
||
|
)
|
||
|
|
||
|
@pytest.mark.asyncio
|
||
|
async def test_run_async(self):
|
||
|
base_structure = BaseStructure()
|
||
|
|
||
|
async def async_function():
|
||
|
return "Async Test Result"
|
||
|
|
||
|
result = await base_structure.run_async(async_function)
|
||
|
assert result == "Async Test Result"
|
||
|
|
||
|
@pytest.mark.asyncio
|
||
|
async def test_save_metadata_async(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_metadata_path=tmp_dir)
|
||
|
|
||
|
metadata = {"name": "Test", "description": "Test metadata"}
|
||
|
await base_structure.save_metadata_async(metadata)
|
||
|
loaded_metadata = base_structure.load_metadata()
|
||
|
|
||
|
assert loaded_metadata == metadata
|
||
|
|
||
|
@pytest.mark.asyncio
|
||
|
async def test_log_error_async(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_error_path=tmp_dir)
|
||
|
|
||
|
error_message = "Test error message"
|
||
|
await base_structure.log_error_async(error_message)
|
||
|
|
||
|
log_file = os.path.join(tmp_dir, "TestStructure_errors.log")
|
||
|
with open(log_file) as file:
|
||
|
lines = file.readlines()
|
||
|
assert len(lines) == 1
|
||
|
assert lines[0] == f"{error_message}\n"
|
||
|
|
||
|
@pytest.mark.asyncio
|
||
|
async def test_save_artifact_async(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_artifact_path=tmp_dir)
|
||
|
|
||
|
artifact = {"key": "value"}
|
||
|
artifact_name = "test_artifact"
|
||
|
await base_structure.save_artifact_async(artifact, artifact_name)
|
||
|
loaded_artifact = base_structure.load_artifact(artifact_name)
|
||
|
|
||
|
assert loaded_artifact == artifact
|
||
|
|
||
|
@pytest.mark.asyncio
|
||
|
async def test_load_artifact_async(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_artifact_path=tmp_dir)
|
||
|
|
||
|
artifact = {"key": "value"}
|
||
|
artifact_name = "test_artifact"
|
||
|
base_structure.save_artifact(artifact, artifact_name)
|
||
|
loaded_artifact = await base_structure.load_artifact_async(
|
||
|
artifact_name
|
||
|
)
|
||
|
|
||
|
assert loaded_artifact == artifact
|
||
|
|
||
|
@pytest.mark.asyncio
|
||
|
async def test_log_event_async(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure(save_metadata_path=tmp_dir)
|
||
|
|
||
|
event = "Test event"
|
||
|
event_type = "INFO"
|
||
|
await base_structure.log_event_async(event, event_type)
|
||
|
|
||
|
log_file = os.path.join(tmp_dir, "TestStructure_events.log")
|
||
|
with open(log_file) as file:
|
||
|
lines = file.readlines()
|
||
|
assert len(lines) == 1
|
||
|
assert (
|
||
|
lines[0] == f"[{base_structure._current_timestamp()}]"
|
||
|
f" [{event_type}] {event}\n"
|
||
|
)
|
||
|
|
||
|
@pytest.mark.asyncio
|
||
|
async def test_asave_to_file(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
file_path = os.path.join(tmp_dir, "test_file.json")
|
||
|
data_to_save = {"key": "value"}
|
||
|
base_structure = BaseStructure()
|
||
|
|
||
|
await base_structure.asave_to_file(data_to_save, file_path)
|
||
|
loaded_data = base_structure.load_from_file(file_path)
|
||
|
|
||
|
assert loaded_data == data_to_save
|
||
|
|
||
|
@pytest.mark.asyncio
|
||
|
async def test_aload_from_file(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
file_path = os.path.join(tmp_dir, "test_file.json")
|
||
|
data_to_save = {"key": "value"}
|
||
|
base_structure = BaseStructure()
|
||
|
base_structure.save_to_file(data_to_save, file_path)
|
||
|
|
||
|
loaded_data = await base_structure.aload_from_file(file_path)
|
||
|
assert loaded_data == data_to_save
|
||
|
|
||
|
def test_run_in_thread(self):
|
||
|
base_structure = BaseStructure()
|
||
|
result = base_structure.run_in_thread(lambda: "Thread Test Result")
|
||
|
assert result.result() == "Thread Test Result"
|
||
|
|
||
|
def test_save_and_decompress_data(self):
|
||
|
base_structure = BaseStructure()
|
||
|
data = {"key": "value"}
|
||
|
compressed_data = base_structure.compress_data(data)
|
||
|
decompressed_data = base_structure.decompres_data(compressed_data)
|
||
|
assert decompressed_data == data
|
||
|
|
||
|
def test_run_batched(self):
|
||
|
base_structure = BaseStructure()
|
||
|
|
||
|
def run_function(data):
|
||
|
return f"Processed {data}"
|
||
|
|
||
|
batched_data = list(range(10))
|
||
|
result = base_structure.run_batched(
|
||
|
batched_data, batch_size=5, func=run_function
|
||
|
)
|
||
|
|
||
|
expected_result = [f"Processed {data}" for data in batched_data]
|
||
|
assert result == expected_result
|
||
|
|
||
|
def test_load_config(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
config_file = os.path.join(tmp_dir, "config.json")
|
||
|
config_data = {"key": "value"}
|
||
|
base_structure = BaseStructure()
|
||
|
|
||
|
base_structure.save_to_file(config_data, config_file)
|
||
|
loaded_config = base_structure.load_config(config_file)
|
||
|
|
||
|
assert loaded_config == config_data
|
||
|
|
||
|
def test_backup_data(self, tmpdir):
|
||
|
tmp_dir = tmpdir.mkdir("test_dir")
|
||
|
base_structure = BaseStructure()
|
||
|
data_to_backup = {"key": "value"}
|
||
|
base_structure.backup_data(data_to_backup, backup_path=tmp_dir)
|
||
|
backup_files = os.listdir(tmp_dir)
|
||
|
|
||
|
assert len(backup_files) == 1
|
||
|
loaded_data = base_structure.load_from_file(
|
||
|
os.path.join(tmp_dir, backup_files[0])
|
||
|
)
|
||
|
assert loaded_data == data_to_backup
|
||
|
|
||
|
def test_monitor_resources(self):
|
||
|
base_structure = BaseStructure()
|
||
|
base_structure.monitor_resources()
|
||
|
|
||
|
def test_run_with_resources(self):
|
||
|
base_structure = BaseStructure()
|
||
|
|
||
|
def run_function():
|
||
|
base_structure.monitor_resources()
|
||
|
return "Resource Test Result"
|
||
|
|
||
|
result = base_structure.run_with_resources(run_function)
|
||
|
assert result == "Resource Test Result"
|
||
|
|
||
|
def test_run_with_resources_batched(self):
|
||
|
base_structure = BaseStructure()
|
||
|
|
||
|
def run_function(data):
|
||
|
base_structure.monitor_resources()
|
||
|
return f"Processed {data}"
|
||
|
|
||
|
batched_data = list(range(10))
|
||
|
result = base_structure.run_with_resources_batched(
|
||
|
batched_data, batch_size=5, func=run_function
|
||
|
)
|
||
|
|
||
|
expected_result = [f"Processed {data}" for data in batched_data]
|
||
|
assert result == expected_result
|