rosa-build/spec/controllers/platforms/repositories_controller_spe...

218 lines
7.2 KiB
Ruby
Raw Normal View History

2012-01-30 20:39:34 +00:00
# -*- encoding : utf-8 -*-
require 'spec_helper'
shared_examples_for 'not destroy personal repository' do
it 'should not be able to destroy personal repository' do
lambda { delete :destroy, :id => @personal_repository.id, :platform_id =>
@personal_repository.platform.id}.should change{ Repository.count }.by(0)
response.should redirect_to(redirect_path)
end
end
shared_examples_for 'user with change projects in repository rights' do
it 'should be able to see add_project page' do
get :add_project, :id => @repository.id, :platform_id => @platform.id
response.should render_template(:projects_list)
end
it 'should be able to add project to repository' do
get :add_project, :id => @repository.id, :platform_id => @platform.id, :project_id => @project.id
response.should redirect_to(platform_repository_path(@repository.platform, @repository))
@repository.projects.should include(@project)
end
it 'should be able to remove project from repository' do
get :remove_project, :id => @repository.id, :platform_id => @platform.id, :project_id => @project.id
response.should redirect_to(platform_repository_path(@repository.platform, @repository))
@repository.projects.should_not include(@project)
end
end
shared_examples_for 'user without change projects in repository rights' do
it 'should not be able to add project to repository' do
get :add_project, :id => @repository.id, :platform_id => @platform.id, :project_id => @project.id
response.should redirect_to(redirect_path)
@repository.projects.should_not include(@project)
end
it 'should not be able to remove project from repository' do
delete :remove_project, :id => @repository.id, :platform_id => @platform.id, :project_id => @project.id
response.should redirect_to(redirect_path)
@repository.projects.should_not include(@project)
end
end
shared_examples_for 'registered user and guest' do
it 'should not be able to perform new action' do
get :new, :platform_id => @platform.id
response.should redirect_to(redirect_path)
end
it 'should not be able to perform create action' do
post :create, @create_params
lambda { post :create, @create_params }.should change{ Repository.count }.by(0)
response.should redirect_to(redirect_path)
end
it 'should not be able to perform edit action' do
get :edit, :id => @repository.id, :platform_id => @platform.id
response.should redirect_to(redirect_path)
end
it 'should not be able to perform update action' do
put :update, :id => @repository.id, :platform_id => @platform.id
response.should redirect_to(redirect_path)
end
it 'should not be able to destroy repository in main platform' do
delete :destroy, :id => @repository.id
response.should redirect_to(redirect_path)
lambda { delete :destroy, :id => @repository.id }.should_not change{ Repository.count }.by(-1)
end
it_should_behave_like 'not destroy personal repository'
end
shared_examples_for 'registered user' do
it 'should be able to perform index action' do
get :index, :platform_id => @platform.id
response.should render_template(:index)
end
it 'should be able to perform show action' do
get :show, :id => @repository.id
response.should render_template(:show)
end
2012-09-07 10:41:49 +01:00
it 'should be able to perform projects_list action' do
get :projects_list, :id => @repository.id, :platform_id => @platform.id, :format => :json
response.should be_success
end
end
shared_examples_for 'platform admin user' do
it_should_behave_like 'registered user'
it 'should be able to perform new action' do
get :new, :platform_id => @platform.id
response.should render_template(:new)
end
it 'should be able to create repository' do
lambda { post :create, @create_params }.should change{ Repository.count }.by(1)
response.should redirect_to(platform_repository_path(@platform, Repository.last))
end
it 'should be able to destroy repository in main platform' do
lambda { delete :destroy, :id => @repository.id }.should change{ Repository.count }.by(-1)
response.should redirect_to(platform_repositories_path(@repository.platform))
end
it 'should be able to perform edit action' do
get :edit, :id => @repository.id, :platform_id => @platform.id
response.should render_template(:edit)
end
it_should_behave_like 'user with change projects in repository rights'
it_should_behave_like 'not destroy personal repository' do
let(:redirect_path) { forbidden_path }
end
end
describe Platforms::RepositoriesController do
before(:each) do
stub_symlink_methods
@platform = FactoryGirl.create(:platform)
@repository = FactoryGirl.create(:repository, :platform => @platform)
@personal_repository = FactoryGirl.create(:personal_repository)
@project = FactoryGirl.create(:project)
@another_user = FactoryGirl.create(:user)
@create_params = {:repository => {:name => 'pro', :description => 'pro2'}, :platform_id => @platform.id}
2012-09-07 10:41:49 +01:00
@user = FactoryGirl.create(:user)
set_session_for(@user)
end
context 'for guest' do
2012-09-07 10:41:49 +01:00
before(:each) do
set_session_for(User.new)
end
2012-09-07 10:41:49 +01:00
it_should_behave_like 'registered user' if APP_CONFIG['anonymous_access']
let(:redirect_path) { new_user_session_path }
it_should_behave_like 'registered user and guest'
it_should_behave_like 'user without change projects in repository rights'
2012-09-07 10:41:49 +01:00
it "should not be able to perform show action", :anonymous_access => false do
get :show, :id => @repository
response.should redirect_to(new_user_session_path)
end
it "should not be able to perform index action", :anonymous_access => false do
get :index, :platform_id => @platform
response.should redirect_to(new_user_session_path)
end
2012-09-07 10:41:49 +01:00
it 'should not be able to perform projects_list action', :anonymous_access => false do
get :projects_list, :id => @repository.id, :platform_id => @platform.id, :format => :json
response.response_code.should == 401
end
end
context 'for user' do
it_should_behave_like 'registered user'
let(:redirect_path) { forbidden_path }
it_should_behave_like 'registered user and guest'
it_should_behave_like 'user without change projects in repository rights'
end
context 'for admin' do
before(:each) do
2012-09-07 10:41:49 +01:00
@user.role = "admin"
@user.save
end
it_should_behave_like 'platform admin user'
end
context 'for platform owner user' do
before(:each) do
2012-09-07 10:41:49 +01:00
@user = @repository.platform.owner
set_session_for(@user)
end
it_should_behave_like 'platform admin user'
end
2012-09-07 10:41:49 +01:00
context 'for platform member user' do
before(:each) do
2012-09-07 10:41:49 +01:00
@platform.relations.create!(:actor_type => 'User', :actor_id => @user.id, :role => 'admin')
end
2012-09-07 10:41:49 +01:00
it_should_behave_like 'platform admin user'
end
context 'for repository member user' do
before(:each) do
@repository.relations.create!(:actor_type => 'User', :actor_id => @user.id, :role => 'admin')
end
it_should_behave_like 'registered user'
let(:redirect_path) { forbidden_path }
it_should_behave_like 'registered user and guest'
it_should_behave_like 'user with change projects in repository rights'
end
end