208 lines
5.5 KiB
Ruby
208 lines
5.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe 'Issue Detail', :js, feature_category: :team_planning do
|
|
let_it_be_with_refind(:project) { create(:project, :public) }
|
|
|
|
let(:user) { create(:user) }
|
|
let(:issue) { create(:issue, project: project, author: user) }
|
|
let(:incident) { create(:incident, project: project, author: user) }
|
|
|
|
context 'when user displays the issue' do
|
|
before do
|
|
visit project_issue_path(project, issue)
|
|
wait_for_requests
|
|
end
|
|
|
|
it 'shows the issue' do
|
|
page.within('.issuable-details') do
|
|
expect(find('h1')).to have_content(issue.title)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when user displays the issue as an incident' do
|
|
before do
|
|
visit project_issue_path(project, incident)
|
|
wait_for_requests
|
|
end
|
|
|
|
it 'does not show design management' do
|
|
expect(page).not_to have_selector('.js-design-management')
|
|
end
|
|
end
|
|
|
|
context 'when issue description has emojis' do
|
|
let(:issue) { create(:issue, project: project, author: user, description: 'hello world :100:') }
|
|
|
|
before do
|
|
sign_in(user)
|
|
visit project_issue_path(project, issue)
|
|
end
|
|
|
|
it 'renders gl-emoji tag' do
|
|
page.within('.description') do
|
|
expect(page).to have_selector('gl-emoji', count: 1)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when issue description has task list items' do
|
|
before do
|
|
description = '- [ ] I am a task
|
|
|
|
| Table |
|
|
|-------|
|
|
| <ul><li>[ ] I am inside a table</li><ul> |'
|
|
issue.update!(description: description)
|
|
|
|
sign_in(user)
|
|
visit project_issue_path(project, issue)
|
|
end
|
|
|
|
it 'shows task actions ellipsis button when hovering over the task list item, but not within a table', :aggregate_failures do
|
|
find('li', text: 'I am a task').hover
|
|
|
|
expect(page).to have_button 'Task actions'
|
|
|
|
find('li', text: 'I am inside a table').hover
|
|
|
|
expect(page).not_to have_button 'Task actions'
|
|
end
|
|
end
|
|
|
|
context 'when issue description has xss snippet' do
|
|
before do
|
|
issue.update!(description: '![xss" onload=alert(1);//](a)')
|
|
|
|
sign_in(user)
|
|
visit project_issue_path(project, issue)
|
|
end
|
|
|
|
it 'encodes the description to prevent xss issues', quarantine: 'https://gitlab.com/gitlab-org/gitlab/-/issues/207951' do
|
|
page.within('.issuable-details .detail-page-description') do
|
|
image = find('img.js-lazy-loaded')
|
|
|
|
expect(page).to have_selector('img', count: 1)
|
|
expect(image['onerror']).to be_nil
|
|
expect(image['src']).to end_with('/a')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when edited by a user who is later deleted' do
|
|
let(:user_to_be_deleted) { create(:user) }
|
|
|
|
before do
|
|
project.add_developer(user_to_be_deleted)
|
|
|
|
sign_in(user_to_be_deleted)
|
|
visit project_issue_path(project, issue)
|
|
wait_for_requests
|
|
|
|
click_button 'Edit title and description'
|
|
fill_in 'issuable-title', with: 'issue title'
|
|
click_button 'Save changes'
|
|
wait_for_requests
|
|
|
|
Users::DestroyService.new(user_to_be_deleted).execute(user_to_be_deleted)
|
|
|
|
sign_in(user)
|
|
visit project_issue_path(project, issue)
|
|
end
|
|
|
|
it 'shows the issue' do
|
|
page.within('.issuable-details') do
|
|
expect(find('h1')).to have_content(issue.reload.title)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'user updates `issue_type` via the issue type dropdown' do
|
|
let_it_be(:reporter) { create(:user) }
|
|
|
|
before_all do
|
|
project.add_reporter(reporter)
|
|
end
|
|
|
|
describe 'when an issue `issue_type` is edited' do
|
|
before do
|
|
sign_in(user)
|
|
|
|
visit project_issue_path(project, issue)
|
|
wait_for_requests
|
|
end
|
|
|
|
context 'by non-member author' do
|
|
it 'cannot see Incident option' do
|
|
open_issue_edit_form
|
|
|
|
page.within('[data-testid="issuable-form"]') do
|
|
expect(page).to have_content('Issue')
|
|
expect(page).not_to have_content('Incident')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'by reporter' do
|
|
let(:user) { reporter }
|
|
|
|
it 'routes the user to the incident details page when the `issue_type` is set to incident' do
|
|
open_issue_edit_form
|
|
|
|
page.within('[data-testid="issuable-form"]') do
|
|
update_type_select('Issue', 'Incident')
|
|
|
|
expect(page).to have_current_path(incident_project_issues_path(project, issue))
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'when an incident `issue_type` is edited' do
|
|
before do
|
|
sign_in(user)
|
|
|
|
visit project_issue_path(project, incident)
|
|
wait_for_requests
|
|
end
|
|
|
|
context 'by non-member author' do
|
|
it 'cannot edit issuable' do
|
|
page.within('.content') do
|
|
expect(page).to have_no_button('Edit title and description')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'by reporter' do
|
|
let(:user) { reporter }
|
|
|
|
it 'routes the user to the issue details page when the `issue_type` is set to issue' do
|
|
open_issue_edit_form
|
|
|
|
page.within('[data-testid="issuable-form"]') do
|
|
update_type_select('Incident', 'Issue')
|
|
|
|
expect(page).to have_current_path(project_issue_path(project, incident))
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
def update_type_select(from, to)
|
|
click_button from
|
|
find('[data-testid="issue-type-list-item"]', text: to).click
|
|
click_button 'Save changes'
|
|
|
|
wait_for_requests
|
|
end
|
|
|
|
def open_issue_edit_form
|
|
wait_for_requests
|
|
click_button 'Edit title and description'
|
|
wait_for_requests
|
|
end
|
|
end
|