blob: 5b7b08a7d8b5851fb9e7a409df5458adb88f7938 (
plain)
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
require File.dirname(__FILE__) + '/../spec_helper'
describe User, " when authenticating" do
before do
@empty_user = User.new
@full_user = User.new
@full_user.name = "Sensible User"
@full_user.password = "foolishpassword"
@full_user.email = "sensible@localhost"
@full_user.save
end
it "should create a hashed password when the password is set" do
@empty_user.hashed_password.should be_nil
@empty_user.password = "a test password"
@empty_user.hashed_password.should_not be_nil
end
it "should have errors when given the wrong password" do
found_user = User.authenticate_from_form({ :email => "sensible@localhost", :password => "iownzyou" })
found_user.errors.size.should > 0
end
it "should not find the user when given the wrong email" do
found_user = User.authenticate_from_form( { :email => "soccer@localhost", :password => "foolishpassword" })
found_user.errors.size.should > 0
end
it "should find the user when given the right email and password" do
found_user = User.authenticate_from_form( { :email => "sensible@localhost", :password => "foolishpassword" })
found_user.errors.size.should == 0
found_user.should == (@full_user)
end
end
describe User, " when saving" do
before do
@user = User.new
end
it "should not save without setting some parameters" do
lambda { @user.save! }.should raise_error(ActiveRecord::RecordInvalid)
end
it "should not save with misformatted email" do
@user.name = "Mr. Silly"
@user.password = "insecurepassword"
@user.email = "mousefooble"
@user.should have(1).error_on(:email)
end
it "should not allow an email address as a name" do
@user.name = "silly@example.com"
@user.email = "silly@example.com"
@user.password = "insecurepassword"
@user.should have(1).error_on(:name)
end
it "should not save with no password" do
@user.name = "Mr. Silly"
@user.password = ""
@user.email = "silly@localhost"
@user.should have(1).error_on(:hashed_password)
end
it "should save with reasonable name, password and email" do
@user.name = "Mr. Reasonable"
@user.password = "insecurepassword"
@user.email = "reasonable@localhost"
@user.save!
end
it "should let you make two users with same name" do
@user.name = "Mr. Flobble"
@user.password = "insecurepassword"
@user.email = "flobble@localhost"
@user.save!
@user2 = User.new
@user2.name = "Mr. Flobble"
@user2.password = "insecurepassword"
@user2.email = "flobble2@localhost"
@user2.save!
end
end
describe User, "when checking abilities" do
fixtures :users
before do
@user = users(:bob_smith_user)
end
it "should not get admin links" do
@user.admin_page_links?.should be_false
end
it "should be able to file requests" do
@user.can_file_requests?.should be_true
end
end
describe User, 'when asked if a user has the ability to edit "requires admin" requests' do
before do
@mock_user = mock_model(User)
end
it 'should return false if no user is passed' do
User.requires_admin_power?(nil).should be_false
end
it 'should return true if the user has "requires admin" power' do
@mock_user.stub!(:requires_admin_power?).and_return true
User.requires_admin_power?(@mock_user).should be_true
end
it 'should return false if the user does not have "requires admin" power' do
@mock_user.stub!(:requires_admin_power?).and_return false
User.requires_admin_power?(@mock_user).should be_false
end
end
|