summaryrefslogtreecommitdiff
path: root/spec/services/clusters/agents/create_activity_event_service_spec.rb
blob: 3da8ecddb8df2d33dd3ed259570f55287a1daec3 (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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Clusters::Agents::CreateActivityEventService, feature_category: :kubernetes_management do
  let_it_be(:agent) { create(:cluster_agent) }
  let_it_be(:token) { create(:cluster_agent_token, agent: agent) }
  let_it_be(:user) { create(:user) }

  describe '#execute' do
    let(:params) do
      {
        kind: :token_created,
        level: :info,
        recorded_at: token.created_at,
        user: user,
        agent_token: token
      }
    end

    subject { described_class.new(agent, **params).execute }

    it 'creates an activity event record' do
      expect { subject }.to change(agent.activity_events, :count).from(0).to(1)

      event = agent.activity_events.last

      expect(event).to have_attributes(
        kind: 'token_created',
        level: 'info',
        recorded_at: token.reload.created_at,
        user: user,
        agent_token_id: token.id
      )
    end

    it 'schedules the cleanup worker' do
      expect(Clusters::Agents::DeleteExpiredEventsWorker).to receive(:perform_at)
        .with(1.hour.from_now.change(min: agent.id % 60), agent.id)

      subject
    end

    context 'when activity event creation fails' do
      let(:params) { {} }

      it 'tracks the exception without raising' do
        expect(Gitlab::ErrorTracking).to receive(:track_exception)
          .with(instance_of(ActiveRecord::RecordInvalid), agent_id: agent.id)

        subject
      end
    end
  end
end