FIX: Cloudflare Workers AI embeddings (#1037)

Regressed on 534b0df
This commit is contained in:
Rafael dos Santos Silva 2024-12-20 17:45:27 -03:00 committed by GitHub
parent 059b3fabb8
commit 7607477ff9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 68 additions and 1 deletions

View File

@ -27,10 +27,12 @@ module ::DiscourseAi
"Authorization" => "Bearer #{api_token}",
}
payload = { text: [content] }
endpoint = "https://api.cloudflare.com/client/v4/accounts/#{account_id}/ai/run/@cf/#{model}"
conn = Faraday.new { |f| f.adapter FinalDestination::FaradayAdapter }
response = conn.post(endpoint, content.to_json, headers)
response = conn.post(endpoint, payload.to_json, headers)
case response.status
when 200

View File

@ -0,0 +1,65 @@
# frozen_string_literal: true
require "rails_helper"
require "webmock/rspec"
RSpec.describe DiscourseAi::Inference::CloudflareWorkersAi do
subject { described_class.new(account_id, api_token, model) }
let(:account_id) { "test_account_id" }
let(:api_token) { "test_api_token" }
let(:model) { "test_model" }
let(:content) { "test content" }
let(:endpoint) do
"https://api.cloudflare.com/client/v4/accounts/#{account_id}/ai/run/@cf/#{model}"
end
let(:headers) do
{
"Referer" => Discourse.base_url,
"Content-Type" => "application/json",
"Authorization" => "Bearer #{api_token}",
}
end
let(:payload) { { text: [content] }.to_json }
before do
stub_request(:post, endpoint).with(body: payload, headers: headers).to_return(
status: response_status,
body: response_body,
)
end
describe "#perform!" do
context "when the response status is 200" do
let(:response_status) { 200 }
let(:response_body) { { result: { data: ["embedding_result"] } }.to_json }
it "returns the embedding result" do
result = subject.perform!(content)
expect(result).to eq("embedding_result")
end
end
context "when the response status is 429" do
let(:response_status) { 429 }
let(:response_body) { "" }
it "doesn't raises a Net::HTTPBadResponse error" do
expect { subject.perform!(content) }.not_to raise_error
end
end
context "when the response status is not 200 or 429" do
let(:response_status) { 500 }
let(:response_body) { "Internal Server Error" }
it "raises a Net::HTTPBadResponse error" do
allow(Rails.logger).to receive(:warn)
expect { subject.perform!(content) }.to raise_error(Net::HTTPBadResponse)
expect(Rails.logger).to have_received(:warn).with(
"Cloudflare Workers AI Embeddings failed with status: #{response_status} body: #{response_body}",
)
end
end
end
end