Chris@0: require File.dirname(__FILE__) + '/test_helper' Chris@0: Chris@0: class OpenIdAuthenticationTest < Test::Unit::TestCase Chris@0: def setup Chris@0: @controller = Class.new do Chris@0: include OpenIdAuthentication Chris@0: def params() {} end Chris@0: end.new Chris@0: end Chris@0: Chris@0: def test_authentication_should_fail_when_the_identity_server_is_missing Chris@0: open_id_consumer = mock() Chris@0: open_id_consumer.expects(:begin).raises(OpenID::OpenIDError) Chris@0: @controller.expects(:open_id_consumer).returns(open_id_consumer) Chris@0: @controller.expects(:logger).returns(mock(:error => true)) Chris@0: Chris@0: @controller.send(:authenticate_with_open_id, "http://someone.example.com") do |result, identity_url| Chris@0: assert result.missing? Chris@0: assert_equal "Sorry, the OpenID server couldn't be found", result.message Chris@0: end Chris@0: end Chris@0: Chris@0: def test_authentication_should_be_invalid_when_the_identity_url_is_invalid Chris@0: @controller.send(:authenticate_with_open_id, "!") do |result, identity_url| Chris@0: assert result.invalid?, "Result expected to be invalid but was not" Chris@0: assert_equal "Sorry, but this does not appear to be a valid OpenID", result.message Chris@0: end Chris@0: end Chris@0: Chris@0: def test_authentication_should_fail_when_the_identity_server_times_out Chris@0: open_id_consumer = mock() Chris@0: open_id_consumer.expects(:begin).raises(Timeout::Error, "Identity Server took too long.") Chris@0: @controller.expects(:open_id_consumer).returns(open_id_consumer) Chris@0: @controller.expects(:logger).returns(mock(:error => true)) Chris@0: Chris@0: @controller.send(:authenticate_with_open_id, "http://someone.example.com") do |result, identity_url| Chris@0: assert result.missing? Chris@0: assert_equal "Sorry, the OpenID server couldn't be found", result.message Chris@0: end Chris@0: end Chris@0: Chris@0: def test_authentication_should_begin_when_the_identity_server_is_present Chris@0: @controller.expects(:begin_open_id_authentication) Chris@0: @controller.send(:authenticate_with_open_id, "http://someone.example.com") Chris@0: end Chris@0: end