From 96d8e5cd747ff2dbf12dcfe36d5e72b176f4fa50 Mon Sep 17 00:00:00 2001 From: Alfred Nutile Date: Sun, 4 Aug 2024 15:56:04 -0400 Subject: [PATCH] Ok the controller and orchestrate v2 chat is working but that is the easy part now for the dynamic tools --- Modules/LlmDriver/app/OllamaClient.php | 4 +- .../tests/Feature/LlmDriverClientTest.php | 4 +- .../Orchestration/OrchestrateVersionTwo.php | 4 +- .../Http/Controllers/ChatControllerTest.php | 12 +- .../Http/Controllers/GoogleControllerTest.php | 1 + tests/Feature/Models/MessageTest.php | 12 +- tests/Feature/OrchestrateVersionTwoTest.php | 4 +- .../fixtures/claude_messages_after_remap.json | 31 +++- .../claude_messages_before_remap.json | 30 +++- tests/fixtures/claude_payload.json | 161 +++++++++++++++++- tests/fixtures/ollama_chat_response.json | 18 +- .../orchestrate_messages_first_send.json | 24 +-- 12 files changed, 236 insertions(+), 69 deletions(-) diff --git a/Modules/LlmDriver/app/OllamaClient.php b/Modules/LlmDriver/app/OllamaClient.php index bbe5265e..241c3b61 100644 --- a/Modules/LlmDriver/app/OllamaClient.php +++ b/Modules/LlmDriver/app/OllamaClient.php @@ -119,6 +119,7 @@ public function chat(array $messages): CompletionResponse } put_fixture('ollama_chat_response.json', $response->json()); + return OllamaChatCompletionResponse::from($response->json()); } @@ -151,7 +152,7 @@ public function completionPool(array $prompts, int $temperature = 0): array $payload = $this->modifyPayload($payload, true); - Log::info('Ollama Request index ' . $index); + Log::info('Ollama Request index '.$index); $pool->withHeaders([ 'content-type' => 'application/json', @@ -282,7 +283,6 @@ public function remapMessages(array $messages): array ->toArray(); })->toArray(); - return $messages; } } diff --git a/Modules/LlmDriver/tests/Feature/LlmDriverClientTest.php b/Modules/LlmDriver/tests/Feature/LlmDriverClientTest.php index 368c358b..4c16f670 100644 --- a/Modules/LlmDriver/tests/Feature/LlmDriverClientTest.php +++ b/Modules/LlmDriver/tests/Feature/LlmDriverClientTest.php @@ -43,14 +43,14 @@ public function test_get_functions() ToolTypes::Chat )->getFunctions(); - $this->assertCount(3, $function); + $this->assertCount(0, $function); } public function test_get_functions_for_ui() { $functions = LlmDriverFacade::getFunctionsForUi(); - $this->assertCount(9, $functions); + $this->assertCount(8, $functions); } } diff --git a/app/Domains/Orchestration/OrchestrateVersionTwo.php b/app/Domains/Orchestration/OrchestrateVersionTwo.php index 61a32ea9..58daa37d 100644 --- a/app/Domains/Orchestration/OrchestrateVersionTwo.php +++ b/app/Domains/Orchestration/OrchestrateVersionTwo.php @@ -154,12 +154,10 @@ protected function chatWithTools(Chat $chat, Message $message, CompletionRespons protected function justChat(Chat $chat, Message $message, ToolTypes $toolType): void { - Log::info('[LaraChain] - Just Chatting ' . $chat->getDriver()); + Log::info('[LaraChain] - Just Chatting '.$chat->getDriver()); $messages = $chat->getChatResponse(); - put_fixture('orchestrate_messages_first_send.json', $messages); - $response = LlmDriverFacade::driver($chat->getDriver()) ->setToolType($toolType) ->chat($messages); diff --git a/tests/Feature/Http/Controllers/ChatControllerTest.php b/tests/Feature/Http/Controllers/ChatControllerTest.php index 2bf78915..71707217 100644 --- a/tests/Feature/Http/Controllers/ChatControllerTest.php +++ b/tests/Feature/Http/Controllers/ChatControllerTest.php @@ -10,7 +10,7 @@ use App\Models\Message; use App\Models\User; use Facades\App\Domains\Agents\VerifyResponseAgent; -use Facades\LlmLaraHub\LlmDriver\Orchestrate; +use Facades\App\Domains\Orchestration\OrchestrateVersionTwo; use LlmLaraHub\LlmDriver\LlmDriverFacade; use LlmLaraHub\LlmDriver\Responses\CompletionResponse; use Tests\TestCase; @@ -44,7 +44,7 @@ public function test_will_verify_on_completion(): void 'user_id' => $user->id, ]); - Orchestrate::shouldReceive('handle')->never(); + OrchestrateVersionTwo::shouldReceive('handle')->never(); $firstResponse = CompletionResponse::from([ 'content' => 'test', @@ -89,7 +89,7 @@ public function test_adds_meta_data_and_date_range() 'user_id' => $user->id, ]); - Orchestrate::shouldReceive('handle')->once()->andReturn('Yo'); + OrchestrateVersionTwo::shouldReceive('handle')->once(); $this->assertDatabaseCount('messages', 0); $this->actingAs($user)->post(route('chats.messages.create', [ @@ -117,7 +117,7 @@ public function test_adds_references_collection_id() 'user_id' => $user->id, ]); - Orchestrate::shouldReceive('handle')->once()->andReturn('Yo'); + OrchestrateVersionTwo::shouldReceive('handle')->once(); $this->actingAs($user)->post(route('chats.messages.create', [ 'chat' => $chat->id, ]), @@ -142,7 +142,7 @@ public function test_a_function_based_chat() 'user_id' => $user->id, ]); - Orchestrate::shouldReceive('handle')->once()->andReturn('Yo'); + OrchestrateVersionTwo::shouldReceive('handle')->once()->andReturn('Yo'); $this->assertDatabaseCount('messages', 0); $this->actingAs($user)->post(route('chats.messages.create', [ @@ -179,7 +179,7 @@ public function test_kick_off_chat_makes_system() public function test_standard_checker() { - Orchestrate::shouldReceive('handle')->once()->andReturn('Yo'); + OrchestrateVersionTwo::shouldReceive('handle')->once()->andReturn('Yo'); $user = User::factory()->create(); $collection = Collection::factory()->create(); diff --git a/tests/Feature/Http/Controllers/GoogleControllerTest.php b/tests/Feature/Http/Controllers/GoogleControllerTest.php index 74f2266d..c51d5ee0 100644 --- a/tests/Feature/Http/Controllers/GoogleControllerTest.php +++ b/tests/Feature/Http/Controllers/GoogleControllerTest.php @@ -13,6 +13,7 @@ class GoogleControllerTest extends TestCase */ public function test_saves_meta_data(): void { + $this->markTestSkipped('@TODO need to come back to getting Google Auth working'); $user = User::factory()->create([ 'meta_data' => [], ]); diff --git a/tests/Feature/Models/MessageTest.php b/tests/Feature/Models/MessageTest.php index 805649d4..52b15e39 100644 --- a/tests/Feature/Models/MessageTest.php +++ b/tests/Feature/Models/MessageTest.php @@ -10,7 +10,7 @@ use App\Models\Message; use App\Models\Report; use App\Models\User; -use Facades\LlmLaraHub\LlmDriver\Orchestrate; +use Facades\App\Domains\Orchestration\OrchestrateVersionTwo; use Illuminate\Foundation\Testing\RefreshDatabase; use Illuminate\Support\Facades\Queue; use LlmLaraHub\LlmDriver\LlmDriverFacade; @@ -77,15 +77,13 @@ public function test_run(): void 'user_id' => $user->id, ]); - Orchestrate::shouldReceive('handle')->never(); + OrchestrateVersionTwo::shouldReceive('handle')->once(); $firstResponse = CompletionResponse::from([ 'content' => 'test', 'stop_reason' => 'stop', ]); - LlmDriverFacade::shouldReceive('driver->hasFunctions')->once()->andReturn(false); - $message = Message::factory()->user()->create([ 'tool' => 'completion', 'meta_data' => MetaDataDto::from([]), @@ -106,13 +104,13 @@ public function test_rerun(): void 'user_id' => $user->id, ]); - Orchestrate::shouldReceive('handle')->never(); + OrchestrateVersionTwo::shouldReceive('handle')->once(); $firstResponse = CompletionResponse::from([ 'content' => 'test', ]); - LlmDriverFacade::shouldReceive('driver->chat')->once()->andReturn($firstResponse); + LlmDriverFacade::shouldReceive('driver->chat')->never(); $message = Message::factory()->user()->create([ 'chat_id' => $chat->id, @@ -130,6 +128,6 @@ public function test_rerun(): void $messageAssistant->reRun(); - $this->assertDatabaseCount('messages', 2); + $this->assertDatabaseCount('messages', 1); } } diff --git a/tests/Feature/OrchestrateVersionTwoTest.php b/tests/Feature/OrchestrateVersionTwoTest.php index 01bc4028..b05beeab 100644 --- a/tests/Feature/OrchestrateVersionTwoTest.php +++ b/tests/Feature/OrchestrateVersionTwoTest.php @@ -7,7 +7,7 @@ use App\Models\Message; use Illuminate\Support\Facades\Bus; use LlmLaraHub\LlmDriver\LlmDriverFacade; -use LlmLaraHub\LlmDriver\Responses\OllamaCompletionResponse; +use LlmLaraHub\LlmDriver\Responses\OllamaChatCompletionResponse; use Tests\TestCase; class OrchestrateVersionTwoTest extends TestCase @@ -22,7 +22,7 @@ public function test_batches(): void $data = get_fixture('ollama_response_tools.json'); LlmDriverFacade::shouldReceive('driver->setToolType->chat')->once()->andReturn( - OllamaCompletionResponse::from($data) + OllamaChatCompletionResponse::from($data) ); $prompt = <<<'PROMPT' diff --git a/tests/fixtures/claude_messages_after_remap.json b/tests/fixtures/claude_messages_after_remap.json index ce0930d8..a001b362 100644 --- a/tests/fixtures/claude_messages_after_remap.json +++ b/tests/fixtures/claude_messages_after_remap.json @@ -1,14 +1,39 @@ [ { "role": "user", - "content": "using the follow requirements list what are some solutions we have in this collection.\nWhen you find them just share a 1 liner to explain what they are about and another as to why you chose it\n\n---- requirements below ---\n# Request for Proposal: Website Enhancement and API Integration\n## 1. Introduction\nOur company, TechInnovate Solutions, is seeking proposals from qualified web development\nagencies or freelance developers to enhance our existing website and resolve critical issues\nwith our API and frontend components. This project aims to improve our website's\nfunctionality, performance, and user experience.\n## 2. Company Background\nTechInnovate Solutions is a leading provider of cloud-based software solutions for small to\nmedium-sized businesses. Founded in 2015, we have grown to serve over 10,000 customers\nacross North America. Our flagship product, CloudManage Pro, helps businesses streamline\ntheir operations, manage customer relationships, and optimize their supply chain processes.\n## 3. Project Overview\nWe are looking to address two main issues with our current website:\n1. API Integration Problem: Our website's backend, built with Laravel, is experiencing issues\nwith API calls, affecting data retrieval and submission processes.\n2. Frontend Banner Quality: The VueJS-powered banner on our homepage is displaying low-\nquality images, impacting the overall user experience and brand perception.\n## 4. Scope of Work\n### 4.1 API Issue Resolution\n- Diagnose the current API integration problems\n- Implement necessary fixes to ensure smooth data flow between frontend and backend\n- Optimize API calls for improved performance\n- Ensure proper error handling and logging\n- Update API documentation as needed\n### 4.2 VueJS Banner Enhancement\n- Investigate the cause of low-quality images in the banner\n- Implement image optimization techniques\n- Ensure responsive design across various devices and screen sizes\n- Improve loading times for banner images\n- Implement lazy loading if appropriate\n### 4.3 General Improvements\n- Conduct a brief audit of the existing codebase\n- Suggest and implement any critical optimizations\n- Ensure cross-browser compatibility\n- Improve overall website performance\n## 5. Technical Requirements\n### 5.1 Backend\n- Laravel framework (version 8.0 or higher)\n- PHP 7.4 or higher\n- MySQL database\n- RESTful API architecture\n### 5.2 Frontend\n- VueJS framework (version 3.0 or higher)\n- HTML5, CSS3, JavaScript\n- Responsive design principles\n- Modern browser compatibility (Chrome, Firefox, Safari, Edge)\n## 6. Deliverables\n1. Fully functional API with resolved integration issues\n2. Optimized VueJS banner with high-quality images\n3. Updated codebase with implemented improvements\n4. Comprehensive documentation of changes and optimizations\n5. Knowledge transfer session with our in-house development team\n## 7. Timeline\nWe anticipate this project to be completed within 2-3 weeks from the start date. Here's a\nproposed timeline:\n- Week 1: API diagnosis and initial fixes\n- Week 2: VueJS banner optimization and general improvements\n- Week 3: Final testing, documentation, and knowledge transfer\n## 8. Budget\nWhile we value quality work, we also have budget constraints. We are looking for the most\ncost-effective solution that meets our requirements. Please provide a detailed breakdown of\nyour costs in your proposal.\n## 9. Proposal Requirements\nYour proposal should include:\n1. Company\/Individual overview and relevant experience\n2. Detailed approach to solving our issues\n3. Proposed timeline\n4. Cost breakdown\n5. Team structure (if applicable)\n6. At least two references from similar projects\n## 10. Evaluation Criteria\nProposals will be evaluated based on the following criteria:\n1. Technical expertise (40%)\n2. Proposed approach and methodology (25%)\n3. Cost effectiveness (20%)\n4. Timeline and ability to meet deadlines (10%)\n5. References and past performance (5%)\n## 11. Submission Guidelines\nPlease submit your proposal in PDF format to rfp@techinnovatesolutions.com by [Insert Date].\nThe subject line should read \"Proposal - Website Enhancement Project\".\n## 12. Contact Information\nFor any questions or clarifications regarding this RFP, please contact:\nJohn Doe\nProject Manager, TechInnovate Solutions\nEmail: john.doe@techinnovatesolutions.com\nPhone: (555) 123-4567\nWe look forward to reviewing your proposals and potentially working with you to enhance our\nwebsite and improve our user experience." + "content": "test1" }, { "role": "assistant", - "content": "Based on the requirements and the solutions presented in our conversation, here are some relevant solutions from our collection:\n\n1. Experienced Laravel developer:\n One-liner: Developer with extensive Laravel experience, including 10 years as a lead contractor at Pfizer.\n Why chosen: Directly addresses the technical expertise requirement for Laravel backend development.\n\n2. Full-stack development capability:\n One-liner: Comprehensive development skills covering both backend (API) and frontend (VueJS) issues.\n Why chosen: Aligns with the project's need for both API resolution and frontend banner enhancement.\n\n3. Build-measure-learn philosophy:\n One-liner: Iterative development approach focusing on continuous improvement and optimization.\n Why chosen: Fits the project's timeline and scope, allowing for ongoing refinement of both API and frontend components.\n\n4. Filament for Laravel:\n One-liner: Powerful admin panel and application framework for Laravel.\n Why chosen: Can address API integration issues and provide an easy-to-use interface for managing backend operations.\n\n5. Inertia and Vue for the frontend:\n One-liner: Approach combining Inertia and Vue for seamless frontend development.\n Why chosen: Aligns with the VueJS requirements and can help resolve frontend banner quality issues.\n\n6. Agile development approach:\n One-liner: Iterative development with frequent feedback and adjustments.\n Why chosen: Matches the need for flexibility and rapid development within the tight project timeline.\n\n7. Performance optimization techniques:\n One-liner: Methods to enhance website speed and responsiveness.\n Why chosen: Directly addresses the requirement for improving loading times and overall website performance." + "content": "test2" }, { "role": "user", - "content": "can you tldr this thread for me" + "content": "Using the surrounding context to continue this response thread" + }, + { + "role": "assistant", + "content": [ + { + "type": "text", + "text": "test3<\/thinking>" + }, + { + "type": "tool_use", + "id": "test_id", + "name": "test", + "input": [] + } + ] + }, + { + "role": "user", + "content": [ + { + "type": "tool_result", + "tool_use_id": "test_id", + "content": "test3" + } + ] } ] \ No newline at end of file diff --git a/tests/fixtures/claude_messages_before_remap.json b/tests/fixtures/claude_messages_before_remap.json index 87cf723b..332b6c91 100644 --- a/tests/fixtures/claude_messages_before_remap.json +++ b/tests/fixtures/claude_messages_before_remap.json @@ -1,32 +1,44 @@ [ { - "content": "using the follow requirements list what are some solutions we have in this collection.\nWhen you find them just share a 1 liner to explain what they are about and another as to why you chose it\n\n---- requirements below ---\n# Request for Proposal: Website Enhancement and API Integration\n## 1. Introduction\nOur company, TechInnovate Solutions, is seeking proposals from qualified web development\nagencies or freelance developers to enhance our existing website and resolve critical issues\nwith our API and frontend components. This project aims to improve our website's\nfunctionality, performance, and user experience.\n## 2. Company Background\nTechInnovate Solutions is a leading provider of cloud-based software solutions for small to\nmedium-sized businesses. Founded in 2015, we have grown to serve over 10,000 customers\nacross North America. Our flagship product, CloudManage Pro, helps businesses streamline\ntheir operations, manage customer relationships, and optimize their supply chain processes.\n## 3. Project Overview\nWe are looking to address two main issues with our current website:\n1. API Integration Problem: Our website's backend, built with Laravel, is experiencing issues\nwith API calls, affecting data retrieval and submission processes.\n2. Frontend Banner Quality: The VueJS-powered banner on our homepage is displaying low-\nquality images, impacting the overall user experience and brand perception.\n## 4. Scope of Work\n### 4.1 API Issue Resolution\n- Diagnose the current API integration problems\n- Implement necessary fixes to ensure smooth data flow between frontend and backend\n- Optimize API calls for improved performance\n- Ensure proper error handling and logging\n- Update API documentation as needed\n### 4.2 VueJS Banner Enhancement\n- Investigate the cause of low-quality images in the banner\n- Implement image optimization techniques\n- Ensure responsive design across various devices and screen sizes\n- Improve loading times for banner images\n- Implement lazy loading if appropriate\n### 4.3 General Improvements\n- Conduct a brief audit of the existing codebase\n- Suggest and implement any critical optimizations\n- Ensure cross-browser compatibility\n- Improve overall website performance\n## 5. Technical Requirements\n### 5.1 Backend\n- Laravel framework (version 8.0 or higher)\n- PHP 7.4 or higher\n- MySQL database\n- RESTful API architecture\n### 5.2 Frontend\n- VueJS framework (version 3.0 or higher)\n- HTML5, CSS3, JavaScript\n- Responsive design principles\n- Modern browser compatibility (Chrome, Firefox, Safari, Edge)\n## 6. Deliverables\n1. Fully functional API with resolved integration issues\n2. Optimized VueJS banner with high-quality images\n3. Updated codebase with implemented improvements\n4. Comprehensive documentation of changes and optimizations\n5. Knowledge transfer session with our in-house development team\n## 7. Timeline\nWe anticipate this project to be completed within 2-3 weeks from the start date. Here's a\nproposed timeline:\n- Week 1: API diagnosis and initial fixes\n- Week 2: VueJS banner optimization and general improvements\n- Week 3: Final testing, documentation, and knowledge transfer\n## 8. Budget\nWhile we value quality work, we also have budget constraints. We are looking for the most\ncost-effective solution that meets our requirements. Please provide a detailed breakdown of\nyour costs in your proposal.\n## 9. Proposal Requirements\nYour proposal should include:\n1. Company\/Individual overview and relevant experience\n2. Detailed approach to solving our issues\n3. Proposed timeline\n4. Cost breakdown\n5. Team structure (if applicable)\n6. At least two references from similar projects\n## 10. Evaluation Criteria\nProposals will be evaluated based on the following criteria:\n1. Technical expertise (40%)\n2. Proposed approach and methodology (25%)\n3. Cost effectiveness (20%)\n4. Timeline and ability to meet deadlines (10%)\n5. References and past performance (5%)\n## 11. Submission Guidelines\nPlease submit your proposal in PDF format to rfp@techinnovatesolutions.com by [Insert Date].\nThe subject line should read \"Proposal - Website Enhancement Project\".\n## 12. Contact Information\nFor any questions or clarifications regarding this RFP, please contact:\nJohn Doe\nProject Manager, TechInnovate Solutions\nEmail: john.doe@techinnovatesolutions.com\nPhone: (555) 123-4567\nWe look forward to reviewing your proposals and potentially working with you to enhance our\nwebsite and improve our user experience.", + "content": "test1", "role": "user", "is_ai": false, "show": true, - "tool": "gather_info_tool", + "tool": "", "tool_id": "", "args": [], "meta_data": null }, { - "content": "Based on the requirements and the solutions presented in our conversation, here are some relevant solutions from our collection:\n\n1. Experienced Laravel developer:\n One-liner: Developer with extensive Laravel experience, including 10 years as a lead contractor at Pfizer.\n Why chosen: Directly addresses the technical expertise requirement for Laravel backend development.\n\n2. Full-stack development capability:\n One-liner: Comprehensive development skills covering both backend (API) and frontend (VueJS) issues.\n Why chosen: Aligns with the project's need for both API resolution and frontend banner enhancement.\n\n3. Build-measure-learn philosophy:\n One-liner: Iterative development approach focusing on continuous improvement and optimization.\n Why chosen: Fits the project's timeline and scope, allowing for ongoing refinement of both API and frontend components.\n\n4. Filament for Laravel:\n One-liner: Powerful admin panel and application framework for Laravel.\n Why chosen: Can address API integration issues and provide an easy-to-use interface for managing backend operations.\n\n5. Inertia and Vue for the frontend:\n One-liner: Approach combining Inertia and Vue for seamless frontend development.\n Why chosen: Aligns with the VueJS requirements and can help resolve frontend banner quality issues.\n\n6. Agile development approach:\n One-liner: Iterative development with frequent feedback and adjustments.\n Why chosen: Matches the need for flexibility and rapid development within the tight project timeline.\n\n7. Performance optimization techniques:\n One-liner: Methods to enhance website speed and responsiveness.\n Why chosen: Directly addresses the requirement for improving loading times and overall website performance.", + "content": "test2", "role": "assistant", "is_ai": false, "show": true, - "tool": "gather_info_tool", + "tool": "", "tool_id": "", "args": [], "meta_data": null }, { - "content": "can you tldr this thread for me", - "role": "user", + "content": "test3", + "role": "tool", "is_ai": false, "show": true, - "tool": "chat", - "tool_id": "", + "tool": "test", + "tool_id": "test_id", "args": [], - "meta_data": null + "meta_data": { + "persona": "", + "filter": null, + "completion": false, + "tool": "", + "tool_id": "", + "date_range": "", + "input": "", + "driver": "", + "source": "", + "reference_collection_id": "", + "args": [] + } } ] \ No newline at end of file diff --git a/tests/fixtures/claude_payload.json b/tests/fixtures/claude_payload.json index 964edcf4..285d7425 100644 --- a/tests/fixtures/claude_payload.json +++ b/tests/fixtures/claude_payload.json @@ -4,16 +4,169 @@ "messages": [ { "role": "user", - "content": "using the follow requirements list what are some solutions we have in this collection.\nWhen you find them just share a 1 liner to explain what they are about and another as to why you chose it\n\n---- requirements below ---\n# Request for Proposal: Website Enhancement and API Integration\n## 1. Introduction\nOur company, TechInnovate Solutions, is seeking proposals from qualified web development\nagencies or freelance developers to enhance our existing website and resolve critical issues\nwith our API and frontend components. This project aims to improve our website's\nfunctionality, performance, and user experience.\n## 2. Company Background\nTechInnovate Solutions is a leading provider of cloud-based software solutions for small to\nmedium-sized businesses. Founded in 2015, we have grown to serve over 10,000 customers\nacross North America. Our flagship product, CloudManage Pro, helps businesses streamline\ntheir operations, manage customer relationships, and optimize their supply chain processes.\n## 3. Project Overview\nWe are looking to address two main issues with our current website:\n1. API Integration Problem: Our website's backend, built with Laravel, is experiencing issues\nwith API calls, affecting data retrieval and submission processes.\n2. Frontend Banner Quality: The VueJS-powered banner on our homepage is displaying low-\nquality images, impacting the overall user experience and brand perception.\n## 4. Scope of Work\n### 4.1 API Issue Resolution\n- Diagnose the current API integration problems\n- Implement necessary fixes to ensure smooth data flow between frontend and backend\n- Optimize API calls for improved performance\n- Ensure proper error handling and logging\n- Update API documentation as needed\n### 4.2 VueJS Banner Enhancement\n- Investigate the cause of low-quality images in the banner\n- Implement image optimization techniques\n- Ensure responsive design across various devices and screen sizes\n- Improve loading times for banner images\n- Implement lazy loading if appropriate\n### 4.3 General Improvements\n- Conduct a brief audit of the existing codebase\n- Suggest and implement any critical optimizations\n- Ensure cross-browser compatibility\n- Improve overall website performance\n## 5. Technical Requirements\n### 5.1 Backend\n- Laravel framework (version 8.0 or higher)\n- PHP 7.4 or higher\n- MySQL database\n- RESTful API architecture\n### 5.2 Frontend\n- VueJS framework (version 3.0 or higher)\n- HTML5, CSS3, JavaScript\n- Responsive design principles\n- Modern browser compatibility (Chrome, Firefox, Safari, Edge)\n## 6. Deliverables\n1. Fully functional API with resolved integration issues\n2. Optimized VueJS banner with high-quality images\n3. Updated codebase with implemented improvements\n4. Comprehensive documentation of changes and optimizations\n5. Knowledge transfer session with our in-house development team\n## 7. Timeline\nWe anticipate this project to be completed within 2-3 weeks from the start date. Here's a\nproposed timeline:\n- Week 1: API diagnosis and initial fixes\n- Week 2: VueJS banner optimization and general improvements\n- Week 3: Final testing, documentation, and knowledge transfer\n## 8. Budget\nWhile we value quality work, we also have budget constraints. We are looking for the most\ncost-effective solution that meets our requirements. Please provide a detailed breakdown of\nyour costs in your proposal.\n## 9. Proposal Requirements\nYour proposal should include:\n1. Company\/Individual overview and relevant experience\n2. Detailed approach to solving our issues\n3. Proposed timeline\n4. Cost breakdown\n5. Team structure (if applicable)\n6. At least two references from similar projects\n## 10. Evaluation Criteria\nProposals will be evaluated based on the following criteria:\n1. Technical expertise (40%)\n2. Proposed approach and methodology (25%)\n3. Cost effectiveness (20%)\n4. Timeline and ability to meet deadlines (10%)\n5. References and past performance (5%)\n## 11. Submission Guidelines\nPlease submit your proposal in PDF format to rfp@techinnovatesolutions.com by [Insert Date].\nThe subject line should read \"Proposal - Website Enhancement Project\".\n## 12. Contact Information\nFor any questions or clarifications regarding this RFP, please contact:\nJohn Doe\nProject Manager, TechInnovate Solutions\nEmail: john.doe@techinnovatesolutions.com\nPhone: (555) 123-4567\nWe look forward to reviewing your proposals and potentially working with you to enhance our\nwebsite and improve our user experience." + "content": "test" }, { "role": "assistant", - "content": "Based on the requirements and the solutions presented in our conversation, here are some relevant solutions from our collection:\n\n1. Experienced Laravel developer:\n One-liner: Developer with extensive Laravel experience, including 10 years as a lead contractor at Pfizer.\n Why chosen: Directly addresses the technical expertise requirement for Laravel backend development.\n\n2. Full-stack development capability:\n One-liner: Comprehensive development skills covering both backend (API) and frontend (VueJS) issues.\n Why chosen: Aligns with the project's need for both API resolution and frontend banner enhancement.\n\n3. Build-measure-learn philosophy:\n One-liner: Iterative development approach focusing on continuous improvement and optimization.\n Why chosen: Fits the project's timeline and scope, allowing for ongoing refinement of both API and frontend components.\n\n4. Filament for Laravel:\n One-liner: Powerful admin panel and application framework for Laravel.\n Why chosen: Can address API integration issues and provide an easy-to-use interface for managing backend operations.\n\n5. Inertia and Vue for the frontend:\n One-liner: Approach combining Inertia and Vue for seamless frontend development.\n Why chosen: Aligns with the VueJS requirements and can help resolve frontend banner quality issues.\n\n6. Agile development approach:\n One-liner: Iterative development with frequent feedback and adjustments.\n Why chosen: Matches the need for flexibility and rapid development within the tight project timeline.\n\n7. Performance optimization techniques:\n One-liner: Methods to enhance website speed and responsiveness.\n Why chosen: Directly addresses the requirement for improving loading times and overall website performance." + "content": "test 1" }, { "role": "user", - "content": "can you tldr this thread for me" + "content": "Using the surrounding context to continue this response thread" + }, + { + "role": "assistant", + "content": "test 2" + }, + { + "role": "user", + "content": "Using the surrounding context to continue this response thread" + }, + { + "role": "assistant", + "content": "test 3" } ], - "tools": [] + "tools": [ + { + "name": "summarize_collection", + "description": "NOT FOR SEARCH, This is used when the prompt wants to summarize the entire collection of documents", + "input_schema": { + "type": "object", + "properties": { + "prompt": { + "description": "The prompt the user is using the search for.", + "type": "string" + } + }, + "required": [ + "prompt" + ] + } + }, + { + "name": "retrieve_related", + "description": "Used to embed users prompt, search local database and return summarized results.\n DOES NOT SEARCH THE WEB. This is only used for local database search.", + "input_schema": { + "type": "object", + "properties": { + "prompt": { + "description": "This is the prompt the user is using to search the database and may or may not assist the results.", + "type": "string" + } + }, + "required": [] + } + }, + { + "name": "standards_checker", + "description": "Checks the prompt data follows the standards of the documents in the collection", + "input_schema": { + "type": "object", + "properties": { + "prompt": { + "description": "The prompt the user is using to check standards.", + "type": "string" + } + }, + "required": [ + "prompt" + ] + } + }, + { + "name": "reporting_tool", + "description": "Uses Reference collection to generate a report", + "input_schema": { + "type": "object", + "properties": { + "prompt": { + "description": "The prompt the user is using to use as solutions to the report", + "type": "string" + } + }, + "required": [ + "prompt" + ] + } + }, + { + "name": "gather_info_tool", + "description": "This will look at all documents using your prompt then return the results after once more using your prompt", + "input_schema": { + "type": "object", + "properties": { + "prompt": { + "description": "Using your prompt we will look at every document, run your prompt against each one and then against the final output", + "type": "string" + } + }, + "required": [ + "prompt" + ] + } + }, + { + "name": "get_web_site_from_url", + "description": "If you add urls to a prompt and ask the llm to get the web site using the url(s) you give it", + "input_schema": { + "type": "object", + "properties": { + "url": { + "description": "The URL To get", + "type": "string" + } + }, + "required": [ + "url" + ] + } + }, + { + "name": "search_the_web", + "description": "Search the web for a topic ONLY if the user asks for web search", + "input_schema": { + "type": "object", + "properties": { + "search_phrase": { + "description": "1-5 words to search for", + "type": "string" + } + }, + "required": [ + "search_phrase" + ] + } + }, + { + "name": "create_document", + "description": "Create or Save a document into the collection of this local system using the content provided", + "input_schema": { + "type": "object", + "properties": { + "content": { + "description": "the content to use for the document", + "type": "string" + } + }, + "required": [ + "content" + ] + } + }, + { + "name": "chat_only", + "description": "User just wants to continue the chat no need to look in the collection for more documents", + "input_schema": { + "type": "object", + "properties": { + "prompt": { + "description": "the prompt to go with the chat", + "type": "string" + } + }, + "required": [] + } + } + ] } \ No newline at end of file diff --git a/tests/fixtures/ollama_chat_response.json b/tests/fixtures/ollama_chat_response.json index a090d873..3c56d5f6 100644 --- a/tests/fixtures/ollama_chat_response.json +++ b/tests/fixtures/ollama_chat_response.json @@ -1,16 +1,16 @@ { - "model": "llama3.1", - "created_at": "2024-08-04T19:37:10.374983Z", + "model": "phi3", + "created_at": "2024-05-20T01:57:46.168876Z", "message": { "role": "assistant", - "content": "Here's a brief summary:\n\nWe discussed a Request for Proposal (RFP) from TechInnovate Solutions to enhance their existing website and resolve critical issues with their API and frontend components.\n\nI identified some relevant solutions from our collection that align with the project requirements, including:\n\n* Experienced Laravel developer\n* Full-stack development capability\n* Build-measure-learn philosophy\n* Filament for Laravel\n* Inertia and Vue for the frontend\n* Agile development approach\n* Performance optimization techniques\n\nThese solutions can help address the technical expertise, proposed approach, cost effectiveness, timeline, and references required by the RFP." + "content": "To address the \"test\" instruction effectively, I'll provide a response as if it were part of an automated system designed to handle user inputs or test cases. Since there is no specific context given, let me assume we are discussing a software application that might receive this input for testing purposes:\n\n\n```\n\nTest Case #1: Input Validation Test\n\nObjective: Verify the application correctly handles an unexpected input string (test).\n\nSteps:\n\n1. Open the application and navigate to the relevant input field where test strings are usually entered.\n\n2. Enter \"test\" into the specified text field without any formatting or additional characters.\n\n3. Submit the entry.\n\nExpected Result: The application should either accept \"test\" as a valid input if it's meant to be accepted in this context, or provide an appropriate error message if such input is not expected or supported by the system.\n\n```\n\nThis example demonstrates how one might construct a test case for handling the specific string \"test.\" Depending on what kind of application you are testing (web form, command-line interface, etc.), and what behavior is intended when encountering this string, your actual instructions would vary accordingly." }, "done_reason": "stop", "done": true, - "total_duration": 5256189083, - "load_duration": 17520708, - "prompt_eval_count": 1300, - "prompt_eval_duration": 50516000, - "eval_count": 125, - "eval_duration": 5182683000 + "total_duration": 6352558125, + "load_duration": 4046250, + "prompt_eval_count": 12, + "prompt_eval_duration": 82735000, + "eval_count": 260, + "eval_duration": 6263825000 } \ No newline at end of file diff --git a/tests/fixtures/orchestrate_messages_first_send.json b/tests/fixtures/orchestrate_messages_first_send.json index 87cf723b..4785c481 100644 --- a/tests/fixtures/orchestrate_messages_first_send.json +++ b/tests/fixtures/orchestrate_messages_first_send.json @@ -1,30 +1,10 @@ [ { - "content": "using the follow requirements list what are some solutions we have in this collection.\nWhen you find them just share a 1 liner to explain what they are about and another as to why you chose it\n\n---- requirements below ---\n# Request for Proposal: Website Enhancement and API Integration\n## 1. Introduction\nOur company, TechInnovate Solutions, is seeking proposals from qualified web development\nagencies or freelance developers to enhance our existing website and resolve critical issues\nwith our API and frontend components. This project aims to improve our website's\nfunctionality, performance, and user experience.\n## 2. Company Background\nTechInnovate Solutions is a leading provider of cloud-based software solutions for small to\nmedium-sized businesses. Founded in 2015, we have grown to serve over 10,000 customers\nacross North America. Our flagship product, CloudManage Pro, helps businesses streamline\ntheir operations, manage customer relationships, and optimize their supply chain processes.\n## 3. Project Overview\nWe are looking to address two main issues with our current website:\n1. API Integration Problem: Our website's backend, built with Laravel, is experiencing issues\nwith API calls, affecting data retrieval and submission processes.\n2. Frontend Banner Quality: The VueJS-powered banner on our homepage is displaying low-\nquality images, impacting the overall user experience and brand perception.\n## 4. Scope of Work\n### 4.1 API Issue Resolution\n- Diagnose the current API integration problems\n- Implement necessary fixes to ensure smooth data flow between frontend and backend\n- Optimize API calls for improved performance\n- Ensure proper error handling and logging\n- Update API documentation as needed\n### 4.2 VueJS Banner Enhancement\n- Investigate the cause of low-quality images in the banner\n- Implement image optimization techniques\n- Ensure responsive design across various devices and screen sizes\n- Improve loading times for banner images\n- Implement lazy loading if appropriate\n### 4.3 General Improvements\n- Conduct a brief audit of the existing codebase\n- Suggest and implement any critical optimizations\n- Ensure cross-browser compatibility\n- Improve overall website performance\n## 5. Technical Requirements\n### 5.1 Backend\n- Laravel framework (version 8.0 or higher)\n- PHP 7.4 or higher\n- MySQL database\n- RESTful API architecture\n### 5.2 Frontend\n- VueJS framework (version 3.0 or higher)\n- HTML5, CSS3, JavaScript\n- Responsive design principles\n- Modern browser compatibility (Chrome, Firefox, Safari, Edge)\n## 6. Deliverables\n1. Fully functional API with resolved integration issues\n2. Optimized VueJS banner with high-quality images\n3. Updated codebase with implemented improvements\n4. Comprehensive documentation of changes and optimizations\n5. Knowledge transfer session with our in-house development team\n## 7. Timeline\nWe anticipate this project to be completed within 2-3 weeks from the start date. Here's a\nproposed timeline:\n- Week 1: API diagnosis and initial fixes\n- Week 2: VueJS banner optimization and general improvements\n- Week 3: Final testing, documentation, and knowledge transfer\n## 8. Budget\nWhile we value quality work, we also have budget constraints. We are looking for the most\ncost-effective solution that meets our requirements. Please provide a detailed breakdown of\nyour costs in your proposal.\n## 9. Proposal Requirements\nYour proposal should include:\n1. Company\/Individual overview and relevant experience\n2. Detailed approach to solving our issues\n3. Proposed timeline\n4. Cost breakdown\n5. Team structure (if applicable)\n6. At least two references from similar projects\n## 10. Evaluation Criteria\nProposals will be evaluated based on the following criteria:\n1. Technical expertise (40%)\n2. Proposed approach and methodology (25%)\n3. Cost effectiveness (20%)\n4. Timeline and ability to meet deadlines (10%)\n5. References and past performance (5%)\n## 11. Submission Guidelines\nPlease submit your proposal in PDF format to rfp@techinnovatesolutions.com by [Insert Date].\nThe subject line should read \"Proposal - Website Enhancement Project\".\n## 12. Contact Information\nFor any questions or clarifications regarding this RFP, please contact:\nJohn Doe\nProject Manager, TechInnovate Solutions\nEmail: john.doe@techinnovatesolutions.com\nPhone: (555) 123-4567\nWe look forward to reviewing your proposals and potentially working with you to enhance our\nwebsite and improve our user experience.", + "content": "Get the content from the url https:\/\/dailyai.studio\n\nThen do a summary of the content breaking it down into\nthree points that would make sense to a real-estate agent\n", "role": "user", "is_ai": false, "show": true, - "tool": "gather_info_tool", - "tool_id": "", - "args": [], - "meta_data": null - }, - { - "content": "Based on the requirements and the solutions presented in our conversation, here are some relevant solutions from our collection:\n\n1. Experienced Laravel developer:\n One-liner: Developer with extensive Laravel experience, including 10 years as a lead contractor at Pfizer.\n Why chosen: Directly addresses the technical expertise requirement for Laravel backend development.\n\n2. Full-stack development capability:\n One-liner: Comprehensive development skills covering both backend (API) and frontend (VueJS) issues.\n Why chosen: Aligns with the project's need for both API resolution and frontend banner enhancement.\n\n3. Build-measure-learn philosophy:\n One-liner: Iterative development approach focusing on continuous improvement and optimization.\n Why chosen: Fits the project's timeline and scope, allowing for ongoing refinement of both API and frontend components.\n\n4. Filament for Laravel:\n One-liner: Powerful admin panel and application framework for Laravel.\n Why chosen: Can address API integration issues and provide an easy-to-use interface for managing backend operations.\n\n5. Inertia and Vue for the frontend:\n One-liner: Approach combining Inertia and Vue for seamless frontend development.\n Why chosen: Aligns with the VueJS requirements and can help resolve frontend banner quality issues.\n\n6. Agile development approach:\n One-liner: Iterative development with frequent feedback and adjustments.\n Why chosen: Matches the need for flexibility and rapid development within the tight project timeline.\n\n7. Performance optimization techniques:\n One-liner: Methods to enhance website speed and responsiveness.\n Why chosen: Directly addresses the requirement for improving loading times and overall website performance.", - "role": "assistant", - "is_ai": false, - "show": true, - "tool": "gather_info_tool", - "tool_id": "", - "args": [], - "meta_data": null - }, - { - "content": "can you tldr this thread for me", - "role": "user", - "is_ai": false, - "show": true, - "tool": "chat", + "tool": "", "tool_id": "", "args": [], "meta_data": null