summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/controllers/issue_statuses_controller.rb15
-rw-r--r--app/views/issue_statuses/index.api.rsb10
-rw-r--r--config/routes.rb1
-rw-r--r--test/functional/issue_statuses_controller_test.rb12
-rw-r--r--test/integration/api_test/issue_statuses_test.rb51
5 files changed, 86 insertions, 3 deletions
diff --git a/app/controllers/issue_statuses_controller.rb b/app/controllers/issue_statuses_controller.rb
index 0be67f401..1f747a4f3 100644
--- a/app/controllers/issue_statuses_controller.rb
+++ b/app/controllers/issue_statuses_controller.rb
@@ -18,14 +18,23 @@
class IssueStatusesController < ApplicationController
layout 'admin'
- before_filter :require_admin
+ before_filter :require_admin, :except => :index
+ before_filter :require_admin_or_api_request, :only => :index
+ accept_api_auth :index
verify :method => :post, :only => [ :destroy, :create, :update, :move, :update_issue_done_ratio ],
:redirect_to => { :action => :index }
def index
- @issue_status_pages, @issue_statuses = paginate :issue_statuses, :per_page => 25, :order => "position"
- render :action => "index", :layout => false if request.xhr?
+ respond_to do |format|
+ format.html {
+ @issue_status_pages, @issue_statuses = paginate :issue_statuses, :per_page => 25, :order => "position"
+ render :action => "index", :layout => false if request.xhr?
+ }
+ format.api {
+ @issue_statuses = IssueStatus.all(:order => 'position')
+ }
+ end
end
def new
diff --git a/app/views/issue_statuses/index.api.rsb b/app/views/issue_statuses/index.api.rsb
new file mode 100644
index 000000000..8a51674d9
--- /dev/null
+++ b/app/views/issue_statuses/index.api.rsb
@@ -0,0 +1,10 @@
+api.array :issue_statuses do
+ @issue_statuses.each do |status|
+ api.issue_status do
+ api.id status.id
+ api.name status.name
+ api.is_default status.is_default
+ api.is_closed status.is_closed
+ end
+ end
+end
diff --git a/config/routes.rb b/config/routes.rb
index 209db1e89..7106be9d5 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -228,6 +228,7 @@ ActionController::Routing::Routes.draw do |map|
#left old routes at the bottom for backwards compat
map.connect 'trackers.:format', :controller => 'trackers', :action => 'index'
+ map.connect 'issue_statuses.:format', :controller => 'issue_statuses', :action => 'index'
map.connect 'projects/:project_id/issues/:action', :controller => 'issues'
map.connect 'projects/:project_id/documents/:action', :controller => 'documents'
map.connect 'projects/:project_id/boards/:action/:id', :controller => 'boards'
diff --git a/test/functional/issue_statuses_controller_test.rb b/test/functional/issue_statuses_controller_test.rb
index c03f30866..d49232605 100644
--- a/test/functional/issue_statuses_controller_test.rb
+++ b/test/functional/issue_statuses_controller_test.rb
@@ -21,6 +21,18 @@ class IssueStatusesControllerTest < ActionController::TestCase
assert_response :success
assert_template 'index'
end
+
+ def test_index_by_anonymous_should_redirect_to_login_form
+ @request.session[:user_id] = nil
+ get :index
+ assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fissue_statuses'
+ end
+
+ def test_index_by_user_should_respond_with_406
+ @request.session[:user_id] = 2
+ get :index
+ assert_response 406
+ end
def test_new
get :new
diff --git a/test/integration/api_test/issue_statuses_test.rb b/test/integration/api_test/issue_statuses_test.rb
new file mode 100644
index 000000000..ed5996bbe
--- /dev/null
+++ b/test/integration/api_test/issue_statuses_test.rb
@@ -0,0 +1,51 @@
+# Redmine - project management software
+# Copyright (C) 2006-2011 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.
+
+require File.expand_path('../../../test_helper', __FILE__)
+
+class ApiTest::IssueStatusesTest < ActionController::IntegrationTest
+ fixtures :issue_statuses
+
+ def setup
+ Setting.rest_api_enabled = '1'
+ end
+
+ context "/issue_statuses" do
+ context "GET" do
+
+ should "return issue statuses" do
+ get '/issue_statuses.xml'
+
+ assert_response :success
+ assert_equal 'application/xml', @response.content_type
+ assert_tag :tag => 'issue_statuses',
+ :attributes => {:type => 'array'},
+ :child => {
+ :tag => 'issue_status',
+ :child => {
+ :tag => 'id',
+ :content => '2',
+ :sibling => {
+ :tag => 'name',
+ :content => 'Assigned'
+ }
+ }
+ }
+ end
+ end
+ end
+end