27 lines
881 B
Ruby
27 lines
881 B
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
require 'spec_helper'
|
||
|
|
||
|
describe AuditEventService do
|
||
|
let(:project) { create(:project) }
|
||
|
let(:user) { create(:user) }
|
||
|
let(:project_member) { create(:project_member, user: user) }
|
||
|
let(:service) { described_class.new(user, project, { action: :destroy }) }
|
||
|
let(:logger) { instance_double(Gitlab::AuditJsonLogger) }
|
||
|
|
||
|
describe '#security_event' do
|
||
|
before do
|
||
|
expect(service).to receive(:file_logger).and_return(logger)
|
||
|
end
|
||
|
|
||
|
it 'creates an event and logs to a file' do
|
||
|
expect(logger).to receive(:info).with(author_id: user.id,
|
||
|
entity_id: project.id,
|
||
|
entity_type: "Project",
|
||
|
action: :destroy)
|
||
|
|
||
|
expect { service.security_event }.to change(SecurityEvent, :count).by(1)
|
||
|
end
|
||
|
end
|
||
|
end
|