FIX: only count 'human' users in group.user_count

This commit is contained in:
Régis Hanol 2018-01-31 21:55:01 +01:00
parent 826584b9c1
commit 4bcf9c5bf3
2 changed files with 17 additions and 20 deletions

View File

@ -281,13 +281,13 @@ class Group < ActiveRecord::Base
remove_subquery = remove_subquery =
case name case name
when :admins when :admins
"SELECT id FROM users WHERE NOT admin" "SELECT id FROM users WHERE id <= 0 OR NOT admin"
when :moderators when :moderators
"SELECT id FROM users WHERE NOT moderator" "SELECT id FROM users WHERE id <= 0 OR NOT moderator"
when :staff when :staff
"SELECT id FROM users WHERE NOT admin AND NOT moderator" "SELECT id FROM users WHERE id <= 0 OR (NOT admin AND NOT moderator)"
when :trust_level_0, :trust_level_1, :trust_level_2, :trust_level_3, :trust_level_4 when :trust_level_0, :trust_level_1, :trust_level_2, :trust_level_3, :trust_level_4
"SELECT id FROM users WHERE trust_level < #{id - 10}" "SELECT id FROM users WHERE id <= 0 OR trust_level < #{id - 10}"
end end
exec_sql <<-SQL exec_sql <<-SQL
@ -301,15 +301,15 @@ class Group < ActiveRecord::Base
insert_subquery = insert_subquery =
case name case name
when :admins when :admins
"SELECT id FROM users WHERE admin" "SELECT id FROM users WHERE id > 0 AND admin"
when :moderators when :moderators
"SELECT id FROM users WHERE moderator" "SELECT id FROM users WHERE id > 0 AND moderator"
when :staff when :staff
"SELECT id FROM users WHERE moderator OR admin" "SELECT id FROM users WHERE id > 0 AND (moderator OR admin)"
when :trust_level_1, :trust_level_2, :trust_level_3, :trust_level_4 when :trust_level_1, :trust_level_2, :trust_level_3, :trust_level_4
"SELECT id FROM users WHERE trust_level >= #{id - 10}" "SELECT id FROM users WHERE id > 0 AND trust_level >= #{id - 10}"
when :trust_level_0 when :trust_level_0
"SELECT id FROM users" "SELECT id FROM users WHERE id > 0"
end end
exec_sql <<-SQL exec_sql <<-SQL

View File

@ -338,7 +338,7 @@ describe Group do
user2 = Fabricate(:coding_horror) user2 = Fabricate(:coding_horror)
user2.change_trust_level!(TrustLevel[3]) user2.change_trust_level!(TrustLevel[3])
expect(Group[:trust_level_2].user_ids.sort.reject { |id| id < -1 }).to eq [-1, user.id, user2.id].sort expect(Group[:trust_level_2].user_ids).to include(user.id, user2.id)
end end
it "Correctly updates all automatic groups upon request" do it "Correctly updates all automatic groups upon request" do
@ -346,7 +346,7 @@ describe Group do
user = Fabricate(:user) user = Fabricate(:user)
user.change_trust_level!(TrustLevel[2]) user.change_trust_level!(TrustLevel[2])
Group.exec_sql("update groups set user_count=0 where id = #{Group::AUTO_GROUPS[:trust_level_2]}") Group.exec_sql("UPDATE groups SET user_count = 0 WHERE id = #{Group::AUTO_GROUPS[:trust_level_2]}")
Group.refresh_automatic_groups! Group.refresh_automatic_groups!
@ -354,23 +354,20 @@ describe Group do
expect(groups.count).to eq Group::AUTO_GROUPS.count expect(groups.count).to eq Group::AUTO_GROUPS.count
g = groups.find { |grp| grp.id == Group::AUTO_GROUPS[:admins] } g = groups.find { |grp| grp.id == Group::AUTO_GROUPS[:admins] }
expect(g.users.count).to eq(g.user_count) expect(g.users.count).to eq g.user_count
expect(g.users.pluck(:id).sort.reject { |id| id < -1 }).to eq([-1, admin.id]) expect(g.users.pluck(:id)).to contain_exactly(admin.id)
g = groups.find { |grp| grp.id == Group::AUTO_GROUPS[:staff] } g = groups.find { |grp| grp.id == Group::AUTO_GROUPS[:staff] }
expect(g.users.count).to eq (g.user_count) expect(g.users.count).to eq g.user_count
expect(g.users.pluck(:id).sort.reject { |id| id < -1 }).to eq([-1, admin.id]) expect(g.users.pluck(:id)).to contain_exactly(admin.id)
g = groups.find { |grp| grp.id == Group::AUTO_GROUPS[:trust_level_1] } g = groups.find { |grp| grp.id == Group::AUTO_GROUPS[:trust_level_1] }
# admin, system and user
expect(g.users.count).to eq g.user_count expect(g.users.count).to eq g.user_count
expect(g.users.where('users.id > -2').count).to eq 3 expect(g.users.pluck(:id)).to contain_exactly(admin.id, user.id)
g = groups.find { |grp| grp.id == Group::AUTO_GROUPS[:trust_level_2] } g = groups.find { |grp| grp.id == Group::AUTO_GROUPS[:trust_level_2] }
# system and user
expect(g.users.count).to eq g.user_count expect(g.users.count).to eq g.user_count
expect(g.users.where('users.id > -2').count).to eq 2 expect(g.users.pluck(:id)).to contain_exactly(user.id)
end end
it "can set members via usernames helper" do it "can set members via usernames helper" do