Welcome to mirror list, hosted at ThFree Co, Russian Federation.

runner_version_spec.rb « ci « models « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 32f840a80340193cef0db5a05593faab455e33f7 (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Ci::RunnerVersion, feature_category: :fleet_visibility do
  let_it_be(:runner_version_upgrade_recommended) do
    create(:ci_runner_version, version: 'abc234', status: :recommended)
  end

  let_it_be(:runner_version_upgrade_unavailable) do
    create(:ci_runner_version, version: 'abc123', status: :unavailable)
  end

  it { is_expected.to have_many(:runner_managers).with_foreign_key(:version) }

  it_behaves_like 'having unique enum values'

  describe '.unavailable' do
    subject { described_class.unavailable }

    it { is_expected.to match_array([runner_version_upgrade_unavailable]) }
  end

  describe '.potentially_outdated' do
    subject { described_class.potentially_outdated }

    let_it_be(:runner_version_nil) { create(:ci_runner_version, version: 'abc345', status: nil) }
    let_it_be(:runner_version_upgrade_available) do
      create(:ci_runner_version, version: 'abc456', status: :available)
    end

    it 'contains any valid or unprocessed runner version that is not already recommended' do
      is_expected.to match_array(
        [runner_version_nil, runner_version_upgrade_unavailable, runner_version_upgrade_available]
      )
    end
  end

  describe 'validation' do
    it { is_expected.to validate_length_of(:version).is_at_most(2048) }
  end

  describe '#status' do
    context 'when is not processed' do
      subject(:ci_runner_version) { create(:ci_runner_version, version: 'abc124', status: :not_processed) }

      let(:attr) { :status }
      let(:attr_value) { :not_processed }

      it_behaves_like 'having enum with nil value'
    end
  end
end