public
Description: Host your Google AppEngine apps on your own server.
Homepage: http://appdrop.com
Clone URL: git://github.com/jchris/appdrop.git
appdrop / spec / models / authenticated_base_spec.rb
100644 80 lines (62 sloc) 2.737 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
require File.dirname(__FILE__) + '/../spec_helper'
 
describe "A User abstract class" do
 
  it "should have valid associations" do
    User.new.should have_valid_associations
  end
 
end
 
describe "An existing user" do
  before(:each) do
    @user = User.create!(:nickname => 'le quentin', :password => 'monkey', :password_confirmation => 'monkey', :email => 'test@foo.bar')
    @store.stub!(:buyers).and_return(User)
  end
  
  it "should authenticate with new or reset password" do
    @user.update_attributes(:password => 'new password', :password_confirmation => 'new password')
    User.authenticate('test@foo.bar', 'new password').should == @user
  end
  
  it "should not rehash password on login change" do
    @user.update_attributes(:email => 'test2@foo.bar')
    User.authenticate('test2@foo.bar', 'monkey').should == @user
  end
  
  it "should remember token" do
    @user.should_not be_remember_token
    lambda{ @user.remember_me }.should change( @user, :remember_token).from(nil)
    @user.remember_token_expires_at.should_not be_nil
    @user.should be_remember_token
  end
  
  it "should increment hit counter" do
    lambda{ @user.remember_me }.should change( @user, :visits_count).from(0).to(1)
  end
  
  it "should forget token" do
    lambda{ @user.remember_me }.should change( @user, :remember_token).from(nil)
    @user.should be_remember_token
 
    lambda{ @user.forget_me }.should change( @user, :remember_token).to(nil)
    @user.should_not be_remember_token
  end
 
  it "should be remembered for a period" do
    before = 1.week.from_now.utc
    lambda{ @user.remember_me_for 1.week }.should change(@user, :remember_token).from(nil)
    after = 1.week.from_now.utc
    @user.remember_token_expires_at.should be_between(before,after)
  end
end
 
# http://rashkovskii.com/files/user_spec.rb
describe "A new user" do
 
  it "should create" do
    lambda{ user = create_user ; user.should_not be_new_record }.should change(User,:count).by(1)
  end
  
  it "should require email" do
    lambda{ u = create_user(:email => nil) ; u.should have_at_least(1).errors_on(:email) }.
          should_not change(User,:count)
  end
  
  it "should require password" do
    lambda{ u = create_user(:password => nil) ; u.should have_at_least(1).errors_on(:password) }.
          should_not change(User,:count)
  end
 
  it "should require password confirmation" do
    lambda{ u = create_user(:password_confirmation => nil) ; u.should have_at_least(1).errors_on(:password_confirmation) }.
          should_not change(User,:count)
  end
 
  def create_user(options = {})
    User.create({ :nickname => 're quire', :email => 'quire@example.com', :password => 'quire', :password_confirmation => 'quire' }.merge(options))
  end
end