Skip to content

Commit

Permalink
Merge branch 'master' of git://github.com/apeckham/recaptcha into ape…
Browse files Browse the repository at this point in the history
…ckham/master
  • Loading branch information
Jason L Perry committed Jun 22, 2008
2 parents 4961180 + a34eab4 commit 8cdc6be
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 13 deletions.
2 changes: 1 addition & 1 deletion lib/recaptcha.rb
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ def verify_recaptcha(model = nil)
:challenge => params[:recaptcha_challenge_field],
:response => params[:recaptcha_response_field]
}
answer, error = recaptcha.body.split.map(&:chomp)
answer, error = recaptcha.body.split.map { |s| s.chomp }
unless answer == 'true'
session[:recaptcha_error] = error
model.valid? if model
Expand Down
12 changes: 0 additions & 12 deletions test/recaptcha_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -35,16 +35,4 @@ def test_should_raise_exception_without_public_key
recaptcha_tags
end
end

def test_should_raise_exception_without_private_key
assert_raise ReCaptchaError do
ENV['RECAPTCHA_PRIVATE_KEY'] = nil
verify_recaptcha
end
end

def test_should_verify_recaptcha
# TODO Mock this, or figure something out...
end

end
78 changes: 78 additions & 0 deletions test/verify_recaptcha_test.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
require 'test/unit'
require 'rubygems'
require 'mocha'
require 'net/http'
require File.dirname(__FILE__) + '/../lib/recaptcha'

class VerifyReCaptchaTest < Test::Unit::TestCase
def setup
ENV['RECAPTCHA_PRIVATE_KEY'] = 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'

@controller = TestController.new
@controller.request = stub(:remote_ip => "1.1.1.1")
@controller.params = {:recaptcha_challenge_field => "challenge", :recaptcha_response_field => "response"}

@expected_post_data = {}
@expected_post_data[:privatekey] = ENV['RECAPTCHA_PRIVATE_KEY']
@expected_post_data[:remoteip] = @controller.request.remote_ip
@expected_post_data[:challenge] = "challenge"
@expected_post_data[:response] = "response"

@expected_uri = URI.parse("http://#{Ambethia::ReCaptcha::RECAPTCHA_VERIFY_SERVER}/verify")
end

def test_should_raise_exception_without_private_key
assert_raise Ambethia::ReCaptcha::ReCaptchaError do
ENV['RECAPTCHA_PRIVATE_KEY'] = nil
@controller.verify_recaptcha
end
end

def test_should_return_false_when_key_is_invalid
expect_http_post(response_with_body("false\ninvalid-site-private-key"))

assert !@controller.verify_recaptcha
assert_equal "invalid-site-private-key", @controller.session[:recaptcha_error]
end

def test_returns_true_on_success
@controller.session[:recaptcha_error] = "previous error that should be cleared"
expect_http_post(response_with_body("true\n"))

assert @controller.verify_recaptcha
assert_nil @controller.session[:recaptcha_error]
end

def test_errors_should_be_added_to_model
expect_http_post(response_with_body("false\nbad-news"))

errors = mock
errors.expects(:add_to_base).with("Captcha response is incorrect, please try again.")

model = mock
model.expects(:valid?)
model.expects(:errors).returns(errors)

assert !@controller.verify_recaptcha(model)
assert_equal "bad-news", @controller.session[:recaptcha_error]
end

private

class TestController
include Ambethia::ReCaptcha::Controller
attr_accessor :request, :params, :session

def initialize
@session = {}
end
end

def expect_http_post(response)
Net::HTTP.expects(:post_form).with(@expected_uri, @expected_post_data).returns(response)
end

def response_with_body(body)
stub(:body => body)
end
end

0 comments on commit 8cdc6be

Please sign in to comment.