require 'rails_helper' feature 'Mini Pipeline Graph', :js, :feature do let(:user) { create(:user) } let(:project) { create(:project, :public) } let(:merge_request) { create(:merge_request, source_project: project, head_pipeline: pipeline) } let(:pipeline) { create(:ci_empty_pipeline, project: project, ref: 'master', status: 'running', sha: project.commit.id) } let(:build) { create(:ci_build, pipeline: pipeline, stage: 'test', commands: 'test') } before do build.run login_as(user) visit namespace_project_merge_request_path(project.namespace, project, merge_request) end it 'should display a mini pipeline graph' do expect(page).to have_selector('.mr-widget-pipeline-graph') end describe 'build list toggle' do let(:toggle) do find('.mini-pipeline-graph-dropdown-toggle') first('.mini-pipeline-graph-dropdown-toggle') end it 'should expand when hovered' do before_width = evaluate_script("$('.mini-pipeline-graph-dropdown-toggle:visible').outerWidth();") toggle.hover after_width = evaluate_script("$('.mini-pipeline-graph-dropdown-toggle:visible').outerWidth();") expect(before_width).to be < after_width end it 'should show dropdown caret when hovered' do toggle.hover expect(toggle).to have_selector('.fa-caret-down') end it 'should show tooltip when hovered' do toggle.hover expect(toggle.find(:xpath, '..')).to have_selector('.tooltip') end end describe 'builds list menu' do let(:toggle) do find('.mini-pipeline-graph-dropdown-toggle') first('.mini-pipeline-graph-dropdown-toggle') end before do toggle.click wait_for_requests end it 'should open when toggle is clicked' do expect(toggle.find(:xpath, '..')).to have_selector('.mini-pipeline-graph-dropdown-menu') end it 'should close when toggle is clicked again' do toggle.trigger('click') expect(toggle.find(:xpath, '..')).not_to have_selector('.mini-pipeline-graph-dropdown-menu') end it 'should close when clicking somewhere else' do find('body').click expect(toggle.find(:xpath, '..')).not_to have_selector('.mini-pipeline-graph-dropdown-menu') end describe 'build list build item' do let(:build_item) do find('.mini-pipeline-graph-dropdown-item') first('.mini-pipeline-graph-dropdown-item') end it 'should visit the build page when clicked' do build_item.click find('.build-page') expect(current_path).to eql(namespace_project_build_path(project.namespace, project, build)) end it 'should show tooltip when hovered' do build_item.hover expect(build_item.find(:xpath, '..')).to have_selector('.tooltip') end end end end