commit
d6d3f74405
|
@ -1,35 +1,24 @@
|
||||||
class AvatarLookup
|
class AvatarLookup
|
||||||
|
attr_accessor :user_ids, :users
|
||||||
|
|
||||||
def initialize(user_ids)
|
def initialize(user_ids=[])
|
||||||
@user_ids = user_ids
|
self.user_ids = AvatarLookup.filtered_users(user_ids)
|
||||||
|
|
||||||
@user_ids.flatten!
|
|
||||||
@user_ids.compact! if @user_ids.present?
|
|
||||||
@user_ids.uniq! if @user_ids.present?
|
|
||||||
|
|
||||||
@loaded = false
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Lookup a user by id
|
# Lookup a user by id
|
||||||
def [](user_id)
|
def [](user_id)
|
||||||
ensure_loaded!
|
self.users = AvatarLookup.hashed_users(user_ids) if self.users.nil?
|
||||||
@users_hashed[user_id]
|
self.users[user_id]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
private
|
||||||
protected
|
def self.filtered_users(user_ids=[])
|
||||||
|
user_ids.flatten.tap(&:compact!).tap(&:uniq!)
|
||||||
def ensure_loaded!
|
|
||||||
return if @loaded
|
|
||||||
|
|
||||||
@users_hashed = {}
|
|
||||||
# need email for hash
|
|
||||||
User.where(id: @user_ids).select([:id, :email, :email, :username]).each do |u|
|
|
||||||
@users_hashed[u.id] = u
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@loaded = true
|
def self.hashed_users(user_ids=[])
|
||||||
|
users = User.where(:id => user_ids).select([:id, :email, :username])
|
||||||
|
users_with_ids = users.collect {|x| [x.id, x] }.flatten
|
||||||
|
Hash[*users_with_ids]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,78 @@
|
||||||
|
# encoding: utf-8
|
||||||
|
|
||||||
|
require 'spec_helper'
|
||||||
|
require 'avatar_lookup'
|
||||||
|
|
||||||
|
describe AvatarLookup do
|
||||||
|
let!(:user){ Fabricate(:user) }
|
||||||
|
user_ids = [1, 2]
|
||||||
|
|
||||||
|
describe '#new' do
|
||||||
|
before do
|
||||||
|
AvatarLookup.stubs(:filtered_users).once.returns(user_ids)
|
||||||
|
@avatar_lookup = AvatarLookup.new
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'init with cleaned user ids' do
|
||||||
|
@avatar_lookup.user_ids.should eq(user_ids)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'init users hash' do
|
||||||
|
@avatar_lookup.users.should eq(nil)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe '#[]' do
|
||||||
|
before do
|
||||||
|
@avatar_lookup = AvatarLookup.new([user.id])
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns nil if user_id does not exists' do
|
||||||
|
@avatar_lookup[0].should be_nil
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns nil if user_id is nil' do
|
||||||
|
@avatar_lookup[nil].should be_nil
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns user if user_id exists' do
|
||||||
|
@avatar_lookup[user.id].should eq(user)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe '.filtered_users' do
|
||||||
|
it 'returns empty array if no params' do
|
||||||
|
AvatarLookup.filtered_users.should eq([])
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns empty array' do
|
||||||
|
AvatarLookup.filtered_users([]).should eq([])
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns filtered ids' do
|
||||||
|
AvatarLookup.filtered_users(user_ids).should eq(user_ids)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns flatten filtered ids' do
|
||||||
|
AvatarLookup.filtered_users([1, [2]]).should eq(user_ids)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns compact filtered ids' do
|
||||||
|
AvatarLookup.filtered_users([1, 2, nil]).should eq(user_ids)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns uniq filtered ids' do
|
||||||
|
AvatarLookup.filtered_users([1, 2, 2]).should eq(user_ids)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe '.hashed_users' do
|
||||||
|
it 'returns empty hash if no params' do
|
||||||
|
AvatarLookup.hashed_users.should eq({})
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns hashed users by id' do
|
||||||
|
AvatarLookup.hashed_users([user.id]).should eq({user.id => user})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue