53 lines
No EOL
1.9 KiB
Ruby
53 lines
No EOL
1.9 KiB
Ruby
require 'test_helper'
|
|
|
|
module SessionTest
|
|
module ParamsTest
|
|
class ConfigTest < ActiveSupport::TestCase
|
|
def test_params_key
|
|
UserSession.params_key = "my_params_key"
|
|
assert_equal "my_params_key", UserSession.params_key
|
|
|
|
UserSession.params_key "user_credentials"
|
|
assert_equal "user_credentials", UserSession.params_key
|
|
end
|
|
|
|
def test_single_access_allowed_request_types
|
|
UserSession.single_access_allowed_request_types = ["my request type"]
|
|
assert_equal ["my request type"], UserSession.single_access_allowed_request_types
|
|
|
|
UserSession.single_access_allowed_request_types ["application/rss+xml", "application/atom+xml"]
|
|
assert_equal ["application/rss+xml", "application/atom+xml"], UserSession.single_access_allowed_request_types
|
|
end
|
|
end
|
|
|
|
class InstanceMethodsTest < ActiveSupport::TestCase
|
|
def test_persist_persist_by_params
|
|
ben = users(:ben)
|
|
session = UserSession.new
|
|
|
|
assert !session.persisting?
|
|
set_params_for(ben)
|
|
|
|
assert !session.persisting?
|
|
assert !session.unauthorized_record
|
|
assert !session.record
|
|
assert_nil controller.session["user_credentials"]
|
|
|
|
set_request_content_type("text/plain")
|
|
assert !session.persisting?
|
|
assert !session.unauthorized_record
|
|
assert_nil controller.session["user_credentials"]
|
|
|
|
set_request_content_type("application/atom+xml")
|
|
assert session.persisting?
|
|
assert_equal ben, session.record
|
|
assert_nil controller.session["user_credentials"] # should not persist since this is single access
|
|
|
|
set_request_content_type("application/rss+xml")
|
|
assert session.persisting?
|
|
assert_equal ben, session.unauthorized_record
|
|
assert_nil controller.session["user_credentials"]
|
|
end
|
|
end
|
|
end
|
|
end |