| 
									
										
										
										
											2010-01-14 20:00:17 +00:00
										 |  |  | # Redmine - project management software | 
					
						
							|  |  |  | # Copyright (C) 2006-2010  Jean-Philippe Lang | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  | # modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  | # as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  | # of the License, or (at your option) any later version. | 
					
						
							|  |  |  | #  | 
					
						
							|  |  |  | # This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | # but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | # GNU General Public License for more details. | 
					
						
							|  |  |  | #  | 
					
						
							|  |  |  | # You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | # along with this program; if not, write to the Free Software | 
					
						
							|  |  |  | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-12 23:24:34 +00:00
										 |  |  | require File.expand_path('../../../test_helper', __FILE__) | 
					
						
							| 
									
										
										
										
											2010-01-14 20:00:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-01 15:26:05 +00:00
										 |  |  | class ApiTest::ProjectsTest < ActionController::IntegrationTest | 
					
						
							| 
									
										
										
										
											2010-01-14 20:00:17 +00:00
										 |  |  |   fixtures :projects, :versions, :users, :roles, :members, :member_roles, :issues, :journals, :journal_details, | 
					
						
							|  |  |  |            :trackers, :projects_trackers, :issue_statuses, :enabled_modules, :enumerations, :boards, :messages, | 
					
						
							|  |  |  |            :attachments, :custom_fields, :custom_values, :time_entries | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def setup | 
					
						
							|  |  |  |     Setting.rest_api_enabled = '1' | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2010-11-27 16:37:15 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |   context "GET /projects" do | 
					
						
							|  |  |  |     context ".xml" do | 
					
						
							|  |  |  |       should "return projects" do | 
					
						
							|  |  |  |         get '/projects.xml' | 
					
						
							|  |  |  |         assert_response :success | 
					
						
							|  |  |  |         assert_equal 'application/xml', @response.content_type | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         assert_tag :tag => 'projects', | 
					
						
							|  |  |  |           :child => {:tag => 'project', :child => {:tag => 'id', :content => '1'}} | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     context ".json" do | 
					
						
							|  |  |  |       should "return projects" do | 
					
						
							|  |  |  |         get '/projects.json' | 
					
						
							|  |  |  |         assert_response :success | 
					
						
							|  |  |  |         assert_equal 'application/json', @response.content_type | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         json = ActiveSupport::JSON.decode(response.body) | 
					
						
							|  |  |  |         assert_kind_of Hash, json | 
					
						
							|  |  |  |         assert_kind_of Array, json['projects'] | 
					
						
							|  |  |  |         assert_kind_of Hash, json['projects'].first | 
					
						
							|  |  |  |         assert json['projects'].first.has_key?('id') | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2010-11-27 16:41:52 +00:00
										 |  |  |   end | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |   context "GET /projects/:id" do | 
					
						
							|  |  |  |     context ".xml" do | 
					
						
							|  |  |  |       # TODO: A private project is needed because should_allow_api_authentication | 
					
						
							|  |  |  |       # actually tests that authentication is *required*, not just allowed | 
					
						
							|  |  |  |       should_allow_api_authentication(:get, "/projects/2.xml") | 
					
						
							| 
									
										
										
										
											2010-11-07 14:15:01 +00:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |       should "return requested project" do | 
					
						
							|  |  |  |         get '/projects/1.xml' | 
					
						
							|  |  |  |         assert_response :success | 
					
						
							|  |  |  |         assert_equal 'application/xml', @response.content_type | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         assert_tag :tag => 'project', | 
					
						
							|  |  |  |           :child => {:tag => 'id', :content => '1'} | 
					
						
							|  |  |  |         assert_tag :tag => 'custom_field', | 
					
						
							|  |  |  |           :attributes => {:name => 'Development status'}, :content => 'Stable' | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       context "with hidden custom fields" do | 
					
						
							|  |  |  |         setup do | 
					
						
							|  |  |  |           ProjectCustomField.find_by_name('Development status').update_attribute :visible, false | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         should "not display hidden custom fields" do | 
					
						
							|  |  |  |           get '/projects/1.xml' | 
					
						
							|  |  |  |           assert_response :success | 
					
						
							|  |  |  |           assert_equal 'application/xml', @response.content_type | 
					
						
							|  |  |  |            | 
					
						
							|  |  |  |           assert_no_tag 'custom_field', | 
					
						
							|  |  |  |             :attributes => {:name => 'Development status'} | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2010-11-13 10:05:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |     context ".json" do | 
					
						
							|  |  |  |       should_allow_api_authentication(:get, "/projects/2.json") | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       should "return requested project" do | 
					
						
							|  |  |  |         get '/projects/1.json' | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         json = ActiveSupport::JSON.decode(response.body) | 
					
						
							|  |  |  |         assert_kind_of Hash, json | 
					
						
							|  |  |  |         assert_kind_of Hash, json['project'] | 
					
						
							|  |  |  |         assert_equal 1, json['project']['id'] | 
					
						
							| 
									
										
										
										
											2010-11-27 16:26:13 +00:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2010-01-14 20:00:17 +00:00
										 |  |  |   end | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |   context "POST /projects" do | 
					
						
							|  |  |  |     context "with valid parameters" do | 
					
						
							|  |  |  |       setup do | 
					
						
							| 
									
										
										
										
											2010-12-03 16:15:16 +00:00
										 |  |  |         Setting.default_projects_modules = ['issue_tracking', 'repository'] | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |         @parameters = {:project => {:name => 'API test', :identifier => 'api-test'}} | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       context ".xml" do | 
					
						
							|  |  |  |         should_allow_api_authentication(:post, | 
					
						
							|  |  |  |                                         '/projects.xml', | 
					
						
							|  |  |  |                                         {:project => {:name => 'API test', :identifier => 'api-test'}}, | 
					
						
							|  |  |  |                                         {:success_code => :created}) | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         should "create a project with the attributes" do | 
					
						
							|  |  |  |           assert_difference('Project.count') do | 
					
						
							|  |  |  |             post '/projects.xml', @parameters, :authorization => credentials('admin') | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |           project = Project.first(:order => 'id DESC') | 
					
						
							|  |  |  |           assert_equal 'API test', project.name | 
					
						
							|  |  |  |           assert_equal 'api-test', project.identifier | 
					
						
							| 
									
										
										
										
											2010-12-03 16:15:16 +00:00
										 |  |  |           assert_equal ['issue_tracking', 'repository'], project.enabled_module_names | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |        | 
					
						
							|  |  |  |           assert_response :created | 
					
						
							|  |  |  |           assert_equal 'application/xml', @response.content_type | 
					
						
							|  |  |  |           assert_tag 'project', :child => {:tag => 'id', :content => project.id.to_s} | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     context "with invalid parameters" do | 
					
						
							|  |  |  |       setup do | 
					
						
							|  |  |  |         @parameters = {:project => {:name => 'API test'}} | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       context ".xml" do | 
					
						
							|  |  |  |         should "return errors" do | 
					
						
							|  |  |  |           assert_no_difference('Project.count') do | 
					
						
							|  |  |  |             post '/projects.xml', @parameters, :authorization => credentials('admin') | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |              | 
					
						
							|  |  |  |           assert_response :unprocessable_entity | 
					
						
							|  |  |  |           assert_equal 'application/xml', @response.content_type | 
					
						
							|  |  |  |           assert_tag 'errors', :child => {:tag => 'error', :content => "Identifier can't be blank"} | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2010-01-14 20:00:17 +00:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |   context "PUT /projects/:id" do | 
					
						
							|  |  |  |     context "with valid parameters" do | 
					
						
							|  |  |  |       setup do | 
					
						
							|  |  |  |         @parameters = {:project => {:name => 'API update'}} | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       context ".xml" do | 
					
						
							|  |  |  |         should_allow_api_authentication(:put, | 
					
						
							|  |  |  |                                         '/projects/2.xml', | 
					
						
							|  |  |  |                                         {:project => {:name => 'API update'}}, | 
					
						
							|  |  |  |                                         {:success_code => :ok}) | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         should "update the project" do | 
					
						
							|  |  |  |           assert_no_difference 'Project.count' do | 
					
						
							|  |  |  |             put '/projects/2.xml', @parameters, :authorization => credentials('jsmith') | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |           assert_response :ok | 
					
						
							|  |  |  |           assert_equal 'application/xml', @response.content_type | 
					
						
							|  |  |  |           project = Project.find(2) | 
					
						
							|  |  |  |           assert_equal 'API update', project.name | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2010-11-27 16:32:48 +00:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |     context "with invalid parameters" do | 
					
						
							|  |  |  |       setup do | 
					
						
							|  |  |  |         @parameters = {:project => {:name => ''}} | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       context ".xml" do | 
					
						
							|  |  |  |         should "return errors" do | 
					
						
							|  |  |  |           assert_no_difference('Project.count') do | 
					
						
							|  |  |  |             put '/projects/2.xml', @parameters, :authorization => credentials('admin') | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |              | 
					
						
							|  |  |  |           assert_response :unprocessable_entity | 
					
						
							|  |  |  |           assert_equal 'application/xml', @response.content_type | 
					
						
							|  |  |  |           assert_tag 'errors', :child => {:tag => 'error', :content => "Name can't be blank"} | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2010-11-27 16:32:48 +00:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2010-01-14 20:00:17 +00:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |   context "DELETE /projects/:id" do | 
					
						
							|  |  |  |     context ".xml" do | 
					
						
							|  |  |  |       should_allow_api_authentication(:delete, | 
					
						
							|  |  |  |                                       '/projects/2.xml', | 
					
						
							|  |  |  |                                       {}, | 
					
						
							|  |  |  |                                       {:success_code => :ok}) | 
					
						
							| 
									
										
										
										
											2010-11-27 16:37:15 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2010-12-03 12:49:07 +00:00
										 |  |  |       should "delete the project" do | 
					
						
							|  |  |  |         assert_difference('Project.count',-1) do | 
					
						
							|  |  |  |           delete '/projects/2.xml', {}, :authorization => credentials('admin') | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |         assert_response :ok | 
					
						
							|  |  |  |         assert_nil Project.find_by_id(2) | 
					
						
							| 
									
										
										
										
											2010-11-27 16:37:15 +00:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2010-01-14 20:00:17 +00:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   def credentials(user, password=nil) | 
					
						
							|  |  |  |     ActionController::HttpAuthentication::Basic.encode_credentials(user, password || user) | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |