summaryrefslogtreecommitdiffstats
path: root/test/functional/projects_controller_test.rb
diff options
context:
space:
mode:
authorEric Davis <edavis@littlestreamsoftware.com>2010-09-06 14:53:08 +0000
committerEric Davis <edavis@littlestreamsoftware.com>2010-09-06 14:53:08 +0000
commit763ab079424eb286d781abb9d8f5adb682b0ce9e (patch)
tree9b966bfc2799e0f5ba6483b0b7d171d812a33b14 /test/functional/projects_controller_test.rb
parent9da4ee5fcce2d20e125acc64377564a2797d1cbb (diff)
downloadredmine-763ab079424eb286d781abb9d8f5adb682b0ce9e.tar.gz
redmine-763ab079424eb286d781abb9d8f5adb682b0ce9e.zip
Refactor: split ProjectsController#add into #add (GET) and #create (POST).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4067 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/functional/projects_controller_test.rb')
-rw-r--r--test/functional/projects_controller_test.rb85
1 files changed, 55 insertions, 30 deletions
diff --git a/test/functional/projects_controller_test.rb b/test/functional/projects_controller_test.rb
index 4decb060f..6b8c84728 100644
--- a/test/functional/projects_controller_test.rb
+++ b/test/functional/projects_controller_test.rb
@@ -98,9 +98,53 @@ class ProjectsControllerTest < ActionController::TestCase
assert_response :success
assert_template 'add'
end
+
+ end
+
+ context "by non-admin user with add_project permission" do
+ setup do
+ Role.non_member.add_permission! :add_project
+ @request.session[:user_id] = 9
+ end
+
+ should "accept get" do
+ get :add
+ assert_response :success
+ assert_template 'add'
+ assert_no_tag :select, :attributes => {:name => 'project[parent_id]'}
+ end
+ end
+
+ context "by non-admin user with add_subprojects permission" do
+ setup do
+ Role.find(1).remove_permission! :add_project
+ Role.find(1).add_permission! :add_subprojects
+ @request.session[:user_id] = 2
+ end
+
+ should "accept get" do
+ get :add, :parent_id => 'ecookbook'
+ assert_response :success
+ assert_template 'add'
+ # parent project selected
+ assert_tag :select, :attributes => {:name => 'project[parent_id]'},
+ :child => {:tag => 'option', :attributes => {:value => '1', :selected => 'selected'}}
+ # no empty value
+ assert_no_tag :select, :attributes => {:name => 'project[parent_id]'},
+ :child => {:tag => 'option', :attributes => {:value => ''}}
+ end
+ end
+
+ end
+
+ context "POST :create" do
+ context "by admin user" do
+ setup do
+ @request.session[:user_id] = 1
+ end
- should "accept post" do
- post :add, :project => { :name => "blog",
+ should "create a new project" do
+ post :create, :project => { :name => "blog",
:description => "weblog",
:identifier => "blog",
:is_public => 1,
@@ -115,8 +159,8 @@ class ProjectsControllerTest < ActionController::TestCase
assert_nil project.parent
end
- should "accept post with parent" do
- post :add, :project => { :name => "blog",
+ should "create a new subproject" do
+ post :create, :project => { :name => "blog",
:description => "weblog",
:identifier => "blog",
:is_public => 1,
@@ -137,15 +181,8 @@ class ProjectsControllerTest < ActionController::TestCase
@request.session[:user_id] = 9
end
- should "accept get" do
- get :add
- assert_response :success
- assert_template 'add'
- assert_no_tag :select, :attributes => {:name => 'project[parent_id]'}
- end
-
- should "accept post" do
- post :add, :project => { :name => "blog",
+ should "accept create a Project" do
+ post :create, :project => { :name => "blog",
:description => "weblog",
:identifier => "blog",
:is_public => 1,
@@ -166,7 +203,7 @@ class ProjectsControllerTest < ActionController::TestCase
should "fail with parent_id" do
assert_no_difference 'Project.count' do
- post :add, :project => { :name => "blog",
+ post :create, :project => { :name => "blog",
:description => "weblog",
:identifier => "blog",
:is_public => 1,
@@ -188,20 +225,8 @@ class ProjectsControllerTest < ActionController::TestCase
@request.session[:user_id] = 2
end
- should "accept get" do
- get :add, :parent_id => 'ecookbook'
- assert_response :success
- assert_template 'add'
- # parent project selected
- assert_tag :select, :attributes => {:name => 'project[parent_id]'},
- :child => {:tag => 'option', :attributes => {:value => '1', :selected => 'selected'}}
- # no empty value
- assert_no_tag :select, :attributes => {:name => 'project[parent_id]'},
- :child => {:tag => 'option', :attributes => {:value => ''}}
- end
-
- should "accept post with parent_id" do
- post :add, :project => { :name => "blog",
+ should "create a project with a parent_id" do
+ post :create, :project => { :name => "blog",
:description => "weblog",
:identifier => "blog",
:is_public => 1,
@@ -214,7 +239,7 @@ class ProjectsControllerTest < ActionController::TestCase
should "fail without parent_id" do
assert_no_difference 'Project.count' do
- post :add, :project => { :name => "blog",
+ post :create, :project => { :name => "blog",
:description => "weblog",
:identifier => "blog",
:is_public => 1,
@@ -230,7 +255,7 @@ class ProjectsControllerTest < ActionController::TestCase
should "fail with unauthorized parent_id" do
assert !User.find(2).member_of?(Project.find(6))
assert_no_difference 'Project.count' do
- post :add, :project => { :name => "blog",
+ post :create, :project => { :name => "blog",
:description => "weblog",
:identifier => "blog",
:is_public => 1,