Commit e726ed5e authored by Camil Staps's avatar Camil Staps

Handle reviewer comments on !24690

parent d2b2486a
......@@ -2,8 +2,10 @@
class StarredProjectsFinder < ProjectsFinder
def initialize(user, params: {}, current_user: nil)
project_ids = user.starred_projects.select(:id)
super(params: params, current_user: current_user, project_ids_relation: project_ids)
super(
params: params,
current_user: current_user,
project_ids_relation: user.starred_projects.select(:id)
)
end
end
......@@ -12,7 +12,7 @@ class UsersStarProjectsFinder
end
def execute
stars = UsersStarProject.all.order_id_desc
stars = UsersStarProject.all
stars = by_project(stars)
stars = by_search(stars)
stars = filter_visible_profiles(stars)
......
......@@ -282,15 +282,17 @@ class User < ApplicationRecord
scope :for_todos, -> (todos) { where(id: todos.select(:user_id)) }
scope :with_emails, -> { preload(:emails) }
scope :with_dashboard, -> (dashboard) { where(dashboard: dashboard) }
scope :with_visible_profile, -> (user) {
if user.nil?
where(private_profile: false)
elsif user.admin?
scope :with_public_profile, -> { where(private_profile: false) }
def self.with_visible_profile(user)
return with_public_profile if user.nil?
if user.admin?
all
else
where(private_profile: false).or where(id: user.id)
with_public_profile.or(where(id: user.id))
end
}
end
# Limits the users to those that have TODOs, optionally in the given state.
#
......
......@@ -12,8 +12,8 @@ class UsersStarProject < ApplicationRecord
alias_attribute :starred_since, :created_at
scope :order_user_name_asc, -> { joins(:user).reorder('users.name ASC') }
scope :order_user_name_desc, -> { joins(:user).reorder('users.name DESC') }
scope :order_user_name_asc, -> { joins(:user).merge(User.order_name_asc) }
scope :order_user_name_desc, -> { joins(:user).merge(User.order_name_desc) }
scope :by_project, -> (project) { where(project_id: project.id) }
scope :with_visible_profile, -> (user) { joins(:user).merge(User.with_visible_profile(user)) }
......
# frozen_string_literal: true
require 'spec_helper'
describe Projects::StarrersController do
......
# frozen_string_literal: true
require 'spec_helper'
describe StarredProjectsFinder do
......@@ -21,19 +23,19 @@ describe StarredProjectsFinder do
describe 'as same user' do
let(:current_user) { user }
it { is_expected.to eq([project2, project1]) }
it { is_expected.to contain_exactly(project1, project2) }
end
describe 'as other user' do
let(:current_user) { other_user }
it { is_expected.to eq([project2, project1]) }
it { is_expected.to contain_exactly(project1, project2) }
end
describe 'as no user' do
let(:current_user) { nil }
it { is_expected.to eq([project2, project1]) }
it { is_expected.to contain_exactly(project1, project2) }
end
end
end
# frozen_string_literal: true
require 'spec_helper'
describe UsersStarProjectsFinder do
......@@ -22,19 +24,19 @@ describe UsersStarProjectsFinder do
describe 'as same user' do
let(:current_user) { private_user }
it { is_expected.to eq(private_stars + public_stars) }
it { is_expected.to match_array(private_stars + public_stars) }
end
describe 'as other user' do
let(:current_user) { other_user }
it { is_expected.to eq(public_stars) }
it { is_expected.to match_array(public_stars) }
end
describe 'as no user' do
let(:current_user) { nil }
it { is_expected.to eq(public_stars) }
it { is_expected.to match_array(public_stars) }
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment