DEV: Add delegated Group#human_users scope (#25398)

Some preparatory refactoring as we're working on TL groups for the system user. On User we have a scope #human_users to exclude the system user, DiscoBot, etc. This PR adds the same scope (delegated to User) on Group.
This commit is contained in:
Ted Johansson 2024-01-24 13:33:05 +08:00 committed by GitHub
parent 85d74ec8bf
commit 32e2a1fd4a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 21 additions and 24 deletions

View File

@ -24,6 +24,7 @@ class Group < ActiveRecord::Base
has_many :categories, through: :category_groups has_many :categories, through: :category_groups
has_many :users, through: :group_users has_many :users, through: :group_users
has_many :human_users, -> { human_users }, through: :group_users, source: :user
has_many :requesters, through: :group_requests, source: :user has_many :requesters, through: :group_requests, source: :user
has_many :group_histories, dependent: :destroy has_many :group_histories, dependent: :destroy
has_many :category_reviews, has_many :category_reviews,

View File

@ -57,6 +57,14 @@ RSpec.describe Group do
end end
end end
describe ".human_users" do
before { group.users << user << Discourse.system_user }
it "returns only human users" do
expect(group.human_users).to contain_exactly(user)
end
end
describe "#posts_for" do describe "#posts_for" do
it "returns the post in the group" do it "returns the post in the group" do
p = Fabricate(:post) p = Fabricate(:post)
@ -197,18 +205,6 @@ RSpec.describe Group do
end end
end end
def real_admins
Group[:admins].user_ids.reject { |id| id < 0 }
end
def real_moderators
Group[:moderators].user_ids.reject { |id| id < 0 }
end
def real_staff
Group[:staff].user_ids.reject { |id| id < 0 }
end
describe "#primary_group=" do describe "#primary_group=" do
before { group.add(user) } before { group.add(user) }
@ -424,33 +420,33 @@ RSpec.describe Group do
Group.refresh_automatic_groups!(:admins, :staff, :moderators) Group.refresh_automatic_groups!(:admins, :staff, :moderators)
expect(real_admins).to eq [admin.id] expect(Group[:admins].human_users).to contain_exactly(admin)
expect(real_moderators).to eq [moderator.id] expect(Group[:moderators].human_users).to contain_exactly(moderator)
expect(real_staff.sort).to eq [moderator.id, admin.id].sort expect(Group[:staff].human_users).to contain_exactly(moderator, admin)
admin.admin = false admin.admin = false
admin.save admin.save
Group.refresh_automatic_group!(:admins) Group.refresh_automatic_group!(:admins)
expect(real_admins).to be_empty expect(Group[:admins].human_users).to be_empty
moderator.revoke_moderation! moderator.revoke_moderation!
admin.grant_admin! admin.grant_admin!
expect(real_admins).to eq [admin.id] expect(Group[:admins].human_users).to contain_exactly(admin)
expect(real_staff).to eq [admin.id] expect(Group[:staff].human_users).to contain_exactly(admin)
admin.revoke_admin! admin.revoke_admin!
expect(real_admins).to be_empty expect(Group[:admins].human_users).to be_empty
expect(real_staff).to be_empty expect(Group[:staff].human_users).to be_empty
admin.grant_moderation! admin.grant_moderation!
expect(real_moderators).to eq [admin.id] expect(Group[:moderators].human_users).to contain_exactly(admin)
expect(real_staff).to eq [admin.id] expect(Group[:staff].human_users).to contain_exactly(admin)
admin.revoke_moderation! admin.revoke_moderation!
expect(real_admins).to be_empty expect(Group[:admins].human_users).to be_empty
expect(real_staff).to eq [] expect(Group[:staff].human_users).to be_empty
# we need some work to set min username to 6 # we need some work to set min username to 6