2010-03-23 11:28:17 -04:00
|
|
|
require 'action_dispatch/testing/integration'
|
2009-10-07 20:46:40 -04:00
|
|
|
|
2010-03-23 11:28:17 -04:00
|
|
|
class ActionDispatch::IntegrationTest
|
2009-10-07 20:46:40 -04:00
|
|
|
def warden
|
|
|
|
request.env['warden']
|
|
|
|
end
|
|
|
|
|
|
|
|
def create_user(options={})
|
|
|
|
@user ||= begin
|
|
|
|
user = User.create!(
|
2010-02-05 19:33:32 -05:00
|
|
|
:username => 'usertest',
|
|
|
|
:email => 'user@test.com',
|
|
|
|
:password => '123456',
|
|
|
|
:password_confirmation => '123456',
|
|
|
|
:created_at => Time.now.utc
|
2009-10-07 20:46:40 -04:00
|
|
|
)
|
|
|
|
user.confirm! unless options[:confirm] == false
|
2010-03-10 10:13:54 -05:00
|
|
|
user.lock_access! if options[:locked] == true
|
2009-10-07 20:46:40 -04:00
|
|
|
user
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2009-10-11 09:49:25 -04:00
|
|
|
def create_admin(options={})
|
|
|
|
@admin ||= begin
|
|
|
|
admin = Admin.create!(
|
|
|
|
:email => 'admin@test.com', :password => '123456', :password_confirmation => '123456'
|
|
|
|
)
|
|
|
|
admin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def sign_in_as_user(options={}, &block)
|
2009-10-19 22:31:33 -04:00
|
|
|
user = create_user(options)
|
2010-02-16 10:11:30 -05:00
|
|
|
get new_user_session_path unless options[:visit] == false
|
2009-10-11 09:49:25 -04:00
|
|
|
fill_in 'email', :with => 'user@test.com'
|
2010-03-28 17:09:28 -04:00
|
|
|
fill_in 'password', :with => options[:password] || '123456'
|
2009-10-19 22:31:33 -04:00
|
|
|
check 'remember me' if options[:remember_me] == true
|
2009-10-11 09:49:25 -04:00
|
|
|
yield if block_given?
|
|
|
|
click_button 'Sign In'
|
2009-10-19 22:31:33 -04:00
|
|
|
user
|
2009-10-11 09:49:25 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def sign_in_as_admin(options={}, &block)
|
2009-10-19 22:31:33 -04:00
|
|
|
admin = create_admin(options)
|
2010-02-16 10:11:30 -05:00
|
|
|
get new_admin_session_path unless options[:visit] == false
|
2009-10-11 09:49:25 -04:00
|
|
|
fill_in 'email', :with => 'admin@test.com'
|
2009-10-07 20:46:40 -04:00
|
|
|
fill_in 'password', :with => '123456'
|
|
|
|
yield if block_given?
|
|
|
|
click_button 'Sign In'
|
2009-10-19 22:31:33 -04:00
|
|
|
admin
|
2009-10-07 20:46:40 -04:00
|
|
|
end
|
2009-10-11 22:24:57 -04:00
|
|
|
|
|
|
|
# Fix assert_redirect_to in integration sessions because they don't take into
|
|
|
|
# account Middleware redirects.
|
|
|
|
#
|
|
|
|
def assert_redirected_to(url)
|
|
|
|
assert [301, 302].include?(@integration_session.status),
|
|
|
|
"Expected status to be 301 or 302, got #{@integration_session.status}"
|
|
|
|
|
|
|
|
url = prepend_host(url)
|
|
|
|
location = prepend_host(@integration_session.headers["Location"])
|
|
|
|
assert_equal url, location
|
|
|
|
end
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def prepend_host(url)
|
|
|
|
url = "http://#{request.host}#{url}" if url[0] == ?/
|
|
|
|
url
|
|
|
|
end
|
|
|
|
|
2009-10-07 20:46:40 -04:00
|
|
|
end
|