environment_spec.rb 8.7 KB
Newer Older
F
Filipa Lacerda 已提交
1 2
require 'spec_helper'

3 4 5 6
describe 'Environment' do
  let(:project) { create(:project) }
  let(:user) { create(:user) }
  let(:role) { :developer }
F
Filipa Lacerda 已提交
7

8
  before do
9
    sign_in(user)
10
    project.add_role(user, role)
F
Filipa Lacerda 已提交
11 12
  end

13 14 15 16 17
  describe 'environment details page' do
    let!(:environment) { create(:environment, project: project) }
    let!(:permissions) { }
    let!(:deployment) { }
    let!(:action) { }
F
Filipa Lacerda 已提交
18 19

    before do
20
      visit_environment(environment)
F
Filipa Lacerda 已提交
21 22
    end

23
    it 'shows environment name' do
24 25 26
      expect(page).to have_content(environment.name)
    end

F
Filipa Lacerda 已提交
27
    context 'without deployments' do
28
      it 'does show no deployments' do
F
Filipa Lacerda 已提交
29 30 31 32 33
        expect(page).to have_content('You don\'t have any deployments right now.')
      end
    end

    context 'with deployments' do
34
      context 'when there is no related deployable' do
35
        let(:deployment) do
36 37
          create(:deployment, environment: environment, deployable: nil)
        end
F
Filipa Lacerda 已提交
38

39
        it 'does show deployment SHA' do
40 41
          expect(page).to have_link(deployment.short_sha)
          expect(page).not_to have_link('Re-deploy')
42 43
          expect(page).not_to have_terminal_button
        end
F
Filipa Lacerda 已提交
44 45
      end

46
      context 'with related deployable present' do
47 48
        let(:pipeline) { create(:ci_pipeline, project: project) }
        let(:build) { create(:ci_build, pipeline: pipeline) }
49

50
        let(:deployment) do
51 52
          create(:deployment, environment: environment, deployable: build)
        end
F
Filipa Lacerda 已提交
53

54
        it 'does show build name' do
F
Filipa Lacerda 已提交
55 56
          expect(page).to have_link("#{build.name} (##{build.id})")
          expect(page).to have_link('Re-deploy')
57 58 59
          expect(page).not_to have_terminal_button
        end

F
Filipa Lacerda 已提交
60
        context 'with manual action' do
61
          let(:action) do
62 63 64
            create(:ci_build, :manual, pipeline: pipeline,
                                       name: 'deploy to production')
          end
F
Filipa Lacerda 已提交
65

66
          context 'when user has ability to trigger deployment' do
67
            let(:permissions) do
68 69 70
              create(:protected_branch, :developers_can_merge,
                     name: action.ref, project: project)
            end
71

72 73 74 75 76 77
            it 'does show a play button' do
              expect(page).to have_link(action.name.humanize)
            end

            it 'does allow to play manual action' do
              expect(action).to be_manual
F
Filipa Lacerda 已提交
78

79 80
              expect { click_link(action.name.humanize) }
                .not_to change { Ci::Pipeline.count }
81

82 83 84 85
              expect(page).to have_content(action.name)
              expect(action.reload).to be_pending
            end
          end
86

87 88 89 90
          context 'when user has no ability to trigger a deployment' do
            it 'does not show a play button' do
              expect(page).not_to have_link(action.name.humanize)
            end
F
Filipa Lacerda 已提交
91 92 93
          end

          context 'with external_url' do
94 95 96
            let(:environment) { create(:environment, project: project, external_url: 'https://git.gitlab.com') }
            let(:build) { create(:ci_build, pipeline: pipeline) }
            let(:deployment) { create(:deployment, environment: environment, deployable: build) }
F
Filipa Lacerda 已提交
97

98
            it 'does show an external link button' do
F
Filipa Lacerda 已提交
99 100 101 102
              expect(page).to have_link(nil, href: environment.external_url)
            end
          end

103
          context 'with terminal' do
104
            shared_examples 'same behavior between KubernetesService and Platform::Kubernetes' do
105 106
              context 'for project master' do
                let(:role) { :master }
107

108
                it 'it shows the terminal button' do
109 110
                  expect(page).to have_terminal_button
                end
111

112 113 114 115 116 117 118 119 120 121 122 123
                context 'web terminal', :js do
                  before do
                    # Stub #terminals as it causes js-enabled feature specs to render the page incorrectly
                    allow_any_instance_of(Environment).to receive(:terminals) { nil }
                    visit terminal_project_environment_path(project, environment)
                  end

                  it 'displays a web terminal' do
                    expect(page).to have_selector('#terminal')
                    expect(page).to have_link(nil, href: environment.external_url)
                  end
                end
124
              end
125

126 127
              context 'for developer' do
                let(:role) { :developer }
128

129
                it 'does not show terminal button' do
130
                  expect(page).not_to have_terminal_button
131 132
                end
              end
133 134
            end

135 136
            context 'when user configured kubernetes from Integration > Kubernetes' do
              let(:project) { create(:kubernetes_project, :test_repo) }
137

138
              it_behaves_like 'same behavior between KubernetesService and Platform::Kubernetes'
139 140 141 142 143 144
            end

            context 'when user configured kubernetes from CI/CD > Clusters' do
              let!(:cluster) { create(:cluster, :project, :provided_by_gcp) }
              let(:project) { cluster.project }

145
              it_behaves_like 'same behavior between KubernetesService and Platform::Kubernetes'
146 147 148
            end
          end

K
Kamil Trzcinski 已提交
149 150
          context 'when environment is available' do
            context 'with stop action' do
151
              let(:action) do
152 153 154 155
                create(:ci_build, :manual, pipeline: pipeline,
                                           name: 'close_app')
              end

156
              let(:deployment) do
157 158 159 160
                create(:deployment, environment: environment,
                                    deployable: build,
                                    on_stop: 'close_app')
              end
F
Filipa Lacerda 已提交
161

162
              context 'when user has ability to stop environment' do
163
                let(:permissions) do
164 165 166
                  create(:protected_branch, :developers_can_merge,
                         name: action.ref, project: project)
                end
167

168
                it 'allows to stop environment' do
169 170
                  click_button('Stop')
                  click_button('Stop environment') # confirm modal
F
Filipa Lacerda 已提交
171

172 173 174 175 176 177
                  expect(page).to have_content('close_app')
                end
              end

              context 'when user has no ability to stop environment' do
                it 'does not allow to stop environment' do
178
                  expect(page).not_to have_button('Stop')
179
                end
K
Kamil Trzcinski 已提交
180
              end
F
Filipa Lacerda 已提交
181

K
Kamil Trzcinski 已提交
182 183
              context 'for reporter' do
                let(:role) { :reporter }
F
Filipa Lacerda 已提交
184

185
                it 'does not show stop button' do
186
                  expect(page).not_to have_button('Stop')
K
Kamil Trzcinski 已提交
187
                end
F
Filipa Lacerda 已提交
188 189
              end
            end
K
Kamil Trzcinski 已提交
190 191 192
          end

          context 'when environment is stopped' do
193
            let(:environment) { create(:environment, project: project, state: :stopped) }
K
Kamil Trzcinski 已提交
194

195
            it 'does not show stop button' do
196
              expect(page).not_to have_button('Stop')
K
Kamil Trzcinski 已提交
197
            end
F
Filipa Lacerda 已提交
198 199 200 201 202
          end
        end
      end
    end
  end
203

204
  describe 'environment folders', :js do
205 206 207 208 209 210 211 212
    context 'when folder name contains special charaters' do
      before do
        create(:environment, project: project,
                             name: 'staging-1.0/review',
                             state: :available)
      end

      it 'renders a correct environment folder' do
M
Mike Greiling 已提交
213 214 215 216 217
        reqs = inspect_requests do
          visit folder_project_environments_path(project, id: 'staging-1.0')
        end

        expect(reqs.first.status_code).to eq(200)
218 219 220 221 222
        expect(page).to have_content('Environments / staging-1.0')
      end
    end
  end

223 224
  describe 'auto-close environment when branch is deleted' do
    let(:project) { create(:project, :repository) }
225

226
    let!(:environment) do
227 228 229 230
      create(:environment, :with_review_app, project: project,
                                             ref: 'feature')
    end

231
    it 'user visits environment page' do
232 233
      visit_environment(environment)

234
      expect(page).to have_button('Stop')
235 236
    end

237
    it 'user deletes the branch with running environment' do
238
      visit project_branches_filtered_path(project, state: 'all', search: 'feature')
239 240 241 242 243 244 245

      remove_branch_with_hooks(project, user, 'feature') do
        page.within('.js-branch-feature') { find('a.btn-remove').click }
      end

      visit_environment(environment)

246
      expect(page).not_to have_button('Stop')
247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265
    end

    ##
    # This is a workaround for problem described in #24543
    #
    def remove_branch_with_hooks(project, user, branch)
      params = {
        oldrev: project.commit(branch).id,
        newrev: Gitlab::Git::BLANK_SHA,
        ref: "refs/heads/#{branch}"
      }

      yield

      GitPushService.new(project, user, params).execute
    end
  end

  def visit_environment(environment)
266
    visit project_environment_path(environment.project, environment)
267
  end
268 269

  def have_terminal_button
270
    have_link(nil, href: terminal_project_environment_path(project, environment))
271
  end
F
Filipa Lacerda 已提交
272
end