Add some testcases:
authorJohn Dong <jdong@mit.edu>
Fri, 17 Aug 2007 18:04:04 +0000 (14:04 -0400)
committerJohn Dong <jdong@mit.edu>
Fri, 17 Aug 2007 18:04:04 +0000 (14:04 -0400)
  * Create a new quickvote
  * Retrieve a quickvote
  * Casting a quickvote

test/unit/selectricityservice_test.rb

index 631110a09694ee76230ca5baee81f631f16276c7..2560fdad7952d1f0b55b1a91a952ce87e33865e3 100644 (file)
@@ -13,4 +13,32 @@ class SelectricityServiceTest < Test::Unit::TestCase
     assert_instance_of Array, result
     assert_equal result.length, 0
   end
+  def test_create_quickvote
+    election = ElectionStruct.new :name => "TestVote", :description => "Test Vote", :candidate_names => ["Apple", "Orange", "Banana", "Pineapple"]
+    result = invoke_delegated :vote, :create_quickvote, election
+    assert_instance_of String, result
+    assert_equal "", result
+    assert_equal(invoke_delegated(:vote,:list_quickvotes).length, 1)
+  end
+  def test_get_quickvote
+    test_create_quickvote
+    result = invoke_delegated :vote, :get_quickvote, "TestVote"
+    assert_instance_of ElectionStruct, result
+    assert_equal 0, result.name.casecmp("TestVote")
+    assert_equal result.description, "Test Vote"
+    assert_equal result.candidate_names.sort, ["Apple", "Orange", "Banana", "Pineapple"].sort
+    assert_not_nil result.id
+    assert result.id != 0
+    assert_nil result.candidate_ids.uniq!
+    assert result.candidate_ids.length == result.candidate_names.length
+  end
+  def test_cast_quickvote
+    test_create_quickvote
+    election = invoke_delegated :vote, :get_quickvote, "TestVote"
+    casted_vote = election.candidate_ids.sort_by {rand} #Shuffles
+    invoke_delegated :vote, :cast_quickvote, "TestVote", 42, [casted_vote]
+    quickvote_votes= invoke_delegated :vote, :get_quickvote_votes, "TestVote"
+    assert_equal quickvote_votes.length, 1
+    assert_equal quickvote_votes[0].vote, casted_vote
+  end
 end

Benjamin Mako Hill || Want to submit a patch?