X-Git-Url: https://projects.mako.cc/source/selectricity-live/blobdiff_plain/4ae380231b08416a3ac3b6966d9dbc00a73fc3ca..37e11a698234dcc8bcb2faae7203088667a8a561:/test/functional/quickvote_controller_test.rb?ds=inline
diff --git a/test/functional/quickvote_controller_test.rb b/test/functional/quickvote_controller_test.rb
index 07c9278..65dfa2a 100644
--- a/test/functional/quickvote_controller_test.rb
+++ b/test/functional/quickvote_controller_test.rb
@@ -5,7 +5,10 @@ class ActionController::TestSession
def session_id
# Override this so we can set session ID
# pass in the 'test_session_id' session variable to override default
- (@session and @session['test_session_id']) or "12345678"
+ return "12345678" unless @attributes
+ if @attributes.has_key? 'test_session_id'
+ return @attributes['test_session_id']
+ end
end
end
# Re-raise errors caught by the controller.
@@ -18,39 +21,60 @@ class QuickvoteControllerTest < Test::Unit::TestCase
@response = ActionController::TestResponse.new
end
- # Replace this with your real tests.
def test_index
get :index
assert_response 302
end
def test_create_quickvote
- post(:create, {'commit' =>"Create Quickvote", 'quickvote' =>{'name' =>"variable", 'description' =>"Favorite variable."}}, nil, {:candlist=>["foo", "bar", "foobar"]})
+ post(:create, {'commit' =>"Create Quickvote",
+ 'quickvote' =>{'name' =>"variable", 'description' =>"Favorite variable."}},
+ nil, {:candidate_names=>["foo", "bar", "foobar"]})
assert_template "quickvote/success"
get :index, { 'ident' => "variable"}
assert_response :success
end
+ #def test_create_dupe_quickvote
+ # test_create_quickvote
+ # assert_raise(Test::Unit::AssertionFailedError) do
+ # test_create_quickvote
+ # end
+ #end
+
def test_create_quickvote_badname
- post(:create, {'commit' => "Create Quickvote", 'quickvote' => {'name' => "has a space", 'description' => "Foobar"}}, nil, {:candlist => ["foo", "bar", "foobar"]})
- assert_template "quickvote/create"
+ post(:create, {'commit' => "Create Quickvote",
+ 'quickvote' => {'name' => "has a space", 'description' => "Foobar"}},
+ nil, {:candidate_names => ["foo", "bar", "foobar"]})
+ assert_template "quickvote/_create_sidebar"
end
def test_create_quickvote_dupe_candidate
- post(:create, {'commit' => "Create Quickvote", 'quickvote' => {'name' => "has a space", 'description' => "Foobar"}}, nil, {:candlist => ["foo", "bar", "bar", "foobar"]})
- assert_template "quickvote/create"
+ post(:create, {'commit' => "Create Quickvote",
+ 'quickvote' => {'name' => "has a space", 'description' => "Foobar"}},
+ nil, {:candidate_names => ["foo", "bar", "bar", "foobar"]})
+ assert_template "quickvote/_create_sidebar"
end
-
+
+ # TODO these should be testing for something better than a non-method
+ # error!
def test_create_quickvote_nil_candidate
- post(:create, {'commit' => "Create Quickvote", 'quickvote' => {'name' => "has a space", 'description' => "Foobar"}}, nil, {:candlist => nil})
- assert_template "quickvote/create"
- post(:create, {'commit' => "Create Quickvote", 'quickvote' => {'name' => "has a space", 'description' => "Foobar"}}, nil, {:candlist => []})
- assert_template "quickvote/create"
+ assert_raise(NoMethodError) do
+ post(:create, {'commit' => "Create Quickvote",
+ 'quickvote' => {'name' => "has a space", 'description' => "Foobar"}},
+ nil, {:candidate_names => nil})
+ end
+
+ assert_raise(NoMethodError) do
+ post(:create, {'commit' => "Create Quickvote",
+ 'quickvote' => {'name' => "has a space", 'description' => "Foobar"}},
+ nil, {:candidate_names => []})
+ end
end
def test_get_quickvote_nonexistent
get :index, { 'ident' => "idontexist" }
- assert_redirected_to :controller => 'site'
+ assert_redirected_to :controller => 'front'
end
def test_get_result_empty_vote
@@ -62,7 +86,85 @@ class QuickvoteControllerTest < Test::Unit::TestCase
def test_get_result_nonexistent
test_create_quickvote
get :results, { 'ident' => 'asdflaksdjf' }
- assert_redirected_to :controller => 'site'
+ assert_redirected_to :controller => 'front'
+ end
+
+ def test_get_result_with_a_vote
+ test_cast_quickvote
+ get :results, { 'ident' => 'variable' }
+ assert_response :success
end
+ def test_get_result_multi_votes
+ test_create_quickvote
+ votes = QuickVote.ident_to_quickvote('variable').candidates.collect { |c| c.id}
+ 5.times do |time|
+ get :index, { 'ident' => 'variable' }, { 'test_session_id' => (time+1)*50 }
+ assert_response :success
+ post :confirm,
+ { 'ident' => 'variable', 'rankings-list' => votes.sort_by {rand} },
+ { 'test_session_id' => (time+1)*50 }
+ assert_template 'quickvote/thanks'
+ end
+ get :results, { 'ident' => 'variable' }
+ assert_response :success
+ end
+
+ def test_cast_quickvote
+ test_create_quickvote
+ votes = QuickVote.ident_to_quickvote('variable').candidates.collect { |c| c.id}
+ post :confirm, { 'ident' => 'variable', 'rankings-list' => votes.sort_by {rand} }
+ assert_template 'quickvote/thanks'
+ end
+
+ def test_cast_dupe_quickvote
+ test_create_quickvote
+ votes = QuickVote.ident_to_quickvote('variable').candidates.collect { |c| c.id}
+ get :index, { 'ident' => 'variable' }
+ assert_response :success
+
+ post :confirm, { 'ident' => 'variable', 'rankings-list' => votes.sort_by {rand} }
+ assert_template 'quickvote/thanks'
+
+ get :index, { 'ident' => 'variable' }
+ assert_response :success
+ post :confirm, { 'ident' => 'variable', 'rankings-list' => votes.sort_by {rand} }
+ assert_redirected_to :controller => 'quickvote', :ident => 'variable'
+ end
+
+ def test_display_tainted_quickvote
+ # create quickvote with tainted data
+ test_create_quickvote
+ qv=QuickVote.ident_to_quickvote('variable')
+ qv.description=""
+ qv.candidate_names = ["