Browse Source

Adds a few functional tests.

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3013 e93f8b46-1217-0410-a6f0-8f06a7374b81
tags/0.9.0
Jean-Philippe Lang 14 years ago
parent
commit
3b9d8c2a72

+ 6
- 0
test/fixtures/issue_relations.yml View File

@@ -4,4 +4,10 @@ issue_relation_001:
issue_to_id: 9
relation_type: blocks
delay:
issue_relation_002:
id: 2
issue_from_id: 2
issue_to_id: 3
relation_type: relates
delay:

+ 15
- 7
test/functional/issue_relations_controller_test.rb View File

@@ -13,6 +13,7 @@ class IssueRelationsControllerTest < ActionController::TestCase
:member_roles,
:issues,
:issue_statuses,
:issue_relations,
:enabled_modules,
:enumerations,
:trackers
@@ -31,13 +32,6 @@ class IssueRelationsControllerTest < ActionController::TestCase
)
end
def test_destroy_routing
assert_recognizes( #TODO: use DELETE on issue URI
{:controller => 'issue_relations', :action => 'destroy', :issue_id => '1', :id => '23'},
{:method => :post, :path => '/issues/1/relations/23/destroy'}
)
end
def test_new
assert_difference 'IssueRelation.count' do
@request.session[:user_id] = 3
@@ -56,4 +50,18 @@ class IssueRelationsControllerTest < ActionController::TestCase
:relation => {:issue_to_id => '4', :relation_type => 'relates', :delay => ''}
end
end
def test_destroy_routing
assert_recognizes( #TODO: use DELETE on issue URI
{:controller => 'issue_relations', :action => 'destroy', :issue_id => '1', :id => '23'},
{:method => :post, :path => '/issues/1/relations/23/destroy'}
)
end
def test_destroy
assert_difference 'IssueRelation.count', -1 do
@request.session[:user_id] = 3
post :destroy, :id => '2', :issue_id => '3'
end
end
end

+ 73
- 0
test/functional/issue_statuses_controller_test.rb View File

@@ -0,0 +1,73 @@
require File.dirname(__FILE__) + '/../test_helper'
require 'issue_statuses_controller'

# Re-raise errors caught by the controller.
class IssueStatusesController; def rescue_action(e) raise e end; end


class IssueStatusesControllerTest < ActionController::TestCase
fixtures :issue_statuses, :issues
def setup
@controller = IssueStatusesController.new
@request = ActionController::TestRequest.new
@response = ActionController::TestResponse.new
User.current = nil
@request.session[:user_id] = 1 # admin
end
def test_index
# TODO: unify with #list
get :index
assert_response :success
assert_template 'list'
end
def test_new
get :new
assert_response :success
assert_template 'new'
end
def test_create
assert_difference 'IssueStatus.count' do
post :create, :issue_status => {:name => 'New status'}
end
assert_redirected_to 'issue_statuses/list'
status = IssueStatus.find(:first, :order => 'id DESC')
assert_equal 'New status', status.name
end
def test_edit
get :edit, :id => '3'
assert_response :success
assert_template 'edit'
end
def test_update
post :update, :id => '3', :issue_status => {:name => 'Renamed status'}
assert_redirected_to 'issue_statuses/list'
status = IssueStatus.find(3)
assert_equal 'Renamed status', status.name
end
def test_destroy
Issue.delete_all("status_id = 1")
assert_difference 'IssueStatus.count', -1 do
post :destroy, :id => '1'
end
assert_redirected_to 'issue_statuses/list'
assert_nil IssueStatus.find_by_id(1)
end
def test_destroy_should_block_if_status_in_use
assert_not_nil Issue.find_by_status_id(1)
assert_no_difference 'IssueStatus.count' do
post :destroy, :id => '1'
end
assert_redirected_to 'issue_statuses/list'
assert_not_nil IssueStatus.find_by_id(1)
end
end

+ 6
- 0
test/functional/settings_controller_test.rb View File

@@ -32,6 +32,12 @@ class SettingsControllerTest < ActionController::TestCase
@request.session[:user_id] = 1 # admin
end
def test_index
get :index
assert_response :success
assert_template 'edit'
end
def test_get_edit
get :edit
assert_response :success

Loading…
Cancel
Save