FIX: only de-prioritise exact matches in mentions (#11843)

Not when doing a site-wide search like we do in the Directory.

This solves the following specfailure:

  1) DirectoryItemsController with data finds user by name
     Failure/Error: expect(json['directory_items'].length).to eq(1)

       expected: 1
            got: 0

       (compared using ==)
     # ./spec/requests/directory_items_controller_spec.rb:88:in `block (3 levels) in <main>'
     # ./spec/rails_helper.rb:271:in `block (2 levels) in <top (required)>'
     # ./bundle/ruby/2.7.0/gems/webmock-3.11.1/lib/webmock/rspec.rb:37:in `block (2 levels) in <top (required)>'
This commit is contained in:
Régis Hanol 2021-01-25 21:27:15 +01:00 committed by GitHub
parent 27656f5c84
commit f421d9bdd6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 9 additions and 6 deletions

View File

@ -64,11 +64,14 @@ class UserSearch
def search_ids def search_ids
users = Set.new users = Set.new
# 1. exact username matches active in the past year # 1. exact username matches
if @term.present? if @term.present?
scoped_users exact_matches = scoped_users.where(username_lower: @term)
.where(username_lower: @term)
.where('last_seen_at > ?', 1.year.ago) # don't polute mentions with users who haven't shown up in over a year
exact_matches = exact_matches.where('last_seen_at > ?', 1.year.ago) if @topic_id || @category_id
exact_matches
.limit(@limit) .limit(@limit)
.pluck(:id) .pluck(:id)
.each { |id| users << id } .each { |id| users << id }

View File

@ -212,13 +212,13 @@ describe UserSearch do
expect(results).to eq [mr_b, mr_brown, mr_blue].map(&:username) expect(results).to eq [mr_b, mr_brown, mr_blue].map(&:username)
end end
it "doesn't prioritises exact matches for users who haven't been seen in more than 1 year" do it "doesn't prioritises exact matches mentions for users who haven't been seen in over a year" do
abcdef = Fabricate(:user, username: "abcdef", last_seen_at: 2.days.ago) abcdef = Fabricate(:user, username: "abcdef", last_seen_at: 2.days.ago)
abcde = Fabricate(:user, username: "abcde", last_seen_at: 2.weeks.ago) abcde = Fabricate(:user, username: "abcde", last_seen_at: 2.weeks.ago)
abcd = Fabricate(:user, username: "abcd", last_seen_at: 2.months.ago) abcd = Fabricate(:user, username: "abcd", last_seen_at: 2.months.ago)
abc = Fabricate(:user, username: "abc", last_seen_at: 2.years.ago) abc = Fabricate(:user, username: "abc", last_seen_at: 2.years.ago)
results = search_for("abc") results = search_for("abc", topic_id: topic.id)
expect(results).to eq [abcdef, abcde, abcd, abc].map(&:username) expect(results).to eq [abcdef, abcde, abcd, abc].map(&:username)
end end