mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 02:52:44 +08:00
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:
parent
a8eb607162
commit
3dcf158b56
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
45
spec/services/tag_hashtag_data_source.rb
Normal file
45
spec/services/tag_hashtag_data_source.rb
Normal 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
|
Loading…
Reference in New Issue
Block a user