discourse/plugins/discourse-ai/spec/lib/utils/pdf_to_text_spec.rb

68 lines
2.2 KiB
Ruby
Vendored

# frozen_string_literal: true
RSpec.describe DiscourseAi::Utils::PdfToText do
fab!(:llm_model)
fab!(:user)
let(:pdf) { plugin_file_from_fixtures("2-page.pdf", "rag") }
let(:upload) { UploadCreator.new(pdf, "2-page.pdf").create_for(Discourse.system_user.id) }
before do
enable_current_plugin
SiteSetting.authorized_extensions = "pdf|png|jpg|jpeg"
end
describe "#extract_text" do
it "extracts text from PDF pages" do
pdf_to_text = described_class.new(upload: upload)
pages = []
pdf_to_text.extract_text { |page| pages << page }
expect(pages).to eq(["Page 1", "Page 2"])
end
end
context "when improving PDF extraction with LLM" do
def imagemagick_with_ghostscript?
system("magick", "-version", out: File::NULL, err: File::NULL) &&
system("gs", "--version", out: File::NULL, err: File::NULL)
end
it "can properly simulate a file" do
skip "Requires imagemagick with ghostscript support" unless imagemagick_with_ghostscript?
responses = [
"<chunk>Page 1: LLM chunk 1</chunk><chunk>Page 1: LLM chunk 2</chunk>",
"<chunk>Page 2: LLM chunk 3</chunk>",
]
pages = []
DiscourseAi::Completions::Llm.with_prepared_responses(responses) do |_, _, _prompts|
file = described_class.as_fake_file(upload: upload, user: user, llm_model: llm_model)
while content = file.read(100_000)
pages << content
end
end
expect(pages).to eq(["Page 1: LLM chunk 1", "Page 1: LLM chunk 2", "Page 2: LLM chunk 3"])
end
it "works as expected" do
skip "Requires imagemagick with ghostscript support" unless imagemagick_with_ghostscript?
pdf_to_text = described_class.new(upload: upload, user: user, llm_model: llm_model)
pages = []
responses = [
"<chunk>Page 1: LLM chunk 1</chunk><chunk>Page 1: LLM chunk 2</chunk>",
"<chunk>Page 2: LLM chunk 3</chunk>",
]
DiscourseAi::Completions::Llm.with_prepared_responses(responses) do |_, _, _prompts|
pdf_to_text.extract_text { |page| pages << page }
end
expect(pages).to eq(["Page 1: LLM chunk 1", "Page 1: LLM chunk 2", "Page 2: LLM chunk 3"])
end
end
end