0db5ccc80e
Fix #48934 - Focus on text input on danger confirmation Closes #48934 See merge request gitlab-org/gitlab-ce!20435
222 lines
6.1 KiB
Ruby
222 lines
6.1 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe 'Project' do
|
|
include ProjectForksHelper
|
|
|
|
describe 'creating from template' do
|
|
let(:user) { create(:user) }
|
|
let(:template) { Gitlab::ProjectTemplate.find(:rails) }
|
|
|
|
before do
|
|
sign_in user
|
|
visit new_project_path
|
|
end
|
|
|
|
it "allows creation from templates", :js do
|
|
find('#create-from-template-tab').click
|
|
find("label[for=#{template.name}]").click
|
|
fill_in("project_path", with: template.name)
|
|
|
|
page.within '#content-body' do
|
|
click_button "Create project"
|
|
end
|
|
|
|
expect(page).to have_content template.name
|
|
end
|
|
end
|
|
|
|
describe 'shows tip about push to create git command' do
|
|
let(:user) { create(:user) }
|
|
|
|
before do
|
|
sign_in user
|
|
visit new_project_path
|
|
end
|
|
|
|
it 'shows the command in a popover', :js do
|
|
page.within '.profile-settings-sidebar' do
|
|
click_link 'Show command'
|
|
end
|
|
|
|
expect(page).to have_css('.popover .push-to-create-popover #push_to_create_tip')
|
|
expect(page).to have_content 'Private projects can be created in your personal namespace with:'
|
|
end
|
|
end
|
|
|
|
describe 'description' do
|
|
let(:project) { create(:project, :repository) }
|
|
let(:path) { project_path(project) }
|
|
|
|
before do
|
|
sign_in(create(:admin))
|
|
end
|
|
|
|
it 'parses Markdown' do
|
|
project.update_attribute(:description, 'This is **my** project')
|
|
visit path
|
|
expect(page).to have_css('.project-home-desc > p > strong')
|
|
end
|
|
|
|
it 'passes through html-pipeline' do
|
|
project.update_attribute(:description, 'This project is the :poop:')
|
|
visit path
|
|
expect(page).to have_css('.project-home-desc > p > gl-emoji')
|
|
end
|
|
|
|
it 'sanitizes unwanted tags' do
|
|
project.update_attribute(:description, "```\ncode\n```")
|
|
visit path
|
|
expect(page).not_to have_css('.project-home-desc code')
|
|
end
|
|
|
|
it 'permits `rel` attribute on links' do
|
|
project.update_attribute(:description, 'https://google.com/')
|
|
visit path
|
|
expect(page).to have_css('.project-home-desc a[rel]')
|
|
end
|
|
end
|
|
|
|
describe 'remove forked relationship', :js do
|
|
let(:user) { create(:user) }
|
|
let(:project) { fork_project(create(:project, :public), user, namespace_id: user.namespace) }
|
|
|
|
before do
|
|
sign_in user
|
|
visit edit_project_path(project)
|
|
end
|
|
|
|
it 'removes fork' do
|
|
expect(page).to have_content 'Remove fork relationship'
|
|
|
|
remove_with_confirm('Remove fork relationship', project.path)
|
|
|
|
expect(page).to have_content 'The fork relationship has been removed.'
|
|
expect(project.reload.forked?).to be_falsey
|
|
expect(page).not_to have_content 'Remove fork relationship'
|
|
end
|
|
end
|
|
|
|
describe 'showing information about source of a project fork' do
|
|
let(:user) { create(:user) }
|
|
let(:base_project) { create(:project, :public, :repository) }
|
|
let(:forked_project) { fork_project(base_project, user, repository: true) }
|
|
|
|
before do
|
|
sign_in user
|
|
end
|
|
|
|
it 'shows a link to the source project when it is available' do
|
|
visit project_path(forked_project)
|
|
|
|
expect(page).to have_content('Forked from')
|
|
expect(page).to have_link(base_project.full_name)
|
|
end
|
|
|
|
it 'does not contain fork network information for the root project' do
|
|
forked_project
|
|
|
|
visit project_path(base_project)
|
|
|
|
expect(page).not_to have_content('In fork network of')
|
|
expect(page).not_to have_content('Forked from')
|
|
end
|
|
|
|
it 'shows the name of the deleted project when the source was deleted' do
|
|
forked_project
|
|
Projects::DestroyService.new(base_project, base_project.owner).execute
|
|
|
|
visit project_path(forked_project)
|
|
|
|
expect(page).to have_content("Forked from #{base_project.full_name} (deleted)")
|
|
end
|
|
|
|
context 'a fork of a fork' do
|
|
let(:fork_of_fork) { fork_project(forked_project, user, repository: true) }
|
|
|
|
it 'links to the base project if the source project is removed' do
|
|
fork_of_fork
|
|
Projects::DestroyService.new(forked_project, user).execute
|
|
|
|
visit project_path(fork_of_fork)
|
|
|
|
expect(page).to have_content("Forked from")
|
|
expect(page).to have_link(base_project.full_name)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'removal', :js do
|
|
let(:user) { create(:user) }
|
|
let(:project) { create(:project, namespace: user.namespace) }
|
|
|
|
before do
|
|
sign_in(user)
|
|
project.add_maintainer(user)
|
|
visit edit_project_path(project)
|
|
end
|
|
|
|
it 'focuses on the confirmation field' do
|
|
click_button 'Remove project'
|
|
|
|
expect(page).to have_selector '#confirm_name_input:focus'
|
|
end
|
|
|
|
it 'removes a project' do
|
|
expect { remove_with_confirm('Remove project', project.path) }.to change { Project.count }.by(-1)
|
|
expect(page).to have_content "Project '#{project.full_name}' is in the process of being deleted."
|
|
expect(Project.all.count).to be_zero
|
|
expect(project.issues).to be_empty
|
|
expect(project.merge_requests).to be_empty
|
|
end
|
|
end
|
|
|
|
describe 'tree view (default view is set to Files)' do
|
|
let(:user) { create(:user, project_view: 'files') }
|
|
let(:project) { create(:forked_project_with_submodules) }
|
|
|
|
before do
|
|
project.add_maintainer(user)
|
|
sign_in user
|
|
visit project_path(project)
|
|
end
|
|
|
|
it 'has working links to files' do
|
|
click_link('PROCESS.md')
|
|
|
|
expect(page.status_code).to eq(200)
|
|
end
|
|
|
|
it 'has working links to directories' do
|
|
click_link('encoding')
|
|
|
|
expect(page.status_code).to eq(200)
|
|
end
|
|
|
|
it 'has working links to submodules' do
|
|
click_link('645f6c4c')
|
|
|
|
expect(page.status_code).to eq(200)
|
|
end
|
|
end
|
|
|
|
describe 'activity view' do
|
|
let(:user) { create(:user, project_view: 'activity') }
|
|
let(:project) { create(:project, :repository) }
|
|
|
|
before do
|
|
project.add_maintainer(user)
|
|
sign_in user
|
|
visit project_path(project)
|
|
end
|
|
|
|
it 'loads activity', :js do
|
|
expect(page).to have_selector('.event-item')
|
|
end
|
|
end
|
|
|
|
def remove_with_confirm(button_text, confirm_with)
|
|
click_button button_text
|
|
fill_in 'confirm_name_input', with: confirm_with
|
|
click_button 'Confirm'
|
|
end
|
|
end
|