# frozen_string_literal: true require 'spec_helper' describe 'User browses a job', :js do let(:user) { create(:user) } let(:user_access_level) { :developer } let(:project) { create(:project, :repository, namespace: user.namespace) } let(:pipeline) { create(:ci_empty_pipeline, project: project, sha: project.commit.sha, ref: 'master') } let!(:build) { create(:ci_build, :success, :trace_artifact, :coverage, pipeline: pipeline) } before do stub_feature_flags(job_log_json: false) project.add_maintainer(user) project.enable_ci sign_in(user) visit(project_job_path(project, build)) end it 'erases the job log', :js do wait_for_requests expect(page).to have_content("Job ##{build.id}") expect(page).to have_css('.js-build-trace') # scroll to the top of the page first execute_script "window.scrollTo(0,0)" accept_confirm { find('.js-erase-link').click } expect(page).to have_no_css('.artifacts') expect(build).not_to have_trace expect(build.artifacts_file.present?).to be_falsy expect(build.artifacts_metadata.present?).to be_falsy expect(page).to have_content('Job has been erased') end shared_examples 'has collapsible sections' do it 'collapses the section clicked' do wait_for_requests text_to_hide = "Cloning into '/nolith/ci-tests'" text_to_show = 'Waiting for pod' expect(page).to have_content(text_to_hide) expect(page).to have_content(text_to_show) first('.js-section-start[data-section="get-sources"]').click expect(page).not_to have_content(text_to_hide) expect(page).to have_content(text_to_show) end it 'collapses the section header clicked' do wait_for_requests text_to_hide = "Cloning into '/nolith/ci-tests'" text_to_show = 'Waiting for pod' expect(page).to have_content(text_to_hide) expect(page).to have_content(text_to_show) first('.js-section-header.js-s-get-sources').click expect(page).not_to have_content(text_to_hide) expect(page).to have_content(text_to_show) end end context 'when job trace contains sections' do let!(:build) { create(:ci_build, :success, :trace_with_sections, :coverage, pipeline: pipeline) } it_behaves_like 'has collapsible sections' end context 'when job trace contains duplicate sections' do let!(:build) { create(:ci_build, :success, :trace_with_duplicate_sections, :coverage, pipeline: pipeline) } it_behaves_like 'has collapsible sections' end context 'when job trace contains sections' do let!(:build) { create(:ci_build, :success, :trace_with_duplicate_sections, :coverage, pipeline: pipeline) } it 'collapses a section' do wait_for_requests text_to_hide = "Cloning into '/nolith/ci-tests'" text_to_show = 'Waiting for pod' expect(page).to have_content(text_to_hide) expect(page).to have_content(text_to_show) first('.js-section-start[data-section="get-sources"]').click expect(page).not_to have_content(text_to_hide) expect(page).to have_content(text_to_show) end end context 'with a failed job' do let!(:build) { create(:ci_build, :failed, :trace_artifact, pipeline: pipeline) } it 'displays the failure reason' do wait_for_all_requests within('.builds-container') do build_link = first('.build-job > a') expect(build_link['data-original-title']).to eq('test - failed - (unknown failure)') end end end context 'when a failed job has been retried' do let!(:build) { create(:ci_build, :failed, :retried, :trace_artifact, pipeline: pipeline) } it 'displays the failure reason and retried label' do wait_for_all_requests within('.builds-container') do build_link = first('.build-job > a') expect(build_link['data-original-title']).to eq('test - failed - (unknown failure) (retried)') end end end end