debian-mirror-gitlab/spec/features/projects/new_project_spec.rb

347 lines
12 KiB
Ruby
Raw Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
2017-09-10 17:25:29 +05:30
require 'spec_helper'
2016-11-24 13:41:30 +05:30
2021-02-22 17:27:13 +05:30
RSpec.describe 'New project', :js do
2018-03-17 18:26:18 +05:30
include Select2Helper
2019-09-30 21:07:59 +05:30
context 'as a user' do
let(:user) { create(:user) }
2016-11-24 13:41:30 +05:30
2019-09-30 21:07:59 +05:30
before do
sign_in(user)
end
2016-11-24 13:41:30 +05:30
2019-09-30 21:07:59 +05:30
it 'shows a message if multiple levels are restricted' do
Gitlab::CurrentSettings.update!(
restricted_visibility_levels: [Gitlab::VisibilityLevel::PRIVATE, Gitlab::VisibilityLevel::INTERNAL]
)
2017-09-10 17:25:29 +05:30
2019-09-30 21:07:59 +05:30
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2017-09-10 17:25:29 +05:30
2019-09-30 21:07:59 +05:30
expect(page).to have_content 'Other visibility settings have been disabled by the administrator.'
end
2018-03-17 18:26:18 +05:30
2019-09-30 21:07:59 +05:30
it 'shows a message if all levels are restricted' do
Gitlab::CurrentSettings.update!(
restricted_visibility_levels: Gitlab::VisibilityLevel.values
)
2017-09-10 17:25:29 +05:30
2018-11-18 11:00:15 +05:30
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2018-11-18 11:00:15 +05:30
2019-09-30 21:07:59 +05:30
expect(page).to have_content 'Visibility settings have been disabled by the administrator.'
2018-11-18 11:00:15 +05:30
end
2019-09-30 21:07:59 +05:30
end
2018-11-18 11:00:15 +05:30
2019-09-30 21:07:59 +05:30
context 'as an admin' do
let(:user) { create(:admin) }
2018-11-18 11:00:15 +05:30
2019-09-30 21:07:59 +05:30
before do
sign_in(user)
2018-11-18 11:00:15 +05:30
end
2019-09-30 21:07:59 +05:30
it 'shows "New project" page', :js do
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2016-11-24 13:41:30 +05:30
2019-09-30 21:07:59 +05:30
expect(page).to have_content('Project name')
expect(page).to have_content('Project URL')
expect(page).to have_content('Project slug')
2017-08-17 22:00:37 +05:30
2021-02-22 17:27:13 +05:30
click_link('New project')
find('[data-qa-selector="import_project_link"]').click
2017-08-17 22:00:37 +05:30
2019-09-30 21:07:59 +05:30
expect(page).to have_link('GitHub')
expect(page).to have_link('Bitbucket')
expect(page).to have_link('GitLab.com')
expect(page).to have_button('Repo by URL')
expect(page).to have_link('GitLab export')
2017-08-17 22:00:37 +05:30
end
2019-09-04 21:01:54 +05:30
2019-09-30 21:07:59 +05:30
describe 'manifest import option' do
2019-09-04 21:01:54 +05:30
before do
2019-09-30 21:07:59 +05:30
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="import_project_link"]').click
2019-09-04 21:01:54 +05:30
end
2019-10-12 21:52:04 +05:30
it { expect(page).to have_link('Manifest file') }
2019-09-04 21:01:54 +05:30
end
2019-09-30 21:07:59 +05:30
context 'Visibility level selector', :js do
Gitlab::VisibilityLevel.options.each do |key, level|
it "sets selector to #{key}" do
stub_application_setting(default_project_visibility: level)
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2019-09-30 21:07:59 +05:30
page.within('#blank-project-pane') do
expect(find_field("project_visibility_level_#{level}")).to be_checked
end
end
2019-09-04 21:01:54 +05:30
2019-09-30 21:07:59 +05:30
it "saves visibility level #{level} on validation error" do
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2019-09-04 21:01:54 +05:30
2021-04-17 20:07:23 +05:30
choose(key)
2019-09-30 21:07:59 +05:30
click_button('Create project')
page.within('#blank-project-pane') do
expect(find_field("project_visibility_level_#{level}")).to be_checked
end
2019-09-04 21:01:54 +05:30
end
end
2017-08-17 22:00:37 +05:30
2019-09-30 21:07:59 +05:30
context 'when group visibility is private but default is internal' do
2021-04-17 20:07:23 +05:30
let_it_be(:group) { create(:group, visibility_level: Gitlab::VisibilityLevel::PRIVATE) }
2019-09-30 21:07:59 +05:30
before do
stub_application_setting(default_project_visibility: Gitlab::VisibilityLevel::INTERNAL)
end
2018-11-08 19:23:39 +05:30
2021-04-17 20:07:23 +05:30
context 'when admin mode is enabled', :enable_admin_mode do
it 'has private selected' do
visit new_project_path(namespace_id: group.id)
find('[data-qa-selector="blank_project_link"]').click
2018-12-05 23:21:45 +05:30
2021-04-17 20:07:23 +05:30
page.within('#blank-project-pane') do
expect(find_field("project_visibility_level_#{Gitlab::VisibilityLevel::PRIVATE}")).to be_checked
end
end
end
context 'when admin mode is disabled' do
it 'is not allowed' do
visit new_project_path(namespace_id: group.id)
expect(page).to have_content('Not Found')
2019-09-30 21:07:59 +05:30
end
end
end
context 'when group visibility is public but user requests private' do
2021-04-17 20:07:23 +05:30
let_it_be(:group) { create(:group, visibility_level: Gitlab::VisibilityLevel::PUBLIC) }
2019-09-30 21:07:59 +05:30
before do
stub_application_setting(default_project_visibility: Gitlab::VisibilityLevel::INTERNAL)
end
2018-12-05 23:21:45 +05:30
2021-04-17 20:07:23 +05:30
context 'when admin mode is enabled', :enable_admin_mode do
it 'has private selected' do
visit new_project_path(namespace_id: group.id, project: { visibility_level: Gitlab::VisibilityLevel::PRIVATE })
find('[data-qa-selector="blank_project_link"]').click
2019-09-30 21:07:59 +05:30
2021-04-17 20:07:23 +05:30
page.within('#blank-project-pane') do
expect(find_field("project_visibility_level_#{Gitlab::VisibilityLevel::PRIVATE}")).to be_checked
end
end
end
context 'when admin mode is disabled' do
it 'is not allowed' do
visit new_project_path(namespace_id: group.id, project: { visibility_level: Gitlab::VisibilityLevel::PRIVATE })
expect(page).to have_content('Not Found')
2019-09-30 21:07:59 +05:30
end
end
2018-12-05 23:21:45 +05:30
end
end
2019-09-30 21:07:59 +05:30
context 'Readme selector' do
it 'shows the initialize with Readme checkbox on "Blank project" tab' do
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2018-12-05 23:21:45 +05:30
2019-09-30 21:07:59 +05:30
expect(page).to have_css('input#project_initialize_with_readme')
expect(page).to have_content('Initialize repository with a README')
2018-12-05 23:21:45 +05:30
end
2018-11-08 19:23:39 +05:30
2019-09-30 21:07:59 +05:30
it 'does not show the initialize with Readme checkbox on "Create from template" tab' do
2017-08-17 22:00:37 +05:30
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="create_from_template_link"]').click
2019-09-30 21:07:59 +05:30
first('.choose-template').click
page.within '.project-fields-form' do
expect(page).not_to have_css('input#project_initialize_with_readme')
expect(page).not_to have_content('Initialize repository with a README')
end
2017-08-17 22:00:37 +05:30
end
2019-09-30 21:07:59 +05:30
it 'does not show the initialize with Readme checkbox on "Import project" tab' do
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="import_project_link"]').click
2019-09-30 21:07:59 +05:30
first('.js-import-git-toggle-button').click
2017-08-17 22:00:37 +05:30
2019-09-30 21:07:59 +05:30
page.within '.toggle-import-form' do
expect(page).not_to have_css('input#project_initialize_with_readme')
expect(page).not_to have_content('Initialize repository with a README')
2018-03-17 18:26:18 +05:30
end
2017-08-17 22:00:37 +05:30
end
end
2019-09-30 21:07:59 +05:30
context 'Namespace selector' do
context 'with user namespace' do
before do
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2019-09-30 21:07:59 +05:30
end
2017-08-17 22:00:37 +05:30
2019-09-30 21:07:59 +05:30
it 'selects the user namespace' do
page.within('#blank-project-pane') do
2021-02-22 17:27:13 +05:30
expect(page).to have_select('project[namespace_id]', visible: false, selected: user.username)
2019-09-30 21:07:59 +05:30
end
end
2017-08-17 22:00:37 +05:30
end
2019-09-30 21:07:59 +05:30
context 'with group namespace' do
let(:group) { create(:group, :private) }
2017-08-17 22:00:37 +05:30
2019-09-30 21:07:59 +05:30
before do
group.add_owner(user)
visit new_project_path(namespace_id: group.id)
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2017-08-17 22:00:37 +05:30
end
2019-09-30 21:07:59 +05:30
it 'selects the group namespace' do
page.within('#blank-project-pane') do
2021-02-22 17:27:13 +05:30
expect(page).to have_select('project[namespace_id]', visible: false, selected: group.name)
2019-09-30 21:07:59 +05:30
end
end
2017-08-17 22:00:37 +05:30
end
2019-09-30 21:07:59 +05:30
context 'with subgroup namespace' do
let(:group) { create(:group) }
let(:subgroup) { create(:group, parent: group) }
2018-03-17 18:26:18 +05:30
2019-09-30 21:07:59 +05:30
before do
group.add_maintainer(user)
visit new_project_path(namespace_id: subgroup.id)
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2018-03-17 18:26:18 +05:30
end
2019-09-30 21:07:59 +05:30
it 'selects the group namespace' do
page.within('#blank-project-pane') do
2021-02-22 17:27:13 +05:30
expect(page).to have_select('project[namespace_id]', visible: false, selected: subgroup.full_path)
2019-09-30 21:07:59 +05:30
end
end
2018-03-17 18:26:18 +05:30
end
2017-08-17 22:00:37 +05:30
2019-09-30 21:07:59 +05:30
context 'when changing namespaces dynamically', :js do
let(:public_group) { create(:group, :public) }
let(:internal_group) { create(:group, :internal) }
let(:private_group) { create(:group, :private) }
2017-08-17 22:00:37 +05:30
2019-09-30 21:07:59 +05:30
before do
public_group.add_owner(user)
internal_group.add_owner(user)
private_group.add_owner(user)
visit new_project_path(namespace_id: public_group.id)
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2019-09-30 21:07:59 +05:30
end
it 'enables the correct visibility options' do
select2(user.namespace_id, from: '#project_namespace_id')
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::PRIVATE}")).not_to be_disabled
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::INTERNAL}")).not_to be_disabled
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::PUBLIC}")).not_to be_disabled
select2(public_group.id, from: '#project_namespace_id')
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::PRIVATE}")).not_to be_disabled
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::INTERNAL}")).not_to be_disabled
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::PUBLIC}")).not_to be_disabled
select2(internal_group.id, from: '#project_namespace_id')
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::PRIVATE}")).not_to be_disabled
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::INTERNAL}")).not_to be_disabled
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::PUBLIC}")).to be_disabled
select2(private_group.id, from: '#project_namespace_id')
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::PRIVATE}")).not_to be_disabled
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::INTERNAL}")).to be_disabled
expect(find("#project_visibility_level_#{Gitlab::VisibilityLevel::PUBLIC}")).to be_disabled
end
end
2017-08-17 22:00:37 +05:30
end
2019-09-30 21:07:59 +05:30
context 'Import project options', :js do
2017-09-10 17:25:29 +05:30
before do
2019-09-30 21:07:59 +05:30
visit new_project_path
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="import_project_link"]').click
2017-09-10 17:25:29 +05:30
end
2019-09-30 21:07:59 +05:30
context 'from git repository url, "Repo by URL"' do
before do
first('.js-import-git-toggle-button').click
end
it 'does not autocomplete sensitive git repo URL' do
autocomplete = find('#project_import_url')['autocomplete']
2017-09-10 17:25:29 +05:30
2019-09-30 21:07:59 +05:30
expect(autocomplete).to eq('off')
end
2017-09-10 17:25:29 +05:30
2019-09-30 21:07:59 +05:30
it 'shows import instructions' do
git_import_instructions = first('.js-toggle-content')
2017-08-17 22:00:37 +05:30
2019-09-30 21:07:59 +05:30
expect(git_import_instructions).to be_visible
expect(git_import_instructions).to have_content 'Git repository URL'
end
2018-03-27 19:54:05 +05:30
2019-09-30 21:07:59 +05:30
it 'keeps "Import project" tab open after form validation error' do
collision_project = create(:project, name: 'test-name-collision', namespace: user.namespace)
2018-03-27 19:54:05 +05:30
2019-09-30 21:07:59 +05:30
fill_in 'project_import_url', with: collision_project.http_url_to_repo
fill_in 'project_name', with: collision_project.name
2018-03-27 19:54:05 +05:30
2019-09-30 21:07:59 +05:30
click_on 'Create project'
2018-03-27 19:54:05 +05:30
2019-09-30 21:07:59 +05:30
expect(page).to have_css('#import-project-pane.active')
expect(page).not_to have_css('.toggle-import-form.hide')
end
2018-03-27 19:54:05 +05:30
end
2017-09-10 17:25:29 +05:30
2019-09-30 21:07:59 +05:30
context 'from GitHub' do
before do
first('.js-import-github').click
end
2017-09-10 17:25:29 +05:30
2019-09-30 21:07:59 +05:30
it 'shows import instructions' do
2019-12-04 20:38:33 +05:30
expect(page).to have_content('Authenticate with GitHub')
2019-09-30 21:07:59 +05:30
expect(current_path).to eq new_import_github_path
end
2017-09-10 17:25:29 +05:30
end
2019-10-12 21:52:04 +05:30
context 'from manifest file' do
2019-09-30 21:07:59 +05:30
before do
first('.import_manifest').click
end
2018-11-18 11:00:15 +05:30
2019-09-30 21:07:59 +05:30
it 'shows import instructions' do
expect(page).to have_content('Manifest file import')
expect(current_path).to eq new_import_manifest_path
end
2018-11-18 11:00:15 +05:30
end
end
2019-07-07 11:18:12 +05:30
2019-09-30 21:07:59 +05:30
context 'Namespace selector' do
context 'with group with DEVELOPER_MAINTAINER_PROJECT_ACCESS project_creation_level' do
let(:group) { create(:group, project_creation_level: ::Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS) }
2019-07-07 11:18:12 +05:30
2019-09-30 21:07:59 +05:30
before do
group.add_developer(user)
visit new_project_path(namespace_id: group.id)
2021-02-22 17:27:13 +05:30
find('[data-qa-selector="blank_project_link"]').click
2019-09-30 21:07:59 +05:30
end
2019-07-07 11:18:12 +05:30
2019-09-30 21:07:59 +05:30
it 'selects the group namespace' do
page.within('#blank-project-pane') do
2021-02-22 17:27:13 +05:30
expect(page).to have_select('project[namespace_id]', visible: false, selected: group.full_path)
2019-09-30 21:07:59 +05:30
end
2019-07-07 11:18:12 +05:30
end
end
end
end
2016-11-24 13:41:30 +05:30
end