discourse/spec/models/user_search_spec.rb

117 lines
3.7 KiB
Ruby

require 'spec_helper'
describe UserSearch do
let(:topic) { Fabricate :topic }
let(:topic2) { Fabricate :topic }
let(:topic3) { Fabricate :topic }
let(:user1) { Fabricate :user, username: "mrb", name: "Michael Madsen", last_seen_at: 10.days.ago }
let(:user2) { Fabricate :user, username: "mrblue", name: "Eddie Code", last_seen_at: 9.days.ago }
let(:user3) { Fabricate :user, username: "mrorange", name: "Tim Roth", last_seen_at: 8.days.ago }
let(:user4) { Fabricate :user, username: "mrpink", name: "Steve Buscemi", last_seen_at: 7.days.ago }
let(:user5) { Fabricate :user, username: "mrbrown", name: "Quentin Tarantino", last_seen_at: 6.days.ago }
let(:user6) { Fabricate :user, username: "mrwhite", name: "Harvey Keitel", last_seen_at: 5.days.ago }
let!(:inactive) { Fabricate :user, username: "Ghost", active: false }
let(:admin) { Fabricate :admin, username: "theadmin" }
let(:moderator) { Fabricate :moderator, username: "themod" }
before do
ActiveRecord::Base.observers.enable :all
Fabricate :post, user: user1, topic: topic
Fabricate :post, user: user2, topic: topic2
Fabricate :post, user: user3, topic: topic
Fabricate :post, user: user4, topic: topic
Fabricate :post, user: user5, topic: topic3
Fabricate :post, user: user6, topic: topic
user6.update_attributes(suspended_at: 1.day.ago, suspended_till: 1.year.from_now)
end
def search_for(*args)
UserSearch.new(*args).search
end
# this is a seriously expensive integration test, re-creating this entire test db is too expensive
# reuse
it "operates correctly" do
# normal search
results = search_for(user1.name.split(" ").first)
results.size.should == 1
results.first.should == user1
# lower case
results = search_for(user1.name.split(" ").first.downcase)
results.size.should == 1
results.first.should == user1
# username
results = search_for(user4.username)
results.size.should == 1
results.first.should == user4
# case insensitive
results = search_for(user4.username.upcase)
results.size.should == 1
results.first.should == user4
# substrings
# only staff members see suspended users in results
results = search_for("mr")
results.size.should == 5
results.should_not include(user6)
search_for("mr", searching_user: user1).size.should == 5
results = search_for("mr", searching_user: admin)
results.size.should == 6
results.should include(user6)
search_for("mr", searching_user: moderator).size.should == 6
results = search_for("mrb", searching_user: admin)
results.size.should == 3
results = search_for("MR", searching_user: admin)
results.size.should == 6
results = search_for("MRB", searching_user: admin, limit: 2)
results.size.should == 2
# topic priority
results = search_for("mrb", topic_id: topic.id)
results.first.should == user1
results = search_for("mrb", topic_id: topic2.id)
results[1].should == user2
results = search_for("mrb", topic_id: topic3.id)
results[1].should == user5
# When searching by name is enabled, it returns the record
SiteSetting.enable_names = true
results = search_for("Tarantino")
results.size.should == 1
results = search_for("coding")
results.size.should == 0
results = search_for("z")
results.size.should == 0
# When searching by name is disabled, it will not return the record
SiteSetting.enable_names = false
results = search_for("Tarantino")
results.size.should == 0
# find an exact match first
results = search_for("mrB")
results.first.should == user1
# don't return inactive users
results = search_for("Ghost")
results.should be_blank
end
end