sorcery 0.8.5 → 0.8.6

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of sorcery might be problematic. Click here for more details.

Files changed (119) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +1 -0
  3. data/.travis.yml +60 -4
  4. data/CHANGELOG.md +15 -1
  5. data/Gemfile +9 -18
  6. data/Gemfile.rails4 +8 -10
  7. data/README.md +31 -11
  8. data/VERSION +1 -1
  9. data/gemfiles/active_record-rails41.gemfile +6 -0
  10. data/gemfiles/mongo_mapper-rails41.gemfile +8 -0
  11. data/gemfiles/mongoid-rails41.gemfile +11 -0
  12. data/lib/sorcery.rb +20 -28
  13. data/lib/sorcery/controller.rb +6 -11
  14. data/lib/sorcery/controller/submodules/external.rb +30 -15
  15. data/lib/sorcery/controller/submodules/session_timeout.rb +1 -1
  16. data/lib/sorcery/model.rb +102 -70
  17. data/lib/sorcery/model/adapters/active_record.rb +7 -2
  18. data/lib/sorcery/model/adapters/datamapper.rb +123 -0
  19. data/lib/sorcery/model/adapters/mongo_mapper.rb +8 -4
  20. data/lib/sorcery/model/adapters/mongoid.rb +6 -6
  21. data/lib/sorcery/model/submodules/activity_logging.rb +24 -0
  22. data/lib/sorcery/model/submodules/brute_force_protection.rb +16 -0
  23. data/lib/sorcery/model/submodules/remember_me.rb +19 -4
  24. data/lib/sorcery/model/submodules/reset_password.rb +30 -13
  25. data/lib/sorcery/model/submodules/user_activation.rb +53 -22
  26. data/lib/sorcery/{controller/submodules/external/protocols → protocols}/certs/ca-bundle.crt +0 -0
  27. data/lib/sorcery/protocols/oauth.rb +42 -0
  28. data/lib/sorcery/protocols/oauth2.rb +47 -0
  29. data/lib/sorcery/providers/base.rb +27 -0
  30. data/lib/sorcery/providers/facebook.rb +63 -0
  31. data/lib/sorcery/providers/github.rb +51 -0
  32. data/lib/sorcery/providers/google.rb +51 -0
  33. data/lib/sorcery/providers/linkedin.rb +66 -0
  34. data/lib/sorcery/providers/liveid.rb +53 -0
  35. data/lib/sorcery/providers/twitter.rb +59 -0
  36. data/lib/sorcery/providers/vk.rb +61 -0
  37. data/lib/sorcery/providers/xing.rb +64 -0
  38. data/lib/sorcery/test_helpers/internal.rb +3 -3
  39. data/lib/sorcery/test_helpers/internal/rails.rb +14 -3
  40. data/lib/sorcery/test_helpers/rails.rb +1 -10
  41. data/lib/sorcery/test_helpers/rails/controller.rb +17 -0
  42. data/lib/sorcery/test_helpers/rails/integration.rb +26 -0
  43. data/sorcery.gemspec +14 -18
  44. data/spec/active_record/controller_activity_logging_spec.rb +5 -116
  45. data/spec/active_record/controller_brute_force_protection_spec.rb +69 -47
  46. data/spec/active_record/controller_http_basic_auth_spec.rb +24 -18
  47. data/spec/active_record/controller_oauth2_spec.rb +112 -187
  48. data/spec/active_record/controller_oauth_spec.rb +41 -37
  49. data/spec/active_record/controller_remember_me_spec.rb +39 -38
  50. data/spec/active_record/controller_session_timeout_spec.rb +31 -16
  51. data/spec/active_record/controller_spec.rb +4 -178
  52. data/spec/active_record/integration_spec.rb +1 -1
  53. data/spec/active_record/user_activation_spec.rb +1 -1
  54. data/spec/active_record/user_activity_logging_spec.rb +1 -1
  55. data/spec/active_record/user_brute_force_protection_spec.rb +1 -1
  56. data/spec/active_record/user_oauth_spec.rb +1 -1
  57. data/spec/active_record/user_remember_me_spec.rb +1 -1
  58. data/spec/active_record/user_reset_password_spec.rb +1 -1
  59. data/spec/active_record/user_spec.rb +7 -8
  60. data/spec/datamapper/controller_activity_logging_spec.rb +17 -0
  61. data/spec/datamapper/controller_spec.rb +8 -0
  62. data/spec/datamapper/user_activation_spec.rb +10 -0
  63. data/spec/datamapper/user_activity_logging_spec.rb +9 -0
  64. data/spec/datamapper/user_brute_force_protection_spec.rb +9 -0
  65. data/spec/datamapper/user_oauth_spec.rb +9 -0
  66. data/spec/datamapper/user_remember_me_spec.rb +8 -0
  67. data/spec/datamapper/user_reset_password_spec.rb +8 -0
  68. data/spec/datamapper/user_spec.rb +27 -0
  69. data/spec/mongo_mapper/controller_spec.rb +4 -171
  70. data/spec/mongo_mapper/user_activation_spec.rb +1 -2
  71. data/spec/mongo_mapper/user_activity_logging_spec.rb +1 -1
  72. data/spec/mongo_mapper/user_brute_force_protection_spec.rb +1 -1
  73. data/spec/mongo_mapper/user_oauth_spec.rb +1 -1
  74. data/spec/mongo_mapper/user_remember_me_spec.rb +1 -1
  75. data/spec/mongo_mapper/user_reset_password_spec.rb +1 -1
  76. data/spec/mongo_mapper/user_spec.rb +7 -8
  77. data/spec/mongoid/controller_activity_logging_spec.rb +4 -99
  78. data/spec/mongoid/controller_spec.rb +4 -182
  79. data/spec/mongoid/user_activation_spec.rb +1 -2
  80. data/spec/mongoid/user_activity_logging_spec.rb +1 -2
  81. data/spec/mongoid/user_brute_force_protection_spec.rb +1 -2
  82. data/spec/mongoid/user_oauth_spec.rb +1 -2
  83. data/spec/mongoid/user_remember_me_spec.rb +1 -2
  84. data/spec/mongoid/user_reset_password_spec.rb +1 -2
  85. data/spec/mongoid/user_spec.rb +8 -9
  86. data/spec/orm/active_record.rb +2 -0
  87. data/spec/orm/datamapper.rb +34 -0
  88. data/spec/orm/mongo_mapper.rb +1 -0
  89. data/spec/orm/mongoid.rb +1 -0
  90. data/spec/rails_app/app/controllers/sorcery_controller.rb +64 -59
  91. data/spec/rails_app/app/datamapper/authentication.rb +8 -0
  92. data/spec/rails_app/app/datamapper/user.rb +7 -0
  93. data/spec/rails_app/config/routes.rb +18 -13
  94. data/spec/shared_examples/controller_activity_logging_shared_examples.rb +125 -0
  95. data/spec/shared_examples/controller_oauth2_shared_examples.rb +32 -36
  96. data/spec/shared_examples/controller_oauth_shared_examples.rb +19 -26
  97. data/spec/shared_examples/controller_shared_examples.rb +203 -0
  98. data/spec/shared_examples/user_activation_shared_examples.rb +107 -90
  99. data/spec/shared_examples/user_activity_logging_shared_examples.rb +10 -10
  100. data/spec/shared_examples/user_brute_force_protection_shared_examples.rb +14 -13
  101. data/spec/shared_examples/user_oauth_shared_examples.rb +23 -15
  102. data/spec/shared_examples/user_remember_me_shared_examples.rb +32 -23
  103. data/spec/shared_examples/user_reset_password_shared_examples.rb +136 -115
  104. data/spec/shared_examples/user_shared_examples.rb +206 -146
  105. data/spec/sorcery_crypto_providers_spec.rb +28 -28
  106. data/spec/spec_helper.rb +15 -6
  107. metadata +83 -127
  108. data/lib/sorcery/controller/submodules/external/protocols/oauth1.rb +0 -46
  109. data/lib/sorcery/controller/submodules/external/protocols/oauth2.rb +0 -50
  110. data/lib/sorcery/controller/submodules/external/providers/base.rb +0 -21
  111. data/lib/sorcery/controller/submodules/external/providers/facebook.rb +0 -99
  112. data/lib/sorcery/controller/submodules/external/providers/github.rb +0 -93
  113. data/lib/sorcery/controller/submodules/external/providers/google.rb +0 -92
  114. data/lib/sorcery/controller/submodules/external/providers/linkedin.rb +0 -103
  115. data/lib/sorcery/controller/submodules/external/providers/liveid.rb +0 -93
  116. data/lib/sorcery/controller/submodules/external/providers/twitter.rb +0 -94
  117. data/lib/sorcery/controller/submodules/external/providers/vk.rb +0 -101
  118. data/lib/sorcery/controller/submodules/external/providers/xing.rb +0 -98
  119. data/lib/sorcery/test_helpers.rb +0 -5
@@ -1,7 +1,7 @@
1
1
  require 'spec_helper'
2
2
  require 'shared_examples/user_reset_password_shared_examples'
3
3
 
4
- describe "User with reset_password submodule" do
4
+ describe User, "with reset_password submodule", :mongo_mapper => true do
5
5
 
6
6
  it_behaves_like "rails_3_reset_password_model"
7
7
 
@@ -1,16 +1,15 @@
1
1
  require 'spec_helper'
2
-
3
2
  require 'rails_app/app/mailers/sorcery_mailer'
4
3
  require 'shared_examples/user_shared_examples'
5
4
 
6
- describe "User with no submodules (core)" do
5
+ describe User, "with no submodules (core)", :mongo_mapper => true do
7
6
  before(:all) do
8
7
  sorcery_reload!
9
8
  end
10
9
 
11
10
  describe User, "when app has plugin loaded" do
12
- it "User should respond_to .authenticates_with_sorcery!" do
13
- User.should respond_to(:authenticates_with_sorcery!)
11
+ it "User responds to .authenticates_with_sorcery!" do
12
+ expect(User).to respond_to :authenticates_with_sorcery!
14
13
  end
15
14
  end
16
15
 
@@ -18,21 +17,21 @@ describe "User with no submodules (core)" do
18
17
 
19
18
  it_should_behave_like "rails_3_core_model"
20
19
 
21
- describe User, "external users" do
20
+ describe "external users" do
22
21
 
23
22
  it_should_behave_like "external_user"
24
23
 
25
24
  end
26
25
 
27
- describe User, "when inherited" do
28
- it "should inherit mongo_mapper keys" do
26
+ context "when inherited" do
27
+ it "inherits mongo_mapper keys" do
29
28
  User.class_eval do
30
29
  key :blabla
31
30
  end
32
31
  class SubUser < User
33
32
  end
34
33
 
35
- SubUser.keys.should include("blabla")
34
+ expect(SubUser.keys).to include("blabla")
36
35
  end
37
36
  end
38
37
  end
@@ -1,111 +1,16 @@
1
1
  require 'spec_helper'
2
+ require 'shared_examples/controller_activity_logging_shared_examples'
2
3
 
3
- describe SorceryController do
4
+ describe SorceryController, :mongoid => true do
4
5
 
5
6
  # ----------------- ACTIVITY LOGGING -----------------------
6
- describe SorceryController, "with activity logging features" do
7
- before(:all) do
8
- sorcery_reload!([:activity_logging])
9
- end
10
-
11
- before(:each) do
12
- create_new_user
13
- end
14
-
7
+ context "with activity logging features" do
15
8
  after(:each) do
16
9
  User.delete_all
17
10
  end
18
11
 
19
- specify { subject.should respond_to(:current_users) }
20
-
21
- it "'current_users' should be empty when no users are logged in" do
22
- subject.current_users.size.should == 0
23
- end
24
-
25
- it "should log login time on login" do
26
- now = Time.now.utc
27
- login_user
28
- @user.last_login_at.should_not be_nil
29
- @user.last_login_at.utc.to_s.should >= now.utc.to_s
30
- @user.last_login_at.utc.to_s.should <= (now.utc+2).to_s
31
- end
32
-
33
- it "should log logout time on logout" do
34
- login_user
35
- now = Time.now.utc
36
- logout_user
37
- User.first.last_logout_at.utc.should_not be_nil
38
- User.first.last_logout_at.utc.to_s.should >= now.utc.to_s
39
- User.first.last_logout_at.utc.to_s.should <= (now.utc+2).to_s
40
- end
41
-
42
- it "should log last activity time when logged in" do
43
- login_user
44
- now = Time.now.utc
45
- get :some_action
46
- User.first.last_activity_at.utc.should >= now.utc
47
- User.first.last_activity_at.utc.should <= (now.utc+2)
48
- end
49
-
50
- it "should log last IP address when logged in" do
51
- login_user
52
- get :some_action
53
- User.first.last_login_from_ip_address.should == "0.0.0.0"
54
- end
55
-
56
- it "should update nothing but activity fields" do
57
- original_user_name = User.first.username
58
- login_user
59
- get :some_action_making_a_non_persisted_change_to_the_user
60
- User.first.username.should == original_user_name
61
- end
62
-
63
- it "'current_users' should hold the user object when 1 user is logged in" do
64
- login_user
65
- get :some_action
66
- subject.current_users.size.should == 1
67
- subject.current_users[0].should == @user
68
- end
69
-
70
- it "'current_users' should show all current_users, whether they have logged out before or not." do
71
- user1 = create_new_user({:username => 'gizmo1', :email => "bla1@bla.com", :password => 'secret1'})
72
- login_user(user1)
73
- get :some_action
74
- clear_user_without_logout
75
- user2 = create_new_user({:username => 'gizmo2', :email => "bla2@bla.com", :password => 'secret2'})
76
- login_user(user2)
77
- get :some_action
78
- clear_user_without_logout
79
- user3 = create_new_user({:username => 'gizmo3', :email => "bla3@bla.com", :password => 'secret3'})
80
- login_user(user3)
81
- get :some_action
82
- subject.current_users.size.should == 3
83
- subject.current_users[0].should == user1
84
- subject.current_users[1].should == user2
85
- subject.current_users[2].should == user3
86
- end
87
-
88
- it "should not register login time if configured so" do
89
- sorcery_controller_property_set(:register_login_time, false)
90
- now = Time.now.in_time_zone
91
- login_user
92
- @user.last_login_at.should be_nil
93
- end
94
12
 
95
- it "should not register logout time if configured so" do
96
- sorcery_controller_property_set(:register_logout_time, false)
97
- now = Time.now.in_time_zone
98
- login_user
99
- logout_user
100
- @user.last_logout_at.should be_nil
101
- end
13
+ it_behaves_like "controller_activity_logging"
102
14
 
103
- it "should not register last activity time if configured so" do
104
- sorcery_controller_property_set(:register_last_activity_time, false)
105
- now = Time.now.in_time_zone
106
- login_user
107
- get :some_action
108
- @user.last_activity_at.should be_nil
109
- end
110
15
  end
111
16
  end
@@ -1,186 +1,8 @@
1
1
  require 'spec_helper'
2
+ require 'shared_examples/controller_shared_examples'
2
3
 
3
- describe SorceryController do
4
-
5
- # ----------------- PLUGIN CONFIGURATION -----------------------
6
- describe SorceryController, "plugin configuration" do
7
- before(:all) do
8
- sorcery_reload!
9
- end
10
-
11
- after(:each) do
12
- Sorcery::Controller::Config.reset!
13
- sorcery_reload!
14
- end
15
-
16
- it "should enable configuration option 'user_class'" do
17
- sorcery_controller_property_set(:user_class, "TestUser")
18
- Sorcery::Controller::Config.user_class.should == "TestUser"
19
- end
20
-
21
- it "should enable configuration option 'not_authenticated_action'" do
22
- sorcery_controller_property_set(:not_authenticated_action, :my_action)
23
- Sorcery::Controller::Config.not_authenticated_action.should equal(:my_action)
24
- end
25
-
26
- end
27
-
28
- # ----------------- PLUGIN ACTIVATED -----------------------
29
- describe SorceryController, "when activated with sorcery" do
30
- before(:all) do
31
- sorcery_reload!
32
- User.delete_all
33
- end
34
-
35
- before(:each) do
36
- create_new_user
37
- end
38
-
39
- after(:each) do
40
- Sorcery::Controller::Config.reset!
41
- sorcery_reload!
42
- User.delete_all
43
- sorcery_controller_property_set(:user_class, User)
44
- sorcery_model_property_set(:username_attribute_names, [:username, :email])
45
- end
46
-
47
- specify { should respond_to(:login) }
48
-
49
- specify { should respond_to(:logout) }
50
-
51
- specify { should respond_to(:logged_in?) }
52
-
53
- specify { should respond_to(:current_user) }
54
-
55
- it "login(username,password) should return the user when success and set the session with user.id" do
56
- get :test_login, :email => 'bla@bla.com', :password => 'secret'
57
- assigns[:user].should == @user
58
- session[:user_id].should == @user.id
59
- end
60
-
61
- it "login(email,password) should return the user when success and set the session with user.id" do
62
- get :test_login, :email => 'bla@bla.com', :password => 'secret'
63
- assigns[:user].should == @user
64
- session[:user_id].should == @user.id
65
- end
66
-
67
- it "login(username,password) should return nil and not set the session when failure" do
68
- get :test_login, :email => 'bla@bla.com', :password => 'opensesame!'
69
- assigns[:user].should be_nil
70
- session[:user_id].should be_nil
71
- end
72
-
73
- it "login(username,password) should return nil and not set the session when upper case username" do
74
- get :test_login, :email => 'BLA@BLA.com', :password => 'secret'
75
- assigns[:user].should be_nil
76
- session[:user_id].should be_nil
77
- end
78
-
79
- it "login(email,password) should return the user when success and set the session with the _csrf_token" do
80
- get :test_login, :email => 'bla@bla.com', :password => 'secret'
81
- session[:_csrf_token].should_not be_nil
82
- end
83
-
84
- it "login(username,password) should return the user and set the session with user.id when upper case username and config is downcase before authenticating" do
85
- sorcery_model_property_set(:downcase_username_before_authenticating, true)
86
- get :test_login, :email => 'bla@bla.com', :password => 'secret'
87
- assigns[:user].should == @user
88
- session[:user_id].should == @user.id
89
- end
90
-
91
- it "login(username,password) should return nil and not set the session when user was created with upper case username, config is default, and log in username is lower case" do
92
- create_new_user({:username => 'GIZMO1', :email => "BLA1@BLA.com", :password => 'secret1'})
93
- get :test_login, :email => 'bla1@bla.com', :password => 'secret1'
94
- assigns[:user].should be_nil
95
- session[:user_id].should be_nil
96
- end
97
-
98
- it "login(username,password) should return the user and set the session with user.id when user was created with upper case username and config is downcase before authenticating" do
99
- sorcery_model_property_set(:downcase_username_before_authenticating, true)
100
- create_new_user({:username => 'GIZMO1', :email => "bla1@bla.com", :password => 'secret1'})
101
- get :test_login, :email => 'bla1@bla.com', :password => 'secret1'
102
- assigns[:user].should == @user
103
- session[:user_id].should == @user.id
104
- end
105
-
106
- it "logout should clear the session" do
107
- cookies[:remember_me_token] = nil
108
- session[:user_id] = @user.id
109
- get :test_logout
110
- session[:user_id].should be_nil
111
- end
112
-
113
- it "logged_in? should return true if logged in" do
114
- session[:user_id] = @user.id
115
- subject.logged_in?.should be_true
116
- end
117
-
118
- it "logged_in? should return false if not logged in" do
119
- session[:user_id] = nil
120
- subject.logged_in?.should be_false
121
- end
122
-
123
- it "current_user should return the user instance if logged in" do
124
- create_new_user
125
- session[:user_id] = @user.id
126
- subject.current_user.should == @user
127
- end
128
-
129
- it "current_user should return false if not logged in" do
130
- session[:user_id] = nil
131
- subject.current_user.should == false
132
- end
133
-
134
- specify { should respond_to(:require_login) }
135
-
136
- it "should call the configured 'not_authenticated_action' when session[:user_id] isn't found" do
137
- # If someone passes in a bogus user_id than no big deal, but if a user is deleted
138
- # and there is still an active session out there for him this causes problems.
139
- user = User.create(:email => 'test@example.com', :password => 'password')
140
- session[:user_id] = user.id
141
- user.destroy
142
- sorcery_controller_property_set(:not_authenticated_action, :test_not_authenticated_action)
143
- get :test_logout
144
- response.body.should == "test_not_authenticated_action"
145
- end
146
-
147
- it "should call the configured 'not_authenticated_action' when authenticate before_filter fails" do
148
- session[:user_id] = nil
149
- sorcery_controller_property_set(:not_authenticated_action, :test_not_authenticated_action)
150
- get :test_logout
151
- response.body.should == "test_not_authenticated_action"
152
- end
153
-
154
- it "require_login before_filter should save the url that the user originally wanted" do
155
- get :some_action
156
- session[:return_to_url].should == "http://test.host/some_action"
157
- response.should redirect_to("http://test.host/")
158
- end
159
-
160
- it "require_login before_filter should not save the url that the user originally wanted upon all non-get http methods" do
161
- [:post, :put, :delete].each do |m|
162
- self.send(m, :some_action)
163
- session[:return_to_url].should be_nil
164
- end
165
- end
166
-
167
- it "on successful login the user should be redirected to the url he originally wanted" do
168
- session[:return_to_url] = "http://test.host/some_action"
169
- post :test_return_to, :username => 'gizmo', :password => 'secret'
170
- response.should redirect_to("http://test.host/some_action")
171
- flash[:notice].should == "haha!"
172
- end
173
-
174
-
175
- # --- login_user(user) ---
176
- specify { should respond_to(:auto_login) }
177
-
178
- it "auto_login(user) should login a user instance" do
179
- create_new_user
180
- session[:user_id] = nil
181
- subject.auto_login(@user)
182
- subject.logged_in?.should be_true
183
- end
184
- end
4
+ describe SorceryController, :mongoid => true do
185
5
 
6
+ it_should_behave_like "sorcery_controller"
7
+
186
8
  end
@@ -1,9 +1,8 @@
1
1
  require 'spec_helper'
2
-
3
2
  require 'rails_app/app/mailers/sorcery_mailer'
4
3
  require 'shared_examples/user_activation_shared_examples'
5
4
 
6
- describe "User with activation submodule" do
5
+ describe User, "with activation submodule", :mongoid => true do
7
6
 
8
7
  it_behaves_like "rails_3_activation_model"
9
8
 
@@ -1,8 +1,7 @@
1
1
  require 'spec_helper'
2
-
3
2
  require 'shared_examples/user_activity_logging_shared_examples'
4
3
 
5
- describe "User with activity logging submodule" do
4
+ describe User, "with activity logging submodule", :mongoid => true do
6
5
 
7
6
  it_behaves_like "rails_3_activity_logging_model"
8
7
 
@@ -1,8 +1,7 @@
1
1
  require 'spec_helper'
2
-
3
2
  require 'shared_examples/user_brute_force_protection_shared_examples'
4
3
 
5
- describe "User with brute_force_protection submodule" do
4
+ describe User, "with brute_force_protection submodule", :mongoid => true do
6
5
 
7
6
  it_behaves_like "rails_3_brute_force_protection_model"
8
7
 
@@ -1,8 +1,7 @@
1
1
  require 'spec_helper'
2
-
3
2
  require 'shared_examples/user_oauth_shared_examples'
4
3
 
5
- describe "User with oauth submodule" do
4
+ describe User, "with oauth submodule", :mongoid => true do
6
5
 
7
6
  it_behaves_like "rails_3_oauth_model"
8
7
 
@@ -1,8 +1,7 @@
1
1
  require 'spec_helper'
2
-
3
2
  require 'shared_examples/user_remember_me_shared_examples'
4
3
 
5
- describe "User with remember_me submodule" do
4
+ describe User, "with remember_me submodule", :mongoid => true do
6
5
 
7
6
  it_behaves_like "rails_3_remember_me_model"
8
7
 
@@ -1,8 +1,7 @@
1
1
  require 'spec_helper'
2
-
3
2
  require 'shared_examples/user_reset_password_shared_examples'
4
3
 
5
- describe "User with reset_password submodule" do
4
+ describe User, "with reset_password submodule", :mongoid => true do
6
5
 
7
6
  it_behaves_like "rails_3_reset_password_model"
8
7
 
@@ -1,16 +1,15 @@
1
1
  require 'spec_helper'
2
-
3
2
  require 'rails_app/app/mailers/sorcery_mailer'
4
3
  require 'shared_examples/user_shared_examples'
5
4
 
6
- describe "User with no submodules (core)" do
5
+ describe User, "with no submodules (core)", :mongoid => true do
7
6
  before(:all) do
8
7
  sorcery_reload!
9
8
  end
10
9
 
11
- describe User, "when app has plugin loaded" do
12
- it "User should respond_to .authenticates_with_sorcery!" do
13
- User.should respond_to(:authenticates_with_sorcery!)
10
+ context "when app has plugin loaded" do
11
+ it "User responds to .authenticates_with_sorcery!" do
12
+ expect(User).to respond_to :authenticates_with_sorcery!
14
13
  end
15
14
  end
16
15
 
@@ -18,21 +17,21 @@ describe "User with no submodules (core)" do
18
17
 
19
18
  it_should_behave_like "rails_3_core_model"
20
19
 
21
- describe User, "external users" do
20
+ describe "external users" do
22
21
 
23
22
  it_should_behave_like "external_user"
24
23
 
25
24
  end
26
25
 
27
- describe User, "when inherited" do
28
- it "should inherit mongoid fields" do
26
+ context "when inherited" do
27
+ it "inherits mongoid fields" do
29
28
  User.class_eval do
30
29
  field :blabla
31
30
  end
32
31
  class SubUser < User
33
32
  end
34
33
 
35
- SubUser.fields.should include("blabla")
34
+ expect(SubUser.fields).to include("blabla")
36
35
  end
37
36
  end
38
37