summaryrefslogtreecommitdiff
path: root/spec/services/audit_event_service_spec.rb
blob: 32fd98e6ef9712dda7c1ae156752c6935dd87374 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
# 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