2019-07-25 01:24:42 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-10-04 18:31:34 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-16 14:09:01 -04:00
|
|
|
RSpec.describe 'User views diffs', :js do
|
2017-10-04 18:31:34 -04:00
|
|
|
let(:merge_request) do
|
|
|
|
create(:merge_request_with_diffs, source_project: project, target_project: project, source_branch: 'merge-test')
|
|
|
|
end
|
2020-08-10 23:11:00 -04:00
|
|
|
|
2017-10-04 18:31:34 -04:00
|
|
|
let(:project) { create(:project, :public, :repository) }
|
2020-02-20 13:08:51 -05:00
|
|
|
let(:view) { 'inline' }
|
2017-10-04 18:31:34 -04:00
|
|
|
|
|
|
|
before do
|
2020-02-20 13:08:51 -05:00
|
|
|
visit(diffs_project_merge_request_path(project, merge_request, view: view))
|
2017-10-04 18:31:34 -04:00
|
|
|
|
|
|
|
wait_for_requests
|
2018-10-03 05:05:43 -04:00
|
|
|
|
|
|
|
find('.js-toggle-tree-list').click
|
2017-10-04 18:31:34 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
shared_examples 'unfold diffs' do
|
2019-08-09 22:36:32 -04:00
|
|
|
it 'unfolds diffs upwards' do
|
2017-10-04 18:31:34 -04:00
|
|
|
first('.js-unfold').click
|
2020-02-20 13:08:51 -05:00
|
|
|
|
|
|
|
page.within('.file-holder[id="a5cc2925ca8258af241be7e5b0381edf30266302"]') do
|
|
|
|
expect(find('.text-file')).to have_content('.bundle')
|
|
|
|
expect(page).to have_selector('.new_line [data-linenumber="1"]', count: 1)
|
|
|
|
end
|
2017-10-04 18:31:34 -04:00
|
|
|
end
|
2019-08-09 22:36:32 -04:00
|
|
|
|
2020-02-20 13:08:51 -05:00
|
|
|
it 'unfolds diffs in the middle' do
|
|
|
|
page.within('.file-holder[id="2f6fcd96b88b36ce98c38da085c795a27d92a3dd"]') do
|
|
|
|
all('.js-unfold-all')[1].click
|
|
|
|
|
|
|
|
expect(page).to have_selector('.new_line [data-linenumber="24"]', count: 1)
|
|
|
|
expect(page).not_to have_selector('.new_line [data-linenumber="1"]')
|
|
|
|
end
|
2019-08-09 22:36:32 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'unfolds diffs downwards' do
|
|
|
|
first('.js-unfold-down').click
|
|
|
|
expect(find('.file-holder[id="2f6fcd96b88b36ce98c38da085c795a27d92a3dd"] .text-file')).to have_content('.popen3')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'unfolds diffs to the end' do
|
|
|
|
page.all('.js-unfold-down').last
|
|
|
|
expect(find('.file-holder[id="6eb14e00385d2fb284765eb1cd8d420d33d63fc9"] .text-file')).to have_content('end')
|
|
|
|
end
|
2017-10-04 18:31:34 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows diffs' do
|
2019-01-24 09:48:03 -05:00
|
|
|
find('.js-show-diff-settings').click
|
|
|
|
|
2017-10-04 18:31:34 -04:00
|
|
|
expect(page).to have_css('.tab-content #diffs.active')
|
|
|
|
expect(page).to have_css('#parallel-diff-btn', count: 1)
|
|
|
|
expect(page).to have_css('#inline-diff-btn', count: 1)
|
|
|
|
end
|
|
|
|
|
2018-05-29 10:49:28 -04:00
|
|
|
it 'hides loading spinner after load' do
|
|
|
|
expect(page).not_to have_selector('.mr-loading-status .loading', visible: true)
|
|
|
|
end
|
|
|
|
|
2019-03-11 09:09:36 -04:00
|
|
|
it 'expands all diffs' do
|
2020-11-06 19:08:58 -05:00
|
|
|
first('.diff-toggle-caret').click
|
2019-03-11 09:09:36 -04:00
|
|
|
|
|
|
|
expect(page).to have_button('Expand all')
|
|
|
|
|
|
|
|
click_button 'Expand all'
|
|
|
|
|
|
|
|
expect(page).not_to have_button('Expand all')
|
|
|
|
end
|
|
|
|
|
2017-10-04 18:31:34 -04:00
|
|
|
context 'when in the inline view' do
|
|
|
|
include_examples 'unfold diffs'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when in the side-by-side view' do
|
2020-02-20 13:08:51 -05:00
|
|
|
let(:view) { 'parallel' }
|
2017-10-04 18:31:34 -04:00
|
|
|
|
|
|
|
it 'shows diffs in parallel' do
|
|
|
|
expect(page).to have_css('.parallel')
|
|
|
|
end
|
|
|
|
|
2018-06-21 08:22:40 -04:00
|
|
|
it 'toggles container class' do
|
|
|
|
expect(page).not_to have_css('.content-wrapper > .container-fluid.container-limited')
|
|
|
|
|
|
|
|
click_link 'Commits'
|
|
|
|
|
|
|
|
expect(page).to have_css('.content-wrapper > .container-fluid.container-limited')
|
|
|
|
end
|
|
|
|
|
2017-10-04 18:31:34 -04:00
|
|
|
include_examples 'unfold diffs'
|
|
|
|
end
|
|
|
|
end
|