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

build_spec.rb « data_builder « gitlab « lib « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 544b210651b2c795cbcf11ef3c1b8befdc5baf31 (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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Gitlab::DataBuilder::Build do
  let_it_be(:runner) { create(:ci_runner, :instance, :tagged_only) }
  let_it_be(:user) { create(:user, :public_email) }
  let_it_be(:ci_build) { create(:ci_build, :running, runner: runner, user: user) }

  describe '.build' do
    around do |example|
      travel_to(Time.current) { example.run }
    end

    let(:data) do
      described_class.build(ci_build)
    end

    it { expect(data).to be_a(Hash) }
    it { expect(data[:ref]).to eq(ci_build.ref) }
    it { expect(data[:sha]).to eq(ci_build.sha) }
    it { expect(data[:tag]).to eq(ci_build.tag) }
    it { expect(data[:build_id]).to eq(ci_build.id) }
    it { expect(data[:build_status]).to eq(ci_build.status) }
    it { expect(data[:build_created_at]).to eq(ci_build.created_at) }
    it { expect(data[:build_started_at]).to eq(ci_build.started_at) }
    it { expect(data[:build_finished_at]).to eq(ci_build.finished_at) }
    it { expect(data[:build_duration]).to eq(ci_build.duration) }
    it { expect(data[:build_queued_duration]).to eq(ci_build.queued_duration) }
    it { expect(data[:build_allow_failure]).to eq(false) }
    it { expect(data[:build_failure_reason]).to eq(ci_build.failure_reason) }
    it { expect(data[:project_id]).to eq(ci_build.project.id) }
    it { expect(data[:project_name]).to eq(ci_build.project.full_name) }
    it { expect(data[:pipeline_id]).to eq(ci_build.pipeline.id) }
    it { expect(data[:retries_count]).to eq(ci_build.retries_count) }

    it {
      expect(data[:user]).to eq(
        {
            id: user.id,
            name: user.name,
            username: user.username,
            avatar_url: user.avatar_url(only_path: false),
            email: user.email
            })
    }

    it { expect(data[:commit][:id]).to eq(ci_build.pipeline.id) }
    it { expect(data[:runner][:id]).to eq(ci_build.runner.id) }
    it { expect(data[:runner][:tags]).to match_array(%w(tag1 tag2)) }
    it { expect(data[:runner][:description]).to eq(ci_build.runner.description) }
    it { expect(data[:runner][:runner_type]).to eq(ci_build.runner.runner_type) }
    it { expect(data[:runner][:is_shared]).to eq(ci_build.runner.instance_type?) }
    it { expect(data[:environment]).to be_nil }

    it 'does not exceed number of expected queries' do
      ci_build # Make sure the Ci::Build model is created before recording.

      control = ActiveRecord::QueryRecorder.new(skip_cached: false) do
        b = Ci::Build.find(ci_build.id)
        described_class.build(b) # Don't use ci_build variable here since it has all associations loaded into memory
      end

      expect(control.count).to eq(13)
    end

    context 'when feature flag is disabled' do
      before do
        stub_feature_flags(job_webhook_retries_count: false)
      end

      it { expect(data).not_to have_key(:retries_count) }

      it 'does not exceed number of expected queries' do
        ci_build # Make sure the Ci::Build model is created before recording.

        control = ActiveRecord::QueryRecorder.new(skip_cached: false) do
          b = Ci::Build.find(ci_build.id)
          described_class.build(b) # Don't use ci_build variable here since it has all associations loaded into memory
        end

        expect(control.count).to eq(12)
      end
    end

    context 'commit author_url' do
      context 'when no commit present' do
        let(:build) { build(:ci_build) }

        it 'sets to mailing address of git_author_email' do
          expect(data[:commit][:author_url]).to eq("mailto:#{ci_build.pipeline.git_author_email}")
        end
      end

      context 'when commit present but has no author' do
        let(:ci_build) { build(:ci_build, :with_commit) }

        it 'sets to mailing address of git_author_email' do
          expect(data[:commit][:author_url]).to eq("mailto:#{ci_build.pipeline.git_author_email}")
        end
      end

      context 'when commit and author are present' do
        let(:ci_build) { build(:ci_build, :with_commit_and_author) }

        it 'sets to GitLab user url' do
          expect(data[:commit][:author_url]).to eq(Gitlab::Routing.url_helpers.user_url(username: ci_build.commit.author.username))
        end
      end

      context 'with environment' do
        let(:ci_build) { build(:ci_build, :teardown_environment) }

        it { expect(data[:environment][:name]).to eq(ci_build.expanded_environment_name) }
        it { expect(data[:environment][:action]).to eq(ci_build.environment_action) }
      end
    end
  end
end