FIX: Tag ordering adjustment for new hashtag autocompletion (#19120)

The tag ordering was inconsistent, because we were not
passing the correct order option to DiscourseTagging.filter_allowed_tags.
The order would change based on the limit provided. Now,
we can have a consistent order which is term exact match -> topic count ->
name.
This commit is contained in:
Martin Brennan 2022-11-21 16:40:15 +10:00 committed by GitHub
parent a8eb607162
commit 3dcf158b56
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 54 additions and 1 deletions

View File

@ -41,6 +41,7 @@ class TagHashtagDataSource
with_context: true, with_context: true,
limit: limit, limit: limit,
for_input: true, for_input: true,
order_search_results: true,
) )
TagsController TagsController
.tag_counts_json(tags_with_counts) .tag_counts_json(tags_with_counts)

View File

@ -169,10 +169,17 @@ RSpec.describe HashtagAutocompleteService do
fab!(:category3) { Fabricate(:category, name: "Book Dome", slug: "book-dome") } fab!(:category3) { Fabricate(:category, name: "Book Dome", slug: "book-dome") }
fab!(:tag2) { Fabricate(:tag, name: "mid-books") } fab!(:tag2) { Fabricate(:tag, name: "mid-books") }
fab!(:tag3) { Fabricate(:tag, name: "terrible-books") } fab!(:tag3) { Fabricate(:tag, name: "terrible-books") }
fab!(:tag4) { Fabricate(:tag, name: "book") }
it "orders them by name within their type order" do it "orders them by name within their type order" do
expect(subject.search("book", %w[category tag], limit: 10).map(&:ref)).to eq( expect(subject.search("book", %w[category tag], limit: 10).map(&:ref)).to eq(
%w[book-club book-dome book-zone great-books mid-books terrible-books], %w[book-club book-dome book-zone book great-books mid-books terrible-books],
)
end
it "orders correctly with lower limits" do
expect(subject.search("book", %w[category tag], limit: 5).map(&:ref)).to eq(
%w[book-club book-dome book-zone book great-books],
) )
end end
end end

View File

@ -0,0 +1,45 @@
# frozen_string_literal: true
RSpec.describe TagHashtagDataSource do
fab!(:tag1) { Fabricate(:tag, name: "fact") }
fab!(:tag2) { Fabricate(:tag, name: "factor", topic_count: 5) }
fab!(:tag3) { Fabricate(:tag, name: "factory", topic_count: 1) }
fab!(:tag4) { Fabricate(:tag, name: "factorio") }
fab!(:tag5) { Fabricate(:tag, name: "factz") }
fab!(:user) { Fabricate(:user) }
let(:guardian) { Guardian.new(user) }
describe "#search" do
it "orders tag results by exact search match, then topic count, then name" do
expect(described_class.search(guardian, "fact", 5).map(&:slug)).to eq(
%w[fact factor factory factorio factz],
)
end
it "does not get more than the limit" do
expect(described_class.search(guardian, "fact", 1).map(&:slug)).to eq(%w[fact])
end
it "does not get tags that the user does not have permission to see" do
Fabricate(:tag_group, permissions: { "staff" => 1 }, tag_names: ["fact"])
expect(described_class.search(guardian, "fact", 5).map(&:slug)).not_to include("fact")
end
it "returns an array of HashtagAutocompleteService::HashtagItem" do
expect(described_class.search(guardian, "fact", 1).first).to be_a(
HashtagAutocompleteService::HashtagItem,
)
end
it "includes the topic count for the text of the tag" do
expect(described_class.search(guardian, "fact", 5).map(&:text)).to eq(
["fact x 0", "factor x 5", "factory x 1", "factorio x 0", "factz x 0"],
)
end
it "returns nothing if tagging is not enabled" do
SiteSetting.tagging_enabled = false
expect(described_class.search(guardian, "fact", 5)).to be_empty
end
end
end