Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
branch: master
Fetching contributors…

Cannot retrieve contributors at this time

110 lines (93 sloc) 3.485 kb
require File.dirname(__FILE__) + '/../test_helper'
class AuthenticatedUserTest < Test::Unit::TestCase
# Be sure to include AuthenticatedTestHelper in test/test_helper.rb instead.
# Then, you can remove it from this and the functional test.
include AuthenticatedTestHelper
scenario :user_authentication, :root => false
def test_should_create_user
assert_difference 'User.count' do
user = create_user
assert !user.new_record?, "#{user.errors.full_messages.to_sentence}"
end
end
def test_should_require_name
assert_no_difference 'User.count' do
u = create_user(:name => nil)
assert u.errors.on(:name)
end
end
def test_should_require_login
assert_no_difference 'User.count' do
u = create_user(:login => nil)
assert u.errors.on(:login)
end
end
def test_should_require_password
assert_no_difference 'User.count' do
u = create_user(:password => nil)
assert u.errors.on(:password)
end
end
def test_should_require_password_confirmation
assert_no_difference 'User.count' do
u = create_user(:password_confirmation => nil)
assert u.errors.on(:password_confirmation)
end
end
def test_should_require_email
assert_no_difference 'User.count' do
u = create_user(:email => nil)
assert u.errors.on(:email)
end
end
def test_should_reset_password
users(:quentin).update_attributes(:password => 'new password', :password_confirmation => 'new password')
assert_equal users(:quentin), User.authenticate('quentin', 'new password')
end
def test_should_not_rehash_password
users(:quentin).update_attributes(:login => 'quentin2')
assert_equal users(:quentin), User.authenticate('quentin2', 'test')
end
def test_should_authenticate_user
assert_equal users(:quentin), User.authenticate('quentin', 'test')
end
def test_should_set_remember_token
users(:quentin).remember_me
assert_not_nil users(:quentin).remember_token
assert_not_nil users(:quentin).remember_token_expires_at
end
def test_should_unset_remember_token
users(:quentin).remember_me
assert_not_nil users(:quentin).remember_token
users(:quentin).forget_me
assert_nil users(:quentin).remember_token
end
def test_should_remember_me_for_one_week
before = 1.week.from_now.utc
users(:quentin).remember_me_for 1.week
after = 1.week.from_now.utc
assert_not_nil users(:quentin).remember_token
assert_not_nil users(:quentin).remember_token_expires_at
assert users(:quentin).remember_token_expires_at.between?(before, after)
end
def test_should_remember_me_until_one_week
time = 1.week.from_now.utc
users(:quentin).remember_me_until time
assert_not_nil users(:quentin).remember_token
assert_not_nil users(:quentin).remember_token_expires_at
assert_equal users(:quentin).remember_token_expires_at, time
end
def test_should_remember_me_default_two_weeks
before = 2.weeks.from_now.utc
users(:quentin).remember_me
after = 2.weeks.from_now.utc
assert_not_nil users(:quentin).remember_token
assert_not_nil users(:quentin).remember_token_expires_at
assert users(:quentin).remember_token_expires_at.between?(before, after)
end
protected
def create_user(options = {})
User.create({ :name => 'Quire', :login => 'quire', :email => 'quire@example.com',
:password => 'quire', :password_confirmation => 'quire' }.merge(options))
end
end
Jump to Line
Something went wrong with that request. Please try again.