2023-04-19 10:55:59 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require "rails_helper"
|
|
|
|
|
2023-05-15 14:10:42 -04:00
|
|
|
describe DiscourseAi::Tokenizer::BertTokenizer do
|
2023-04-19 10:55:59 -04:00
|
|
|
describe "#size" do
|
|
|
|
describe "returns a token count" do
|
|
|
|
it "for a single word" do
|
2023-05-15 14:10:42 -04:00
|
|
|
expect(described_class.size("hello")).to eq(3)
|
2023-04-19 10:55:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "for a sentence" do
|
2023-05-15 14:10:42 -04:00
|
|
|
expect(described_class.size("hello world")).to eq(4)
|
2023-04-19 10:55:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "for a sentence with punctuation" do
|
2023-05-15 14:10:42 -04:00
|
|
|
expect(described_class.size("hello, world!")).to eq(6)
|
2023-04-19 10:55:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "for a sentence with punctuation and capitalization" do
|
2023-05-15 14:10:42 -04:00
|
|
|
expect(described_class.size("Hello, World!")).to eq(6)
|
2023-04-19 10:55:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "for a sentence with punctuation and capitalization and numbers" do
|
2023-05-15 14:10:42 -04:00
|
|
|
expect(described_class.size("Hello, World! 123")).to eq(7)
|
2023-04-19 10:55:59 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#tokenizer" do
|
|
|
|
it "returns a tokenizer" do
|
2023-05-15 14:10:42 -04:00
|
|
|
expect(described_class.tokenizer).to be_a(Tokenizers::Tokenizer)
|
2023-04-19 10:55:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "returns the same tokenizer" do
|
2023-05-15 14:10:42 -04:00
|
|
|
expect(described_class.tokenizer).to eq(described_class.tokenizer)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#truncate" do
|
|
|
|
it "truncates a sentence" do
|
|
|
|
sentence = "foo bar baz qux quux corge grault garply waldo fred plugh xyzzy thud"
|
|
|
|
expect(described_class.truncate(sentence, 3)).to eq("foo bar")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe DiscourseAi::Tokenizer::AnthropicTokenizer do
|
|
|
|
describe "#size" do
|
|
|
|
describe "returns a token count" do
|
|
|
|
it "for a sentence with punctuation and capitalization and numbers" do
|
|
|
|
expect(described_class.size("Hello, World! 123")).to eq(5)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#truncate" do
|
|
|
|
it "truncates a sentence" do
|
|
|
|
sentence = "foo bar baz qux quux corge grault garply waldo fred plugh xyzzy thud"
|
|
|
|
expect(described_class.truncate(sentence, 3)).to eq("foo bar baz")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe DiscourseAi::Tokenizer::OpenAiTokenizer do
|
|
|
|
describe "#size" do
|
|
|
|
describe "returns a token count" do
|
|
|
|
it "for a sentence with punctuation and capitalization and numbers" do
|
|
|
|
expect(described_class.size("Hello, World! 123")).to eq(6)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#truncate" do
|
|
|
|
it "truncates a sentence" do
|
|
|
|
sentence = "foo bar baz qux quux corge grault garply waldo fred plugh xyzzy thud"
|
|
|
|
expect(described_class.truncate(sentence, 3)).to eq("foo bar baz")
|
2023-04-19 10:55:59 -04:00
|
|
|
end
|
2023-06-16 14:15:36 -04:00
|
|
|
|
|
|
|
it "truncates a sentence successfully at a multibyte unicode character" do
|
|
|
|
sentence = "foo bar 👨🏿👩🏿👧🏿👧🏿 baz qux quux corge grault garply waldo fred plugh xyzzy thud"
|
|
|
|
expect(described_class.truncate(sentence, 7)).to eq("foo bar 👨🏿")
|
|
|
|
end
|
2023-04-19 10:55:59 -04:00
|
|
|
end
|
|
|
|
end
|