Commit 1d5e32e8 authored by Stan Hu's avatar Stan Hu

Merge branch '338707-csv-export-bugs' into 'master'

Fix group membership CSV export for invited users

See merge request gitlab-org/gitlab!69065
parents 512be817 732b8b8c
...@@ -21,8 +21,8 @@ module Groups ...@@ -21,8 +21,8 @@ module Groups
def header_to_value_hash def header_to_value_hash
{ {
'Username' => 'user_username', 'Username' => -> (member) { member&.user&.username },
'Name' => 'user_name', 'Name' => -> (member) { member&.user&.name },
'Access granted' => -> (member) { member.created_at.to_s(:csv) }, 'Access granted' => -> (member) { member.created_at.to_s(:csv) },
'Access expires' => -> (member) { member.expires_at }, 'Access expires' => -> (member) { member.expires_at },
'Max role' => 'human_access', 'Max role' => 'human_access',
......
...@@ -16,10 +16,6 @@ module Groups ...@@ -16,10 +16,6 @@ module Groups
@response = Groups::Memberships::ExportService.new(container: @group, current_user: @current_user).execute @response = Groups::Memberships::ExportService.new(container: @group, current_user: @current_user).execute
send_email if @response.success? send_email if @response.success?
rescue Module::DelegationError => exception
# TEMPORARY: Rescue when a User record is not available,
# see https://gitlab.com/gitlab-org/gitlab/-/issues/338707
Raven.capture_exception(exception, tags: { group_id: @group.id, user_id: @current_user.id })
end end
private private
......
...@@ -89,6 +89,10 @@ RSpec.describe Groups::Memberships::ExportService do ...@@ -89,6 +89,10 @@ RSpec.describe Groups::Memberships::ExportService do
before do before do
create_list(:group_member, 4, group: group) create_list(:group_member, 4, group: group)
create(:group_member, group: group, created_at: '2021-02-01', expires_at: '2022-01-01', user: create(:user, username: 'mwoolf', name: 'Max Woolf')) create(:group_member, group: group, created_at: '2021-02-01', expires_at: '2022-01-01', user: create(:user, username: 'mwoolf', name: 'Max Woolf'))
create(:group_member, :invited, group: group)
create(:group_member, :ldap, group: group)
create(:group_member, :blocked, group: group)
create(:group_member, :minimal_access, group: group)
end end
let(:csv) { CSV.parse(service.execute.payload, headers: true) } let(:csv) { CSV.parse(service.execute.payload, headers: true) }
...@@ -97,7 +101,7 @@ RSpec.describe Groups::Memberships::ExportService do ...@@ -97,7 +101,7 @@ RSpec.describe Groups::Memberships::ExportService do
end end
it 'has the correct number of rows' do it 'has the correct number of rows' do
expect(csv.size).to eq(6) expect(csv.size).to eq(9)
end end
context 'a direct user', :aggregate_failures do context 'a direct user', :aggregate_failures do
......
...@@ -19,18 +19,4 @@ RSpec.describe Groups::ExportMembershipsWorker do ...@@ -19,18 +19,4 @@ RSpec.describe Groups::ExportMembershipsWorker do
worker.perform(group.id, user.id) worker.perform(group.id, user.id)
end end
context 'when there is a Module::DelegationError' do
before do
allow_next_instance_of(Groups::Memberships::ExportService) do |service|
allow(service).to receive(:execute).and_raise(Module::DelegationError)
end
end
it 'rescues the exception' do
expect(Notify).not_to receive(:memberships_export_email)
expect(Raven).to receive(:capture_exception).and_call_original
worker.perform(group.id, user.id)
end
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