2015-10-06 14:36:22 -04:00
|
|
|
require 'spec_helper'
|
2016-08-30 06:47:31 -04:00
|
|
|
require 'tempfile'
|
2015-10-06 14:36:22 -04:00
|
|
|
|
|
|
|
describe "Builds" do
|
2015-10-12 17:47:32 -04:00
|
|
|
let(:artifacts_file) { fixture_file_upload(Rails.root + 'spec/fixtures/banana_sample.gif', 'image/gif') }
|
|
|
|
|
2015-10-06 14:36:22 -04:00
|
|
|
before do
|
|
|
|
login_as(:user)
|
2016-06-03 10:22:26 -04:00
|
|
|
@commit = FactoryGirl.create :ci_pipeline
|
2016-08-30 06:47:31 -04:00
|
|
|
@build = FactoryGirl.create :ci_build, :trace, pipeline: @commit
|
2016-06-03 18:02:40 -04:00
|
|
|
@build2 = FactoryGirl.create :ci_build
|
2015-12-04 06:55:23 -05:00
|
|
|
@project = @commit.project
|
2016-02-04 06:57:46 -05:00
|
|
|
@project.team << [@user, :developer]
|
2015-10-06 14:36:22 -04:00
|
|
|
end
|
|
|
|
|
2015-10-14 06:15:03 -04:00
|
|
|
describe "GET /:project/builds" do
|
2016-07-12 04:31:15 -04:00
|
|
|
context "Pending scope" do
|
|
|
|
before do
|
|
|
|
visit namespace_project_builds_path(@project.namespace, @project, scope: :pending)
|
|
|
|
end
|
|
|
|
|
2016-07-18 04:57:22 -04:00
|
|
|
it "shows Pending tab builds" do
|
|
|
|
expect(page).to have_link 'Cancel running'
|
|
|
|
expect(page).to have_selector('.nav-links li.active', text: 'Pending')
|
|
|
|
expect(page).to have_content @build.short_sha
|
|
|
|
expect(page).to have_content @build.ref
|
|
|
|
expect(page).to have_content @build.name
|
|
|
|
end
|
2016-07-12 04:31:15 -04:00
|
|
|
end
|
|
|
|
|
2015-10-14 08:21:49 -04:00
|
|
|
context "Running scope" do
|
2015-10-14 06:15:03 -04:00
|
|
|
before do
|
2015-10-14 08:21:49 -04:00
|
|
|
@build.run!
|
2015-12-30 09:25:42 -05:00
|
|
|
visit namespace_project_builds_path(@project.namespace, @project, scope: :running)
|
2015-10-14 06:15:03 -04:00
|
|
|
end
|
|
|
|
|
2016-07-18 04:57:22 -04:00
|
|
|
it "shows Running tab builds" do
|
|
|
|
expect(page).to have_selector('.nav-links li.active', text: 'Running')
|
|
|
|
expect(page).to have_link 'Cancel running'
|
|
|
|
expect(page).to have_content @build.short_sha
|
|
|
|
expect(page).to have_content @build.ref
|
|
|
|
expect(page).to have_content @build.name
|
|
|
|
end
|
2015-10-14 06:15:03 -04:00
|
|
|
end
|
|
|
|
|
2015-10-14 08:21:49 -04:00
|
|
|
context "Finished scope" do
|
2015-10-14 06:15:03 -04:00
|
|
|
before do
|
2015-10-14 08:21:49 -04:00
|
|
|
@build.run!
|
2015-12-04 06:55:23 -05:00
|
|
|
visit namespace_project_builds_path(@project.namespace, @project, scope: :finished)
|
2015-10-14 06:15:03 -04:00
|
|
|
end
|
|
|
|
|
2016-07-18 04:57:22 -04:00
|
|
|
it "shows Finished tab builds" do
|
|
|
|
expect(page).to have_selector('.nav-links li.active', text: 'Finished')
|
|
|
|
expect(page).to have_content 'No builds to show'
|
|
|
|
expect(page).to have_link 'Cancel running'
|
|
|
|
end
|
2015-10-14 06:15:03 -04:00
|
|
|
end
|
|
|
|
|
2015-10-14 08:21:49 -04:00
|
|
|
context "All builds" do
|
2015-10-14 06:15:03 -04:00
|
|
|
before do
|
2015-12-10 11:44:06 -05:00
|
|
|
@project.builds.running_or_pending.each(&:success)
|
2015-12-30 09:25:42 -05:00
|
|
|
visit namespace_project_builds_path(@project.namespace, @project)
|
2015-10-14 06:15:03 -04:00
|
|
|
end
|
|
|
|
|
2016-07-18 04:57:22 -04:00
|
|
|
it "shows All tab builds" do
|
|
|
|
expect(page).to have_selector('.nav-links li.active', text: 'All')
|
|
|
|
expect(page).to have_content @build.short_sha
|
|
|
|
expect(page).to have_content @build.ref
|
|
|
|
expect(page).to have_content @build.name
|
|
|
|
expect(page).not_to have_link 'Cancel running'
|
|
|
|
end
|
2015-10-14 06:15:03 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-11-03 05:44:07 -05:00
|
|
|
describe "POST /:project/builds/:id/cancel_all" do
|
2015-10-14 06:15:03 -04:00
|
|
|
before do
|
|
|
|
@build.run!
|
2015-12-04 06:55:23 -05:00
|
|
|
visit namespace_project_builds_path(@project.namespace, @project)
|
2015-12-08 08:13:03 -05:00
|
|
|
click_link "Cancel running"
|
2015-10-14 06:15:03 -04:00
|
|
|
end
|
|
|
|
|
2016-02-03 14:21:26 -05:00
|
|
|
it { expect(page).to have_selector('.nav-links li.active', text: 'All') }
|
2015-12-30 09:25:42 -05:00
|
|
|
it { expect(page).to have_content 'canceled' }
|
|
|
|
it { expect(page).to have_content @build.short_sha }
|
|
|
|
it { expect(page).to have_content @build.ref }
|
|
|
|
it { expect(page).to have_content @build.name }
|
2016-05-23 19:37:59 -04:00
|
|
|
it { expect(page).not_to have_link 'Cancel running' }
|
2015-10-14 06:15:03 -04:00
|
|
|
end
|
|
|
|
|
2015-10-06 14:36:22 -04:00
|
|
|
describe "GET /:project/builds/:id" do
|
2016-06-03 18:02:40 -04:00
|
|
|
context "Build from project" do
|
|
|
|
before do
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(page.status_code).to eq(200) }
|
|
|
|
it { expect(page).to have_content @commit.sha[0..7] }
|
|
|
|
it { expect(page).to have_content @commit.git_commit_message }
|
|
|
|
it { expect(page).to have_content @commit.git_author_name }
|
2015-10-06 14:36:22 -04:00
|
|
|
end
|
|
|
|
|
2016-06-03 18:02:40 -04:00
|
|
|
context "Build from other project" do
|
|
|
|
before do
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build2)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(page.status_code).to eq(404) }
|
|
|
|
end
|
2015-10-12 17:47:32 -04:00
|
|
|
|
|
|
|
context "Download artifacts" do
|
|
|
|
before do
|
|
|
|
@build.update_attributes(artifacts_file: artifacts_file)
|
2015-12-04 06:55:23 -05:00
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
2015-10-12 17:47:32 -04:00
|
|
|
end
|
|
|
|
|
2015-12-28 06:34:47 -05:00
|
|
|
it 'has button to download artifacts' do
|
2016-04-20 05:11:22 -04:00
|
|
|
expect(page).to have_content 'Download'
|
2015-12-28 06:34:47 -05:00
|
|
|
end
|
2015-10-12 17:47:32 -04:00
|
|
|
end
|
2016-04-17 12:19:23 -04:00
|
|
|
|
2016-06-10 10:20:11 -04:00
|
|
|
context 'Artifacts expire date' do
|
|
|
|
before do
|
|
|
|
@build.update_attributes(artifacts_file: artifacts_file, artifacts_expire_at: expire_at)
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'no expire date defined' do
|
|
|
|
let(:expire_at) { nil }
|
|
|
|
|
2016-06-10 15:45:06 -04:00
|
|
|
it 'does not have the Keep button' do
|
2016-06-14 05:38:34 -04:00
|
|
|
expect(page).not_to have_content 'Keep'
|
2016-06-10 10:20:11 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when expire date is defined' do
|
|
|
|
let(:expire_at) { Time.now + 7.days }
|
|
|
|
|
2016-06-10 15:45:06 -04:00
|
|
|
it 'keeps artifacts when Keep button is clicked' do
|
2016-06-14 05:38:34 -04:00
|
|
|
expect(page).to have_content 'The artifacts will be removed'
|
|
|
|
click_link 'Keep'
|
2016-06-10 10:20:11 -04:00
|
|
|
|
|
|
|
expect(page).not_to have_link 'Keep'
|
|
|
|
expect(page).not_to have_content 'The artifacts will be removed'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when artifacts expired' do
|
|
|
|
let(:expire_at) { Time.now - 7.days }
|
|
|
|
|
2016-06-10 15:45:06 -04:00
|
|
|
it 'does not have the Keep button' do
|
2016-06-14 05:38:34 -04:00
|
|
|
expect(page).to have_content 'The artifacts were removed'
|
|
|
|
expect(page).not_to have_link 'Keep'
|
2016-06-10 10:20:11 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-04-17 12:19:23 -04:00
|
|
|
context 'Build raw trace' do
|
|
|
|
before do
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
end
|
|
|
|
|
|
|
|
it do
|
2016-04-20 05:11:22 -04:00
|
|
|
expect(page).to have_link 'Raw'
|
2016-04-17 12:19:23 -04:00
|
|
|
end
|
|
|
|
end
|
2016-08-30 11:37:49 -04:00
|
|
|
|
|
|
|
describe 'Variables' do
|
|
|
|
before do
|
|
|
|
@trigger_request = create :ci_trigger_request_with_variables
|
|
|
|
@build = create :ci_build, pipeline: @commit, trigger_request: @trigger_request
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows variable key and value after click', js: true do
|
|
|
|
expect(page).to have_css('.reveal-variables')
|
|
|
|
expect(page).not_to have_css('.js-build-variable')
|
|
|
|
expect(page).not_to have_css('.js-build-value')
|
|
|
|
|
2016-09-06 05:49:40 -04:00
|
|
|
click_button 'Reveal Variables'
|
2016-08-30 11:37:49 -04:00
|
|
|
|
|
|
|
expect(page).not_to have_css('.reveal-variables')
|
|
|
|
expect(page).to have_selector('.js-build-variable', text: 'TRIGGER_KEY_1')
|
|
|
|
expect(page).to have_selector('.js-build-value', text: 'TRIGGER_VALUE_1')
|
|
|
|
end
|
|
|
|
end
|
2015-10-06 14:36:22 -04:00
|
|
|
end
|
2015-10-07 09:24:32 -04:00
|
|
|
|
2015-11-03 05:44:07 -05:00
|
|
|
describe "POST /:project/builds/:id/cancel" do
|
2016-06-03 18:02:40 -04:00
|
|
|
context "Build from project" do
|
|
|
|
before do
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
click_link "Cancel"
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(page.status_code).to eq(200) }
|
|
|
|
it { expect(page).to have_content 'canceled' }
|
|
|
|
it { expect(page).to have_content 'Retry' }
|
2015-10-07 09:24:32 -04:00
|
|
|
end
|
|
|
|
|
2016-06-03 18:02:40 -04:00
|
|
|
context "Build from other project" do
|
|
|
|
before do
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
page.driver.post(cancel_namespace_project_build_path(@project.namespace, @project, @build2))
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(page.status_code).to eq(404) }
|
|
|
|
end
|
2015-10-07 09:24:32 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "POST /:project/builds/:id/retry" do
|
2016-06-03 18:02:40 -04:00
|
|
|
context "Build from project" do
|
|
|
|
before do
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
click_link 'Cancel'
|
|
|
|
click_link 'Retry'
|
|
|
|
end
|
|
|
|
|
2016-07-25 12:35:00 -04:00
|
|
|
it 'shows the right status and buttons' do
|
|
|
|
expect(page).to have_http_status(200)
|
|
|
|
expect(page).to have_content 'pending'
|
|
|
|
page.within('aside.right-sidebar') do
|
|
|
|
expect(page).to have_content 'Cancel'
|
|
|
|
end
|
|
|
|
end
|
2015-10-07 09:24:32 -04:00
|
|
|
end
|
|
|
|
|
2016-06-03 18:02:40 -04:00
|
|
|
context "Build from other project" do
|
|
|
|
before do
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
click_link 'Cancel'
|
|
|
|
page.driver.post(retry_namespace_project_build_path(@project.namespace, @project, @build2))
|
|
|
|
end
|
|
|
|
|
2016-07-25 12:35:00 -04:00
|
|
|
it { expect(page).to have_http_status(404) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "Build that current user is not allowed to retry" do
|
|
|
|
before do
|
|
|
|
@build.run!
|
|
|
|
@build.cancel!
|
|
|
|
@project.update(visibility_level: Gitlab::VisibilityLevel::PUBLIC)
|
|
|
|
|
|
|
|
logout_direct
|
|
|
|
login_with(create(:user))
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not show the Retry button' do
|
|
|
|
page.within('aside.right-sidebar') do
|
|
|
|
expect(page).not_to have_content 'Retry'
|
|
|
|
end
|
|
|
|
end
|
2016-06-03 18:02:40 -04:00
|
|
|
end
|
2015-10-07 09:24:32 -04:00
|
|
|
end
|
2015-10-12 17:47:32 -04:00
|
|
|
|
|
|
|
describe "GET /:project/builds/:id/download" do
|
2016-04-20 05:11:22 -04:00
|
|
|
before do
|
|
|
|
@build.update_attributes(artifacts_file: artifacts_file)
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
click_link 'Download'
|
2015-10-12 17:47:32 -04:00
|
|
|
end
|
|
|
|
|
2016-06-03 18:02:40 -04:00
|
|
|
context "Build from other project" do
|
|
|
|
before do
|
|
|
|
@build2.update_attributes(artifacts_file: artifacts_file)
|
|
|
|
visit download_namespace_project_build_artifacts_path(@project.namespace, @project, @build2)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(page.status_code).to eq(404) }
|
|
|
|
end
|
2015-10-12 17:47:32 -04:00
|
|
|
end
|
2016-04-17 12:19:23 -04:00
|
|
|
|
2016-08-30 06:47:31 -04:00
|
|
|
describe 'GET /:project/builds/:id/raw' do
|
|
|
|
context 'access source' do
|
|
|
|
context 'build from project' do
|
|
|
|
before do
|
|
|
|
Capybara.current_session.driver.header('X-Sendfile-Type', 'X-Sendfile')
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
page.within('.js-build-sidebar') { click_link 'Raw' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sends the right headers' do
|
|
|
|
expect(page.status_code).to eq(200)
|
|
|
|
expect(page.response_headers['Content-Type']).to eq('text/plain; charset=utf-8')
|
|
|
|
expect(page.response_headers['X-Sendfile']).to eq(@build.path_to_trace)
|
|
|
|
end
|
2016-06-03 18:02:40 -04:00
|
|
|
end
|
|
|
|
|
2016-08-30 06:47:31 -04:00
|
|
|
context 'build from other project' do
|
|
|
|
before do
|
|
|
|
Capybara.current_session.driver.header('X-Sendfile-Type', 'X-Sendfile')
|
|
|
|
@build2.run!
|
|
|
|
visit raw_namespace_project_build_path(@project.namespace, @project, @build2)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sends the right headers' do
|
|
|
|
expect(page.status_code).to eq(404)
|
|
|
|
end
|
2016-06-03 18:02:40 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-08-30 06:47:31 -04:00
|
|
|
context 'storage form' do
|
2016-08-31 13:38:01 -04:00
|
|
|
let(:existing_file) { Tempfile.new('existing-trace-file').path }
|
|
|
|
let(:non_existing_file) do
|
2016-08-30 06:47:31 -04:00
|
|
|
file = Tempfile.new('non-existing-trace-file')
|
|
|
|
path = file.path
|
|
|
|
file.unlink
|
|
|
|
path
|
2016-06-03 18:02:40 -04:00
|
|
|
end
|
|
|
|
|
2016-08-30 06:47:31 -04:00
|
|
|
context 'when build has trace in file' do
|
|
|
|
before do
|
|
|
|
Capybara.current_session.driver.header('X-Sendfile-Type', 'X-Sendfile')
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
|
|
|
|
allow_any_instance_of(Project).to receive(:ci_id).and_return(nil)
|
|
|
|
allow_any_instance_of(Ci::Build).to receive(:path_to_trace).and_return(existing_file)
|
|
|
|
allow_any_instance_of(Ci::Build).to receive(:old_path_to_trace).and_return(non_existing_file)
|
|
|
|
|
|
|
|
page.within('.js-build-sidebar') { click_link 'Raw' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sends the right headers' do
|
|
|
|
expect(page.status_code).to eq(200)
|
|
|
|
expect(page.response_headers['Content-Type']).to eq('text/plain; charset=utf-8')
|
|
|
|
expect(page.response_headers['X-Sendfile']).to eq(existing_file)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when build has trace in old file' do
|
|
|
|
before do
|
|
|
|
Capybara.current_session.driver.header('X-Sendfile-Type', 'X-Sendfile')
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
|
|
|
|
allow_any_instance_of(Project).to receive(:ci_id).and_return(999)
|
|
|
|
allow_any_instance_of(Ci::Build).to receive(:path_to_trace).and_return(non_existing_file)
|
|
|
|
allow_any_instance_of(Ci::Build).to receive(:old_path_to_trace).and_return(existing_file)
|
|
|
|
|
|
|
|
page.within('.js-build-sidebar') { click_link 'Raw' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sends the right headers' do
|
|
|
|
expect(page.status_code).to eq(200)
|
|
|
|
expect(page.response_headers['Content-Type']).to eq('text/plain; charset=utf-8')
|
|
|
|
expect(page.response_headers['X-Sendfile']).to eq(existing_file)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when build has trace in DB' do
|
|
|
|
before do
|
|
|
|
Capybara.current_session.driver.header('X-Sendfile-Type', 'X-Sendfile')
|
|
|
|
@build.run!
|
|
|
|
visit namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
|
|
|
|
allow_any_instance_of(Project).to receive(:ci_id).and_return(nil)
|
|
|
|
allow_any_instance_of(Ci::Build).to receive(:path_to_trace).and_return(non_existing_file)
|
|
|
|
allow_any_instance_of(Ci::Build).to receive(:old_path_to_trace).and_return(non_existing_file)
|
|
|
|
|
|
|
|
page.within('.js-build-sidebar') { click_link 'Raw' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sends the right headers' do
|
|
|
|
expect(page.status_code).to eq(404)
|
|
|
|
end
|
2016-06-03 18:02:40 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET /:project/builds/:id/trace.json" do
|
|
|
|
context "Build from project" do
|
|
|
|
before do
|
|
|
|
visit trace_namespace_project_build_path(@project.namespace, @project, @build, format: :json)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(page.status_code).to eq(200) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "Build from other project" do
|
|
|
|
before do
|
|
|
|
visit trace_namespace_project_build_path(@project.namespace, @project, @build2, format: :json)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(page.status_code).to eq(404) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET /:project/builds/:id/status" do
|
|
|
|
context "Build from project" do
|
|
|
|
before do
|
|
|
|
visit status_namespace_project_build_path(@project.namespace, @project, @build)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(page.status_code).to eq(200) }
|
2016-04-17 12:19:23 -04:00
|
|
|
end
|
|
|
|
|
2016-06-07 07:02:37 -04:00
|
|
|
context "Build from other project" do
|
|
|
|
before do
|
|
|
|
visit status_namespace_project_build_path(@project.namespace, @project, @build2)
|
|
|
|
end
|
2016-04-19 07:02:41 -04:00
|
|
|
|
2016-06-03 18:02:40 -04:00
|
|
|
it { expect(page.status_code).to eq(404) }
|
2016-04-19 07:02:41 -04:00
|
|
|
end
|
2016-04-17 12:19:23 -04:00
|
|
|
end
|
2015-10-06 14:36:22 -04:00
|
|
|
end
|