Commit b3f5e1e5 authored by Ezekiel Kigbo's avatar Ezekiel Kigbo

Merge branch '347496-consolidate-rspec-test-due-date-sidebar' into 'master'

Consolidate due date sidebar rspec tests [RUN AS-IF-FOLL

See merge request gitlab-org/gitlab!76718
parents 7df55271 713facd9
...@@ -154,7 +154,7 @@ export default { ...@@ -154,7 +154,7 @@ export default {
}; };
}, },
dataTestId() { dataTestId() {
return this.dateType === dateTypes.start ? 'start-date' : 'due-date'; return this.dateType === dateTypes.start ? 'sidebar-start-date' : 'sidebar-due-date';
}, },
}, },
methods: { methods: {
......
...@@ -114,7 +114,7 @@ RSpec.describe 'Epic boards sidebar', :js do ...@@ -114,7 +114,7 @@ RSpec.describe 'Epic boards sidebar', :js do
wait_for_requests wait_for_requests
page.within('[data-testid="start-date"]') do page.within('[data-testid="sidebar-start-date"]') do
edit_fixed_date edit_fixed_date
end end
end end
...@@ -124,7 +124,7 @@ RSpec.describe 'Epic boards sidebar', :js do ...@@ -124,7 +124,7 @@ RSpec.describe 'Epic boards sidebar', :js do
wait_for_requests wait_for_requests
page.within('[data-testid="start-date"]') do page.within('[data-testid="sidebar-start-date"]') do
remove_fixed_date remove_fixed_date
end end
end end
...@@ -136,7 +136,7 @@ RSpec.describe 'Epic boards sidebar', :js do ...@@ -136,7 +136,7 @@ RSpec.describe 'Epic boards sidebar', :js do
wait_for_requests wait_for_requests
page.within('[data-testid="due-date"]') do page.within('[data-testid="sidebar-due-date"]') do
edit_fixed_date edit_fixed_date
end end
end end
...@@ -146,7 +146,7 @@ RSpec.describe 'Epic boards sidebar', :js do ...@@ -146,7 +146,7 @@ RSpec.describe 'Epic boards sidebar', :js do
wait_for_requests wait_for_requests
page.within('[data-testid="due-date"]') do page.within('[data-testid="sidebar-due-date"]') do
remove_fixed_date remove_fixed_date
end end
end end
......
...@@ -11,7 +11,6 @@ RSpec.describe 'Issue Sidebar' do ...@@ -11,7 +11,6 @@ RSpec.describe 'Issue Sidebar' do
let_it_be(:label) { create(:label, project: project, title: 'bug') } let_it_be(:label) { create(:label, project: project, title: 'bug') }
let_it_be(:issue) { create(:labeled_issue, project: project, labels: [label]) } let_it_be(:issue) { create(:labeled_issue, project: project, labels: [label]) }
let_it_be(:mock_date) { Date.today.at_beginning_of_month + 2.days } let_it_be(:mock_date) { Date.today.at_beginning_of_month + 2.days }
let_it_be(:issue_with_due_date) { create(:issue, project: project, due_date: mock_date) }
let_it_be(:xss_label) { create(:label, project: project, title: '<script>alert("xss");</script>') } let_it_be(:xss_label) { create(:label, project: project, title: '<script>alert("xss");</script>') }
before do before do
...@@ -201,30 +200,6 @@ RSpec.describe 'Issue Sidebar' do ...@@ -201,30 +200,6 @@ RSpec.describe 'Issue Sidebar' do
end end
end end
context 'due date widget', :js do
let(:due_date_value) { find('[data-testid="due-date"] [data-testid="sidebar-date-value"]') }
context 'when no due date exists' do
before do
visit_issue(project, issue)
end
it "displays 'None'" do
expect(due_date_value.text).to have_content 'None'
end
end
context 'when due date exists' do
before do
visit_issue(project, issue_with_due_date)
end
it "displays the due date" do
expect(due_date_value.text).to have_content mock_date.strftime('%b %-d, %Y')
end
end
end
context 'as an allowed user' do context 'as an allowed user' do
before do before do
project.add_developer(user) project.add_developer(user)
...@@ -262,6 +237,10 @@ RSpec.describe 'Issue Sidebar' do ...@@ -262,6 +237,10 @@ RSpec.describe 'Issue Sidebar' do
it_behaves_like 'milestone sidebar widget' it_behaves_like 'milestone sidebar widget'
end end
context 'editing issue due date', :js do
it_behaves_like 'date sidebar widget'
end
context 'editing issue labels', :js do context 'editing issue labels', :js do
before do before do
issue.update!(labels: [label]) issue.update!(labels: [label])
......
...@@ -417,7 +417,7 @@ RSpec.describe "Issues > User edits issue", :js do ...@@ -417,7 +417,7 @@ RSpec.describe "Issues > User edits issue", :js do
it 'adds due date to issue' do it 'adds due date to issue' do
date = Date.today.at_beginning_of_month + 2.days date = Date.today.at_beginning_of_month + 2.days
page.within '[data-testid="due-date"]' do page.within '[data-testid="sidebar-due-date"]' do
click_button 'Edit' click_button 'Edit'
page.within '.pika-single' do page.within '.pika-single' do
click_button date.day click_button date.day
...@@ -432,7 +432,7 @@ RSpec.describe "Issues > User edits issue", :js do ...@@ -432,7 +432,7 @@ RSpec.describe "Issues > User edits issue", :js do
it 'removes due date from issue' do it 'removes due date from issue' do
date = Date.today.at_beginning_of_month + 2.days date = Date.today.at_beginning_of_month + 2.days
page.within '[data-testid="due-date"]' do page.within '[data-testid="sidebar-due-date"]' do
click_button 'Edit' click_button 'Edit'
page.within '.pika-single' do page.within '.pika-single' do
......
# frozen_string_literal: true # frozen_string_literal: true
require 'spec_helper' RSpec.shared_examples 'date sidebar widget' do
context 'editing due date' do
RSpec.describe 'Project issue boards sidebar due date', :js do let(:due_date_value) { find('[data-testid="sidebar-due-date"] [data-testid="sidebar-date-value"]') }
include BoardHelpers
let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project, :public) }
let_it_be(:issue) { create(:issue, project: project, relative_position: 1) }
let_it_be(:board) { create(:board, project: project) }
let_it_be(:list) { create(:list, board: board, position: 0) }
let(:card) { find('.board:nth-child(1)').first('.board-card') }
around do |example| around do |example|
freeze_time { example.run } freeze_time { example.run }
end end
before do it 'displays "None" when there is no due date' do
project.add_maintainer(user) expect(due_date_value.text).to have_content 'None'
sign_in(user)
visit project_board_path(project, board)
wait_for_requests
end end
context 'due date' do
it 'updates due date' do it 'updates due date' do
click_card(card)
page.within('[data-testid="sidebar-due-date"]') do page.within('[data-testid="sidebar-due-date"]') do
today = Date.today.day today = Date.today.day
...@@ -40,6 +23,7 @@ RSpec.describe 'Project issue boards sidebar due date', :js do ...@@ -40,6 +23,7 @@ RSpec.describe 'Project issue boards sidebar due date', :js do
wait_for_requests wait_for_requests
expect(page).to have_content(today.to_s(:medium)) expect(page).to have_content(today.to_s(:medium))
expect(due_date_value.text).to have_content Time.current.strftime('%b %-d, %Y')
end end
end end
end end
......
...@@ -46,6 +46,10 @@ RSpec.shared_examples 'issue boards sidebar' do ...@@ -46,6 +46,10 @@ RSpec.shared_examples 'issue boards sidebar' do
it_behaves_like 'milestone sidebar widget' it_behaves_like 'milestone sidebar widget'
end end
context 'editing issue due date', :js do
it_behaves_like 'date sidebar widget'
end
context 'in notifications subscription' do context 'in notifications subscription' do
it 'displays notifications toggle', :aggregate_failures do it 'displays notifications toggle', :aggregate_failures do
page.within('[data-testid="sidebar-notifications"]') do page.within('[data-testid="sidebar-notifications"]') do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment