From 47ecf86aa16310165abff04e837d554c2942abb2 Mon Sep 17 00:00:00 2001 From: Sam Date: Tue, 24 Dec 2024 09:37:23 +1100 Subject: [PATCH] FIX: embedding validation (#1043) --- lib/configuration/embeddings_module_validator.rb | 5 +++-- .../embeddings_module_validator_spec.rb | 15 +++++++++++++++ 2 files changed, 18 insertions(+), 2 deletions(-) create mode 100644 spec/lib/configuration/embeddings_module_validator_spec.rb diff --git a/lib/configuration/embeddings_module_validator.rb b/lib/configuration/embeddings_module_validator.rb index 08db0692..bd5a38bc 100644 --- a/lib/configuration/embeddings_module_validator.rb +++ b/lib/configuration/embeddings_module_validator.rb @@ -42,8 +42,9 @@ module DiscourseAi def can_generate_embeddings?(val) DiscourseAi::Embeddings::VectorRepresentations::Base .find_representation(val) - .new(DiscourseAi::Embeddings::Strategies::Truncation.new) - .vector_from("this is a test") + .new + .inference_client + .perform!("this is a test") .present? end end diff --git a/spec/lib/configuration/embeddings_module_validator_spec.rb b/spec/lib/configuration/embeddings_module_validator_spec.rb new file mode 100644 index 00000000..0b1e5713 --- /dev/null +++ b/spec/lib/configuration/embeddings_module_validator_spec.rb @@ -0,0 +1,15 @@ +# frozen_string_literal: true + +RSpec.describe DiscourseAi::Configuration::EmbeddingsModuleValidator do + let(:validator) { described_class.new } + + describe "#can_generate_embeddings?" do + it "returns true if embeddings can be generated" do + stub_request( + :post, + "https://generativelanguage.googleapis.com/v1beta/models/embedding-001:embedContent?key=", + ).to_return(status: 200, body: { embedding: { values: [1, 2, 3] } }.to_json) + expect(validator.can_generate_embeddings?("gemini")).to eq(true) + end + end +end