From a26628d9b03d6fa26e137bd1512762aa44f8d632 Mon Sep 17 00:00:00 2001 From: Ashley Johnson <61059402+PapaRascal2020@users.noreply.github.com> Date: Sat, 21 Sep 2024 18:49:46 +0100 Subject: [PATCH] tests(SK): Updated and Added tests - Refactored Feature Test to be Mocked - Created Ultilities test --- src/SidekickConversation.php | 2 +- tests/Feature/SidekickConversationTest.php | 93 +++++++++++++++------- tests/Unit/UtilitiesTest.php | 78 ++++++++++++++++++ 3 files changed, 142 insertions(+), 31 deletions(-) create mode 100644 tests/Unit/UtilitiesTest.php diff --git a/src/SidekickConversation.php b/src/SidekickConversation.php index b1e8481..e149288 100644 --- a/src/SidekickConversation.php +++ b/src/SidekickConversation.php @@ -7,7 +7,7 @@ class SidekickConversation { - protected Driver $sidekick; + public Driver $sidekick; public Conversation $conversation; /** diff --git a/tests/Feature/SidekickConversationTest.php b/tests/Feature/SidekickConversationTest.php index f3a4029..e557685 100644 --- a/tests/Feature/SidekickConversationTest.php +++ b/tests/Feature/SidekickConversationTest.php @@ -2,8 +2,6 @@ namespace PapaRascalDev\Sidekick\Tests\Feature; -use Faker\Factory; -use Faker\Generator; use PapaRascalDev\Sidekick\Drivers\OpenAi; use Illuminate\Foundation\Testing\TestCase; use PapaRascalDev\Sidekick\Models\Conversation; @@ -15,96 +13,131 @@ class SidekickConversationTest extends TestCase { use RefreshDatabase; - protected Generator $faker; + protected SidekickConversation $conversationMock; public function setUp(): void { parent::setUp(); - $this->faker = Factory::create(); + $this->conversationMock = $this->createMock(SidekickConversation::class); + + $this->conversationMock->method('begin') + ->willReturnCallback(function ($driver, $model, $systemPrompt) { + $this->conversationMock->conversation = new Conversation(); + $this->conversationMock->conversation->class = get_class($driver); + $this->conversationMock->conversation->model = $model; + $this->conversationMock->conversation->system_prompt = $systemPrompt; + $this->conversationMock->conversation->max_tokens = 1024; + $this->conversationMock->conversation->save(); + + return $this->conversationMock; + }); + + $this->conversationMock->method('resume') + ->willReturnCallback(function ($id) { + $this->conversationMock->conversation = Conversation::find($id); + return $this->conversationMock; + }); } public function test_you_can_create_a_new_conversation() { - $systemPrompt = $this->faker->sentence(); + $systemPrompt = 'You are an assistant'; - $sidekick = new SidekickConversation(); - $sidekick->begin( + $this->conversationMock->begin( driver: new OpenAi(), model: 'gpt-3.5-turbo', systemPrompt: $systemPrompt ); - $this->assertDatabaseHas(Conversation::class, [ - 'id' => $sidekick->conversation->id, + $this->assertDatabaseHas('sidekick_conversations', [ + 'id' => $this->conversationMock->conversation->id, 'system_prompt' => $systemPrompt, ]); } public function test_you_can_remove_new_conversation() { - $systemPrompt = $this->faker->sentence(); + $systemPrompt = "You are an assistant"; - $sidekick = new SidekickConversation(); - $sidekick->begin( + $this->conversationMock->begin( driver: new OpenAi(), model: 'gpt-3.5-turbo', systemPrompt: $systemPrompt ); $this->assertDatabaseHas(Conversation::class, [ - 'id' => $sidekick->conversation->id, + 'id' => $this->conversationMock->conversation->id, 'system_prompt' => $systemPrompt, ]); $sidekickManager = new SidekickChatManager(); - $sidekickManager->delete($sidekick->conversation); + $sidekickManager->delete($this->conversationMock->conversation); - $this->assertDatabaseMissing(Conversation::class, ['id' => $sidekick->conversation->id]); + $this->assertDatabaseMissing(Conversation::class, ['id' => $this->conversationMock->conversation->id]); } public function test_you_can_resume_a_conversation() { - $systemPrompt = $this->faker->sentence(); + $systemPrompt = "You are an assistant"; - $sidekick = new SidekickConversation(); - $sidekick->begin( + $this->conversationMock->begin( driver: new OpenAi(), model: 'gpt-3.5-turbo', systemPrompt: $systemPrompt ); - $id = $sidekick->conversation->id; + $id = $this->conversationMock->conversation->id; $this->assertDatabaseHas(Conversation::class, [ 'id' => $id, 'system_prompt' => $systemPrompt, ]); - $sidekickConversation = new SidekickConversation(); - $sidekickConversation->resume($id); + $this->conversationMock->resume($id); - $this->assertSame($sidekickConversation->conversation->id, $id); + $this->assertSame($this->conversationMock->conversation->id, $id); } public function test_you_can_send_and_receive_a_message() { - $systemPrompt = $this->faker->sentence(); + $systemPrompt = "You are an assistant"; - $sidekick = new SidekickConversation(); - $sidekick->begin( + $this->conversationMock->begin( driver: new OpenAi(), model: 'gpt-3.5-turbo', systemPrompt: $systemPrompt ); - $this->assertDatabaseHas(Conversation::class, [ - 'id' => $sidekick->conversation->id, + $this->assertDatabaseHas('sidekick_conversations', [ + 'id' => $this->conversationMock->conversation->id, 'system_prompt' => $systemPrompt, ]); - $sidekick->sendMessage("Hello"); + $this->conversationMock->method('sendMessage') + ->willReturnCallback(function ($message) { + $wholeMessage = "Response to: " . $message; // Simulate a response message + + $this->conversationMock->conversation->messages()->create([ + 'role' => 'user', + 'content' => $message + ]); + + $this->conversationMock->conversation->messages()->create([ + 'role' => 'assistant', + 'content' => nl2br($wholeMessage) + ]); + + return $this->conversationMock; + }); + + $this->conversationMock->method('messages') + ->willReturnCallback(function () { + return $this->conversationMock->conversation->messages()->get()->toArray(); + }); + + $this->conversationMock->sendMessage("Hello"); - // Assert that there is both the sent message and response - $this->assertCount(2, $sidekick->conversation->messages); + // Assert that there are both the sent message and response + $this->assertCount(2, $this->conversationMock->messages()); } } diff --git a/tests/Unit/UtilitiesTest.php b/tests/Unit/UtilitiesTest.php new file mode 100644 index 0000000..54e221e --- /dev/null +++ b/tests/Unit/UtilitiesTest.php @@ -0,0 +1,78 @@ +sidekickMock = $this->createMock(OpenAi::class); + $this->completionMock = $this->createMock(Completion::class); + } + + public function testSummarize() + { + $content = 'Some long content'; + $expectedResponse = 'summary text'; + + $gptUtilitiesMock = $this->createMock(GptUtilities::class); + $gptUtilitiesMock->method('summarize')->willReturn($expectedResponse); + + $this->sidekickMock->method('utilities')->willReturn($gptUtilitiesMock); + + $result = $this->sidekickMock->utilities()->summarize($content); + + $this->assertEquals($expectedResponse, $result); + } + + public function testExtractKeywords() + { + $text = "This is a text with important keywords."; + $expectedResponse = "text, important, keywords"; + + $gptUtilitiesMock = $this->createMock(GptUtilities::class); + $gptUtilitiesMock->method('extractKeywords')->willReturn($expectedResponse); + + $this->sidekickMock->method('utilities')->willReturn($gptUtilitiesMock); + + $result = $this->sidekickMock->utilities()->extractKeywords($text); + $this->assertEquals($expectedResponse, $result); + } + + public function testTranslateText() + { + $text = "Hello, world!"; + $targetLanguage = "Spanish"; + $expectedResponse = "Hola, mundo!"; + + $gptUtilitiesMock = $this->createMock(GptUtilities::class); + $gptUtilitiesMock->method('translateText')->willReturn($expectedResponse); + + $this->sidekickMock->method('utilities')->willReturn($gptUtilitiesMock); + + $result = $this->sidekickMock->utilities()->translateText($text, $targetLanguage); + $this->assertEquals($expectedResponse, $result); + } + + public function testGenerateContent() + { + $prompt = "Write a story about a brave knight."; + $expectedResponse = "Once upon a time, there was a brave knight..."; + + $gptUtilitiesMock = $this->createMock(GptUtilities::class); + $gptUtilitiesMock->method('generateContent')->willReturn($expectedResponse); + + $this->sidekickMock->method('utilities')->willReturn($gptUtilitiesMock); + + $result = $this->sidekickMock->utilities()->generateContent($prompt); + $this->assertEquals($expectedResponse, $result); + } +}