mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 03:02:46 +08:00
BUGFIX: exact username match not correctly prioritized on search
This commit is contained in:
parent
8bf19e244a
commit
198cf851ff
|
@ -6,10 +6,11 @@ class UserSearch
|
||||||
@term_like = "#{term.downcase}%"
|
@term_like = "#{term.downcase}%"
|
||||||
@topic_id = opts[:topic_id]
|
@topic_id = opts[:topic_id]
|
||||||
@searching_user = opts[:searching_user]
|
@searching_user = opts[:searching_user]
|
||||||
|
@limit = opts[:limit] || 20
|
||||||
end
|
end
|
||||||
|
|
||||||
def search
|
def search
|
||||||
users = User.order(User.sql_fragment("CASE WHEN username_lower = ? THEN 0 ELSE 1 END ASC", :term))
|
users = User.order(User.sql_fragment("CASE WHEN username_lower = ? THEN 0 ELSE 1 END ASC", @term.downcase))
|
||||||
|
|
||||||
if @term.present?
|
if @term.present?
|
||||||
if SiteSetting.enable_names?
|
if SiteSetting.enable_names?
|
||||||
|
@ -37,7 +38,7 @@ class UserSearch
|
||||||
end
|
end
|
||||||
|
|
||||||
users.order("CASE WHEN last_seen_at IS NULL THEN 0 ELSE 1 END DESC, last_seen_at DESC, username ASC")
|
users.order("CASE WHEN last_seen_at IS NULL THEN 0 ELSE 1 END DESC, last_seen_at DESC, username ASC")
|
||||||
.limit(20)
|
.limit(@limit)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -5,12 +5,12 @@ describe UserSearch do
|
||||||
let(:topic) { Fabricate :topic }
|
let(:topic) { Fabricate :topic }
|
||||||
let(:topic2) { Fabricate :topic }
|
let(:topic2) { Fabricate :topic }
|
||||||
let(:topic3) { Fabricate :topic }
|
let(:topic3) { Fabricate :topic }
|
||||||
let(:user1) { Fabricate :user, username: "mrblonde", name: "Michael Madsen" }
|
let(:user1) { Fabricate :user, username: "mrb", name: "Michael Madsen", last_seen_at: 10.days.ago }
|
||||||
let(:user2) { Fabricate :user, username: "mrblue", name: "Eddie Bunker" }
|
let(:user2) { Fabricate :user, username: "mrblue", name: "Eddie Bunker", last_seen_at: 9.days.ago }
|
||||||
let(:user3) { Fabricate :user, username: "mrorange", name: "Tim Roth" }
|
let(:user3) { Fabricate :user, username: "mrorange", name: "Tim Roth", last_seen_at: 8.days.ago }
|
||||||
let(:user4) { Fabricate :user, username: "mrpink", name: "Steve Buscemi" }
|
let(:user4) { Fabricate :user, username: "mrpink", name: "Steve Buscemi", last_seen_at: 7.days.ago }
|
||||||
let(:user5) { Fabricate :user, username: "mrbrown", name: "Quentin Tarantino" }
|
let(:user5) { Fabricate :user, username: "mrbrown", name: "Quentin Tarantino", last_seen_at: 6.days.ago }
|
||||||
let(:user6) { Fabricate :user, username: "mrwhite", name: "Harvey Keitel" }
|
let(:user6) { Fabricate :user, username: "mrwhite", name: "Harvey Keitel", last_seen_at: 5.days.ago }
|
||||||
let(:admin) { Fabricate :admin, username: "theadmin" }
|
let(:admin) { Fabricate :admin, username: "theadmin" }
|
||||||
let(:moderator) { Fabricate :moderator, username: "themod" }
|
let(:moderator) { Fabricate :moderator, username: "themod" }
|
||||||
|
|
||||||
|
@ -70,8 +70,8 @@ describe UserSearch do
|
||||||
results = search_for("MR", searching_user: admin)
|
results = search_for("MR", searching_user: admin)
|
||||||
results.size.should == 6
|
results.size.should == 6
|
||||||
|
|
||||||
results = search_for("MRB", searching_user: admin)
|
results = search_for("MRB", searching_user: admin, limit: 2)
|
||||||
results.size.should == 3
|
results.size.should == 2
|
||||||
|
|
||||||
# topic priority
|
# topic priority
|
||||||
results = search_for("mrb", topic_id: topic.id)
|
results = search_for("mrb", topic_id: topic.id)
|
||||||
|
@ -79,21 +79,26 @@ describe UserSearch do
|
||||||
|
|
||||||
|
|
||||||
results = search_for("mrb", topic_id: topic2.id)
|
results = search_for("mrb", topic_id: topic2.id)
|
||||||
results.first.should == user2
|
results[1].should == user2
|
||||||
|
|
||||||
results = search_for("mrb", topic_id: topic3.id)
|
results = search_for("mrb", topic_id: topic3.id)
|
||||||
results.first.should == user5
|
results[1].should == user5
|
||||||
|
|
||||||
# When searching by name is enabled, it returns the record
|
# When searching by name is enabled, it returns the record
|
||||||
SiteSetting.stubs(:enable_names).returns(true)
|
SiteSetting.enable_names = true
|
||||||
results = search_for("Tarantino")
|
results = search_for("Tarantino")
|
||||||
results.size.should == 1
|
results.size.should == 1
|
||||||
|
|
||||||
# When searching by name is disabled, it will not return the record
|
# When searching by name is disabled, it will not return the record
|
||||||
SiteSetting.stubs(:enable_names).returns(false)
|
SiteSetting.enable_names = false
|
||||||
results = search_for("Tarantino")
|
results = search_for("Tarantino")
|
||||||
results.size.should == 0
|
results.size.should == 0
|
||||||
|
|
||||||
|
|
||||||
|
# find an exact match first
|
||||||
|
results = search_for("mrB")
|
||||||
|
results.first.should == user1
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue
Block a user