Sha256: 3bb984646c63518cd0b292b83395b635238d2b70a5d9855f38d3474778532c11
Contents?: true
Size: 1.83 KB
Versions: 2
Compression:
Stored size: 1.83 KB
Contents
module Sorcery module TestHelpers module Rails SUBMODUELS_AUTO_ADDED_CONTROLLER_FILTERS = [:register_last_activity_time_to_db, :deny_banned_user, :validate_session] def sorcery_reload!(submodules = [], options = {}) reload_user_class # return to no-module configuration ::Sorcery::Controller::Config.init! ::Sorcery::Controller::Config.reset! # remove all plugin before_filters so they won't fail other tests. # I don't like this way, but I didn't find another. # hopefully it won't break until Rails 4. ApplicationController._process_action_callbacks.delete_if {|c| SUBMODUELS_AUTO_ADDED_CONTROLLER_FILTERS.include?(c.filter) } # configure ::Sorcery::Controller::Config.submodules = submodules ::Sorcery::Controller::Config.user_class = nil ActionController::Base.send(:include,::Sorcery::Controller) User.activate_sorcery! do |config| options.each do |property,value| config.send(:"#{property}=", value) end end end def sorcery_controller_property_set(property, value) ApplicationController.activate_sorcery! do |config| config.send(:"#{property}=", value) end end def sorcery_controller_oauth_property_set(provider, property, value) ApplicationController.activate_sorcery! do |config| config.send(provider).send(:"#{property}=", value) end end def login_user(user = nil) user ||= @user subject.send(:login_user,user) subject.send(:after_login!,user,[user.username,'secret']) end def logout_user subject.send(:logout) end def clear_user_without_logout subject.instance_variable_set(:@current_user,nil) end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
sorcery-0.3.1 | lib/sorcery/test_helpers/rails.rb |
sorcery-0.3.0 | lib/sorcery/test_helpers/rails.rb |