From 49ce4db646e956a009be53decabca71eb07dab28 Mon Sep 17 00:00:00 2001 From: Kye Date: Fri, 22 Dec 2023 23:01:23 -0500 Subject: [PATCH] [CLEANUP] [WeaviateDB] --- scripts/delete_pycache.sh | 4 + swarms/memory/__init__.py | 7 +- swarms/memory/weaviate_db.py | 2 +- tests/memory/test_weaviate.py | 2 +- tests/models/test_auto_temp.py | 83 -------------- tests/models/test_hf.py | 28 ++++- tests/utils/test_metrics_decorator.py | 63 ----------- tests/utils/test_phoenix_handler.py | 150 -------------------------- 8 files changed, 37 insertions(+), 302 deletions(-) create mode 100644 scripts/delete_pycache.sh delete mode 100644 tests/models/test_auto_temp.py delete mode 100644 tests/utils/test_metrics_decorator.py delete mode 100644 tests/utils/test_phoenix_handler.py diff --git a/scripts/delete_pycache.sh b/scripts/delete_pycache.sh new file mode 100644 index 00000000..db11f239 --- /dev/null +++ b/scripts/delete_pycache.sh @@ -0,0 +1,4 @@ +#!/bin/bash + +# Find all __pycache__ directories and delete them +find . -type d -name "__pycache__" -exec rm -rf {} + \ No newline at end of file diff --git a/swarms/memory/__init__.py b/swarms/memory/__init__.py index de056f04..a63a9553 100644 --- a/swarms/memory/__init__.py +++ b/swarms/memory/__init__.py @@ -3,4 +3,9 @@ from swarms.memory.short_term_memory import ShortTermMemory from swarms.memory.sqlite import SQLiteDB from swarms.memory.weaviate_db import WeaviateDB -__all__ = ["VectorDatabase", "ShortTermMemory", "SQLiteDB", "WeaviateDB"] +__all__ = [ + "VectorDatabase", + "ShortTermMemory", + "SQLiteDB", + "WeaviateDB", +] diff --git a/swarms/memory/weaviate_db.py b/swarms/memory/weaviate_db.py index f5d3771f..a6d0c4ab 100644 --- a/swarms/memory/weaviate_db.py +++ b/swarms/memory/weaviate_db.py @@ -11,6 +11,7 @@ try: except ImportError as error: print("pip install weaviate-client") + class WeaviateDB(VectorDatabase): """ @@ -179,4 +180,3 @@ class WeaviateDB(VectorDatabase): except Exception as error: print(f"Error deleting object: {error}") raise - diff --git a/tests/memory/test_weaviate.py b/tests/memory/test_weaviate.py index edd99b3a..f9e61c8f 100644 --- a/tests/memory/test_weaviate.py +++ b/tests/memory/test_weaviate.py @@ -1,6 +1,6 @@ import pytest from unittest.mock import Mock, patch -from swarms.memory.weaviate_db import WeaviateDB +from swarms.memory import WeaviateDB # Define fixture for a WeaviateDB instance with mocked methods diff --git a/tests/models/test_auto_temp.py b/tests/models/test_auto_temp.py deleted file mode 100644 index 7937d0dc..00000000 --- a/tests/models/test_auto_temp.py +++ /dev/null @@ -1,83 +0,0 @@ -import os -from concurrent.futures import ThreadPoolExecutor -from unittest.mock import patch - -import pytest -from dotenv import load_dotenv - -from swarms.models.autotemp import AutoTempAgent - -api_key = os.getenv("OPENAI_API_KEY") - -load_dotenv() - - -@pytest.fixture -def auto_temp_agent(): - return AutoTempAgent(api_key=api_key) - - -def test_initialization(auto_temp_agent): - assert isinstance(auto_temp_agent, AutoTempAgent) - assert auto_temp_agent.auto_select is True - assert auto_temp_agent.max_workers == 6 - assert auto_temp_agent.temperature == 0.5 - assert auto_temp_agent.alt_temps == [0.4, 0.6, 0.8, 1.0, 1.2, 1.4] - - -def test_evaluate_output(auto_temp_agent): - output = "This is a test output." - with patch("swarms.models.OpenAIChat") as MockOpenAIChat: - mock_instance = MockOpenAIChat.return_value - mock_instance.return_value = "Score: 95.5" - score = auto_temp_agent.evaluate_output(output) - assert score == 95.5 - mock_instance.assert_called_once() - - -def test_run_auto_select(auto_temp_agent): - task = "Generate a blog post." - temperature_string = "0.4,0.6,0.8,1.0,1.2,1.4" - result = auto_temp_agent.run(task, temperature_string) - assert "Best AutoTemp Output" in result - assert "Temp" in result - assert "Score" in result - - -def test_run_no_scores(auto_temp_agent): - task = "Invalid task." - temperature_string = "0.4,0.6,0.8,1.0,1.2,1.4" - with ThreadPoolExecutor( - max_workers=auto_temp_agent.max_workers - ) as executor: - with patch.object( - executor, - "submit", - side_effect=[None, None, None, None, None, None], - ): - result = auto_temp_agent.run(task, temperature_string) - assert result == "No valid outputs generated." - - -def test_run_manual_select(auto_temp_agent): - auto_temp_agent.auto_select = False - task = "Generate a blog post." - temperature_string = "0.4,0.6,0.8,1.0,1.2,1.4" - result = auto_temp_agent.run(task, temperature_string) - assert "Best AutoTemp Output" not in result - assert "Temp" in result - assert "Score" in result - - -def test_failed_initialization(): - with pytest.raises(Exception): - AutoTempAgent() - - -def test_failed_evaluate_output(auto_temp_agent): - output = "This is a test output." - with patch("swarms.models.OpenAIChat") as MockOpenAIChat: - mock_instance = MockOpenAIChat.return_value - mock_instance.return_value = "Invalid score text" - score = auto_temp_agent.evaluate_output(output) - assert score == 0.0 diff --git a/tests/models/test_hf.py b/tests/models/test_hf.py index f94e915a..3a66f045 100644 --- a/tests/models/test_hf.py +++ b/tests/models/test_hf.py @@ -102,38 +102,47 @@ def test_llm_set_max_length(llm_instance): llm_instance.set_max_length(new_max_length) assert llm_instance.max_length == new_max_length + # Test for setting verbose def test_llm_set_verbose(llm_instance): llm_instance.set_verbose(True) assert llm_instance.verbose is True + # Test for setting distributed def test_llm_set_distributed(llm_instance): llm_instance.set_distributed(True) assert llm_instance.distributed is True + # Test for setting decoding def test_llm_set_decoding(llm_instance): llm_instance.set_decoding(True) assert llm_instance.decoding is True + # Test for setting max_workers def test_llm_set_max_workers(llm_instance): new_max_workers = 10 llm_instance.set_max_workers(new_max_workers) assert llm_instance.max_workers == new_max_workers + # Test for setting repitition_penalty def test_llm_set_repitition_penalty(llm_instance): new_repitition_penalty = 1.5 llm_instance.set_repitition_penalty(new_repitition_penalty) assert llm_instance.repitition_penalty == new_repitition_penalty + # Test for setting no_repeat_ngram_size def test_llm_set_no_repeat_ngram_size(llm_instance): new_no_repeat_ngram_size = 6 llm_instance.set_no_repeat_ngram_size(new_no_repeat_ngram_size) - assert llm_instance.no_repeat_ngram_size == new_no_repeat_ngram_size + assert ( + llm_instance.no_repeat_ngram_size == new_no_repeat_ngram_size + ) + # Test for setting temperature def test_llm_set_temperature(llm_instance): @@ -141,23 +150,27 @@ def test_llm_set_temperature(llm_instance): llm_instance.set_temperature(new_temperature) assert llm_instance.temperature == new_temperature + # Test for setting top_k def test_llm_set_top_k(llm_instance): new_top_k = 50 llm_instance.set_top_k(new_top_k) assert llm_instance.top_k == new_top_k + # Test for setting top_p def test_llm_set_top_p(llm_instance): new_top_p = 0.9 llm_instance.set_top_p(new_top_p) assert llm_instance.top_p == new_top_p + # Test for setting quantize def test_llm_set_quantize(llm_instance): llm_instance.set_quantize(True) assert llm_instance.quantize is True + # Test for setting quantization_config def test_llm_set_quantization_config(llm_instance): new_quantization_config = { @@ -169,19 +182,24 @@ def test_llm_set_quantization_config(llm_instance): llm_instance.set_quantization_config(new_quantization_config) assert llm_instance.quantization_config == new_quantization_config + # Test for setting model_id def test_llm_set_model_id(llm_instance): new_model_id = "EleutherAI/gpt-neo-2.7B" llm_instance.set_model_id(new_model_id) assert llm_instance.model_id == new_model_id + # Test for setting model -@patch("swarms.models.huggingface.AutoModelForCausalLM.from_pretrained") +@patch( + "swarms.models.huggingface.AutoModelForCausalLM.from_pretrained" +) def test_llm_set_model(mock_model, llm_instance): mock_model.return_value = "mocked model" llm_instance.set_model(mock_model) assert llm_instance.model == "mocked model" + # Test for setting tokenizer @patch("swarms.models.huggingface.AutoTokenizer.from_pretrained") def test_llm_set_tokenizer(mock_tokenizer, llm_instance): @@ -189,27 +207,31 @@ def test_llm_set_tokenizer(mock_tokenizer, llm_instance): llm_instance.set_tokenizer(mock_tokenizer) assert llm_instance.tokenizer == "mocked tokenizer" + # Test for setting logger def test_llm_set_logger(llm_instance): new_logger = logging.getLogger("test_logger") llm_instance.set_logger(new_logger) assert llm_instance.logger == new_logger + # Test for saving model @patch("torch.save") def test_llm_save_model(mock_save, llm_instance): llm_instance.save_model("path/to/save") mock_save.assert_called_once() + # Test for print_dashboard @patch("builtins.print") def test_llm_print_dashboard(mock_print, llm_instance): llm_instance.print_dashboard("test task") mock_print.assert_called() + # Test for __call__ method @patch("swarms.models.huggingface.HuggingfaceLLM.run") def test_llm_call(mock_run, llm_instance): mock_run.return_value = "mocked output" result = llm_instance("test task") - assert result == "mocked output" \ No newline at end of file + assert result == "mocked output" diff --git a/tests/utils/test_metrics_decorator.py b/tests/utils/test_metrics_decorator.py deleted file mode 100644 index 126c6465..00000000 --- a/tests/utils/test_metrics_decorator.py +++ /dev/null @@ -1,63 +0,0 @@ -import time -from swarms.utils.llm_metrics_decorator import metrics_decorator - - -def test_metrics_decorator(): - @metrics_decorator - def test_func(): - time.sleep(0.1) # simulate some work - return list(range(100)) # return a list of 100 tokens - - result = test_func() - lines = result.strip().split("\n") - - # Check that the decorator returns 3 lines of output - assert len(lines) == 3 - - # Check that the Time to First Token is less than or equal to the Generation Latency - time_to_first_token = float(lines[0].split(": ")[1]) - generation_latency = float(lines[1].split(": ")[1]) - assert time_to_first_token <= generation_latency - - # Check that the Throughput is approximately equal to the number of tokens divided by the Generation Latency - throughput = float(lines[2].split(": ")[1]) - assert ( - abs(throughput - 100 / generation_latency) < 0.01 - ) # allow for a small amount of error - - -def test_metrics_decorator_1_token(): - @metrics_decorator - def test_func(): - time.sleep(0.1) # simulate some work - return [0] # return a list of 1 token - - result = test_func() - lines = result.strip().split("\n") - assert len(lines) == 3 - time_to_first_token = float(lines[0].split(": ")[1]) - generation_latency = float(lines[1].split(": ")[1]) - assert time_to_first_token <= generation_latency - throughput = float(lines[2].split(": ")[1]) - assert abs(throughput - 1 / generation_latency) < 0.01 - - -# Repeat the test with different numbers of tokens and different amounts of work -for i in range(2, 17): - - def test_func(): - @metrics_decorator - def test_func(): - time.sleep(0.01 * i) # simulate some work - return list(range(i)) # return a list of i tokens - - result = test_func() - lines = result.strip().split("\n") - assert len(lines) == 3 - time_to_first_token = float(lines[0].split(": ")[1]) - generation_latency = float(lines[1].split(": ")[1]) - assert time_to_first_token <= generation_latency - throughput = float(lines[2].split(": ")[1]) - assert abs(throughput - i / generation_latency) < 0.01 - - globals()[f"test_metrics_decorator_{i}_tokens"] = test_func diff --git a/tests/utils/test_phoenix_handler.py b/tests/utils/test_phoenix_handler.py deleted file mode 100644 index a7dc8898..00000000 --- a/tests/utils/test_phoenix_handler.py +++ /dev/null @@ -1,150 +0,0 @@ -# Import necessary modules and functions for testing -import subprocess -import sys - -import pytest - -# Try importing phoenix and handle exceptions -try: - import phoenix as px -except Exception as error: - print(f"Error importing phoenix: {error}") - print("Please install phoenix: pip install phoenix") - subprocess.run( - [sys.executable, "-m", "pip", "install", "arize-mlflow"] - ) - -# Import the code to be tested -from swarms.utils.phoenix_handler import phoenix_trace_decorator - - -# Define a fixture for Phoenix session -@pytest.fixture(scope="function") -def phoenix_session(): - session = px.active_session() or px.launch_app() - yield session - session.stop() - - -# Define test cases for the phoenix_trace_decorator function -def test_phoenix_trace_decorator_documentation(): - """Test if phoenix_trace_decorator has a docstring.""" - assert phoenix_trace_decorator.__doc__ is not None - - -def test_phoenix_trace_decorator_functionality( - capsys, phoenix_session -): - """Test the functionality of phoenix_trace_decorator.""" - - # Define a function to be decorated - @phoenix_trace_decorator("This is a test function.") - def test_function(): - print("Hello, Phoenix!") - - # Execute the decorated function - test_function() - - # Capture the printed output - captured = capsys.readouterr() - assert captured.out == "Hello, Phoenix!\n" - - -def test_phoenix_trace_decorator_exception_handling(phoenix_session): - """Test if phoenix_trace_decorator handles exceptions correctly.""" - - # Define a function that raises an exception - @phoenix_trace_decorator("This function raises an exception.") - def exception_function(): - raise ValueError("An error occurred.") - - # Execute the decorated function - with pytest.raises(ValueError): - exception_function() - - # Check if the exception was traced by Phoenix - traces = phoenix_session.get_traces() - assert len(traces) == 1 - assert traces[0].get("error") is not None - assert traces[0].get("error_info") is not None - - -# Define test cases for phoenix_trace_decorator -def test_phoenix_trace_decorator_docstring(): - """Test if phoenix_trace_decorator's inner function has a docstring.""" - - @phoenix_trace_decorator("This is a test function.") - def test_function(): - """Test function docstring.""" - pass - - assert test_function.__doc__ is not None - - -def test_phoenix_trace_decorator_functionality_with_params( - capsys, phoenix_session -): - """Test the functionality of phoenix_trace_decorator with parameters.""" - - # Define a function with parameters to be decorated - @phoenix_trace_decorator("This function takes parameters.") - def param_function(a, b): - result = a + b - print(f"Result: {result}") - - # Execute the decorated function with parameters - param_function(2, 3) - - # Capture the printed output - captured = capsys.readouterr() - assert captured.out == "Result: 5\n" - - -def test_phoenix_trace_decorator_nested_calls( - capsys, phoenix_session -): - """Test nested calls of phoenix_trace_decorator.""" - - # Define a nested function with decorators - @phoenix_trace_decorator("Outer function") - def outer_function(): - print("Outer function") - - @phoenix_trace_decorator("Inner function") - def inner_function(): - print("Inner function") - - inner_function() - - # Execute the decorated functions - outer_function() - - # Capture the printed output - captured = capsys.readouterr() - assert "Outer function" in captured.out - assert "Inner function" in captured.out - - -def test_phoenix_trace_decorator_nested_exception_handling( - phoenix_session, -): - """Test exception handling with nested phoenix_trace_decorators.""" - - # Define a function with nested decorators and an exception - @phoenix_trace_decorator("Outer function") - def outer_function(): - @phoenix_trace_decorator("Inner function") - def inner_function(): - raise ValueError("Inner error") - - inner_function() - - # Execute the decorated functions - with pytest.raises(ValueError): - outer_function() - - # Check if both exceptions were traced by Phoenix - traces = phoenix_session.get_traces() - assert len(traces) == 2 - assert "Outer function" in traces[0].get("error_info") - assert "Inner function" in traces[1].get("error_info")