0ce6785851
Replaces all the explicit include metadata syntax in the specs (tag: true) into the implicit one (:tag). Added a cop to prevent future errors and handle autocorrection.
130 lines
3.6 KiB
Ruby
130 lines
3.6 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe "Admin::Projects" do
|
|
include Select2Helper
|
|
|
|
let(:user) { create :user }
|
|
let(:project) { create(:project) }
|
|
let(:current_user) { create(:admin) }
|
|
|
|
before do
|
|
sign_in(current_user)
|
|
end
|
|
|
|
describe "GET /admin/projects" do
|
|
let!(:archived_project) { create :project, :public, :archived }
|
|
|
|
before do
|
|
expect(project).to be_persisted
|
|
visit admin_projects_path
|
|
end
|
|
|
|
it "is ok" do
|
|
expect(current_path).to eq(admin_projects_path)
|
|
end
|
|
|
|
it 'renders projects list without archived project' do
|
|
expect(page).to have_content(project.name)
|
|
expect(page).not_to have_content(archived_project.name)
|
|
end
|
|
|
|
it 'renders all projects', :js do
|
|
find(:css, '#sort-projects-dropdown').click
|
|
click_link 'Show archived projects'
|
|
|
|
expect(page).to have_content(project.name)
|
|
expect(page).to have_content(archived_project.name)
|
|
expect(page).to have_xpath("//span[@class='label label-warning']", text: 'archived')
|
|
end
|
|
|
|
it 'renders only archived projects', :js do
|
|
find(:css, '#sort-projects-dropdown').click
|
|
click_link 'Show archived projects only'
|
|
|
|
expect(page).to have_content(archived_project.name)
|
|
expect(page).not_to have_content(project.name)
|
|
end
|
|
end
|
|
|
|
describe "GET /admin/projects/:namespace_id/:id" do
|
|
before do
|
|
expect(project).to be_persisted
|
|
|
|
visit admin_projects_path
|
|
click_link project.name
|
|
end
|
|
|
|
it "has project info" do
|
|
expect(current_path).to eq admin_project_path(project)
|
|
expect(page).to have_content(project.path)
|
|
expect(page).to have_content(project.name)
|
|
expect(page).to have_content(project.name_with_namespace)
|
|
expect(page).to have_content(project.creator.name)
|
|
end
|
|
end
|
|
|
|
describe 'transfer project' do
|
|
# The gitlab-shell transfer will fail for a project without a repository
|
|
let(:project) { create(:project, :repository) }
|
|
|
|
before do
|
|
create(:group, name: 'Web')
|
|
|
|
allow_any_instance_of(Projects::TransferService)
|
|
.to receive(:move_uploads_to_new_namespace).and_return(true)
|
|
end
|
|
|
|
it 'transfers project to group web', :js do
|
|
visit admin_project_path(project)
|
|
|
|
click_button 'Search for Namespace'
|
|
click_link 'group: web'
|
|
click_button 'Transfer'
|
|
|
|
expect(page).to have_content("Web / #{project.name}")
|
|
expect(page).to have_content('Namespace: Web')
|
|
end
|
|
end
|
|
|
|
describe 'add admin himself to a project' do
|
|
before do
|
|
project.team << [user, :master]
|
|
end
|
|
|
|
it 'adds admin a to a project as developer', :js do
|
|
visit project_project_members_path(project)
|
|
|
|
page.within '.users-project-form' do
|
|
select2(current_user.id, from: '#user_ids', multiple: true)
|
|
select 'Developer', from: 'access_level'
|
|
end
|
|
|
|
click_button 'Add to project'
|
|
|
|
page.within '.content-list' do
|
|
expect(page).to have_content(current_user.name)
|
|
expect(page).to have_content('Developer')
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'admin remove himself from a project' do
|
|
before do
|
|
project.team << [user, :master]
|
|
project.team << [current_user, :developer]
|
|
end
|
|
|
|
it 'removes admin from the project' do
|
|
visit project_project_members_path(project)
|
|
|
|
page.within '.content-list' do
|
|
expect(page).to have_content(current_user.name)
|
|
expect(page).to have_content('Developer')
|
|
end
|
|
|
|
find(:css, '.content-list li', text: current_user.name).find(:css, 'a.btn-remove').click
|
|
|
|
expect(page).not_to have_selector(:css, '.content-list')
|
|
end
|
|
end
|
|
end
|