devise_token_auth 0.1.43 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/README.md +42 -895
- data/Rakefile +11 -4
- data/app/controllers/devise_token_auth/application_controller.rb +19 -8
- data/app/controllers/devise_token_auth/concerns/resource_finder.rb +26 -12
- data/app/controllers/devise_token_auth/concerns/set_user_by_token.rb +106 -85
- data/app/controllers/devise_token_auth/confirmations_controller.rb +73 -17
- data/app/controllers/devise_token_auth/omniauth_callbacks_controller.rb +95 -51
- data/app/controllers/devise_token_auth/passwords_controller.rb +65 -57
- data/app/controllers/devise_token_auth/registrations_controller.rb +61 -61
- data/app/controllers/devise_token_auth/sessions_controller.rb +22 -18
- data/app/controllers/devise_token_auth/token_validations_controller.rb +5 -3
- data/app/controllers/devise_token_auth/unlocks_controller.rb +20 -16
- data/app/models/devise_token_auth/concerns/active_record_support.rb +14 -0
- data/app/models/devise_token_auth/concerns/confirmable_support.rb +28 -0
- data/app/models/devise_token_auth/concerns/mongoid_support.rb +19 -0
- data/app/models/devise_token_auth/concerns/tokens_serialization.rb +31 -0
- data/app/models/devise_token_auth/concerns/user.rb +92 -100
- data/app/models/devise_token_auth/concerns/user_omniauth_callbacks.rb +8 -3
- data/app/validators/{email_validator.rb → devise_token_auth_email_validator.rb} +5 -3
- data/app/views/devise_token_auth/omniauth_external_window.html.erb +1 -1
- data/config/locales/da-DK.yml +11 -9
- data/config/locales/de.yml +2 -0
- data/config/locales/en.yml +10 -0
- data/config/locales/es.yml +2 -0
- data/config/locales/fr.yml +2 -0
- data/config/locales/he.yml +52 -0
- data/config/locales/it.yml +2 -0
- data/config/locales/ja.yml +4 -2
- data/config/locales/ko.yml +51 -0
- data/config/locales/nl.yml +2 -0
- data/config/locales/pl.yml +6 -3
- data/config/locales/pt-BR.yml +2 -0
- data/config/locales/pt.yml +6 -3
- data/config/locales/ro.yml +2 -0
- data/config/locales/ru.yml +2 -0
- data/config/locales/sq.yml +2 -0
- data/config/locales/sv.yml +52 -0
- data/config/locales/uk.yml +2 -0
- data/config/locales/vi.yml +2 -0
- data/config/locales/zh-CN.yml +2 -0
- data/config/locales/zh-HK.yml +2 -0
- data/config/locales/zh-TW.yml +2 -0
- data/lib/devise_token_auth/blacklist.rb +6 -0
- data/lib/devise_token_auth/controllers/helpers.rb +21 -13
- data/lib/devise_token_auth/controllers/url_helpers.rb +2 -0
- data/lib/devise_token_auth/engine.rb +26 -14
- data/lib/devise_token_auth/errors.rb +8 -0
- data/lib/devise_token_auth/rails/routes.rb +37 -30
- data/lib/devise_token_auth/token_factory.rb +126 -0
- data/lib/devise_token_auth/url.rb +11 -4
- data/lib/devise_token_auth/version.rb +3 -1
- data/lib/devise_token_auth.rb +11 -5
- data/lib/generators/devise_token_auth/USAGE +2 -2
- data/lib/generators/devise_token_auth/install_generator.rb +36 -105
- data/lib/generators/devise_token_auth/install_generator_helpers.rb +98 -0
- data/lib/generators/devise_token_auth/install_mongoid_generator.rb +46 -0
- data/lib/generators/devise_token_auth/install_views_generator.rb +7 -5
- data/lib/generators/devise_token_auth/templates/devise_token_auth.rb +12 -0
- data/lib/generators/devise_token_auth/templates/devise_token_auth_create_users.rb.erb +8 -14
- data/lib/generators/devise_token_auth/templates/user.rb.erb +9 -0
- data/lib/generators/devise_token_auth/templates/user_mongoid.rb.erb +56 -0
- data/lib/tasks/devise_token_auth_tasks.rake +2 -0
- data/test/controllers/custom/custom_confirmations_controller_test.rb +5 -1
- data/test/controllers/custom/custom_omniauth_callbacks_controller_test.rb +4 -0
- data/test/controllers/custom/custom_passwords_controller_test.rb +6 -2
- data/test/controllers/custom/custom_registrations_controller_test.rb +17 -8
- data/test/controllers/custom/custom_sessions_controller_test.rb +7 -5
- data/test/controllers/custom/custom_token_validations_controller_test.rb +5 -3
- data/test/controllers/demo_group_controller_test.rb +4 -6
- data/test/controllers/demo_mang_controller_test.rb +3 -3
- data/test/controllers/demo_user_controller_test.rb +53 -25
- data/test/controllers/devise_token_auth/confirmations_controller_test.rb +159 -25
- data/test/controllers/devise_token_auth/omniauth_callbacks_controller_test.rb +117 -47
- data/test/controllers/devise_token_auth/passwords_controller_test.rb +309 -126
- data/test/controllers/devise_token_auth/registrations_controller_test.rb +65 -23
- data/test/controllers/devise_token_auth/sessions_controller_test.rb +93 -61
- data/test/controllers/devise_token_auth/token_validations_controller_test.rb +18 -6
- data/test/controllers/devise_token_auth/unlocks_controller_test.rb +24 -5
- data/test/controllers/overrides/confirmations_controller_test.rb +6 -2
- data/test/controllers/overrides/omniauth_callbacks_controller_test.rb +5 -1
- data/test/controllers/overrides/passwords_controller_test.rb +27 -29
- data/test/controllers/overrides/registrations_controller_test.rb +33 -27
- data/test/controllers/overrides/sessions_controller_test.rb +6 -4
- data/test/controllers/overrides/token_validations_controller_test.rb +5 -3
- data/test/dummy/app/active_record/confirmable_user.rb +11 -0
- data/test/dummy/app/{models → active_record}/lockable_user.rb +2 -0
- data/test/dummy/app/{models → active_record}/mang.rb +2 -0
- data/test/dummy/app/{models → active_record}/only_email_user.rb +2 -0
- data/test/dummy/app/{models → active_record}/scoped_user.rb +4 -2
- data/test/dummy/app/{models → active_record}/unconfirmable_user.rb +3 -2
- data/test/dummy/app/active_record/unregisterable_user.rb +9 -0
- data/test/dummy/app/active_record/user.rb +6 -0
- data/test/dummy/app/controllers/application_controller.rb +2 -0
- data/test/dummy/app/controllers/auth_origin_controller.rb +2 -0
- data/test/dummy/app/controllers/custom/confirmations_controller.rb +2 -2
- data/test/dummy/app/controllers/custom/omniauth_callbacks_controller.rb +2 -0
- data/test/dummy/app/controllers/custom/passwords_controller.rb +3 -4
- data/test/dummy/app/controllers/custom/registrations_controller.rb +3 -3
- data/test/dummy/app/controllers/custom/sessions_controller.rb +3 -3
- data/test/dummy/app/controllers/custom/token_validations_controller.rb +3 -3
- data/test/dummy/app/controllers/demo_group_controller.rb +2 -0
- data/test/dummy/app/controllers/demo_mang_controller.rb +2 -0
- data/test/dummy/app/controllers/demo_user_controller.rb +2 -0
- data/test/dummy/app/controllers/overrides/confirmations_controller.rb +8 -6
- data/test/dummy/app/controllers/overrides/omniauth_callbacks_controller.rb +5 -3
- data/test/dummy/app/controllers/overrides/passwords_controller.rb +10 -8
- data/test/dummy/app/controllers/overrides/registrations_controller.rb +5 -3
- data/test/dummy/app/controllers/overrides/sessions_controller.rb +12 -12
- data/test/dummy/app/controllers/overrides/token_validations_controller.rb +5 -5
- data/test/dummy/app/helpers/application_helper.rb +1029 -1036
- data/test/dummy/app/models/{user.rb → concerns/favorite_color.rb} +8 -7
- data/test/dummy/app/mongoid/confirmable_user.rb +52 -0
- data/test/dummy/app/mongoid/lockable_user.rb +38 -0
- data/test/dummy/app/mongoid/mang.rb +46 -0
- data/test/dummy/app/mongoid/only_email_user.rb +33 -0
- data/test/dummy/app/mongoid/scoped_user.rb +50 -0
- data/test/dummy/app/mongoid/unconfirmable_user.rb +44 -0
- data/test/dummy/app/mongoid/unregisterable_user.rb +47 -0
- data/test/dummy/app/mongoid/user.rb +49 -0
- data/test/dummy/app/views/layouts/application.html.erb +0 -2
- data/test/dummy/config/application.rb +26 -3
- data/test/dummy/config/boot.rb +8 -2
- data/test/dummy/config/environment.rb +3 -1
- data/test/dummy/config/environments/development.rb +5 -13
- data/test/dummy/config/environments/production.rb +2 -16
- data/test/dummy/config/environments/test.rb +3 -1
- data/test/dummy/config/initializers/backtrace_silencers.rb +2 -0
- data/test/dummy/config/initializers/cookies_serializer.rb +3 -1
- data/test/dummy/config/initializers/devise.rb +287 -0
- data/test/dummy/config/initializers/devise_token_auth.rb +37 -4
- data/test/dummy/config/initializers/figaro.rb +3 -1
- data/test/dummy/config/initializers/filter_parameter_logging.rb +2 -0
- data/test/dummy/config/initializers/inflections.rb +2 -0
- data/test/dummy/config/initializers/mime_types.rb +2 -0
- data/test/dummy/config/initializers/omniauth.rb +5 -2
- data/test/dummy/config/initializers/session_store.rb +2 -0
- data/test/dummy/config/initializers/wrap_parameters.rb +2 -0
- data/test/dummy/config/routes.rb +14 -29
- data/test/dummy/config/spring.rb +2 -0
- data/test/dummy/config.ru +5 -3
- data/test/dummy/db/migrate/20140715061447_devise_token_auth_create_users.rb +9 -14
- data/test/dummy/db/migrate/20140715061805_devise_token_auth_create_mangs.rb +8 -13
- data/test/dummy/db/migrate/20140829044006_add_operating_thetan_to_user.rb +2 -0
- data/test/dummy/db/migrate/20140916224624_add_favorite_color_to_mangs.rb +2 -0
- data/test/dummy/db/migrate/20141222035835_devise_token_auth_create_only_email_users.rb +6 -11
- data/test/dummy/db/migrate/20141222053502_devise_token_auth_create_unregisterable_users.rb +8 -13
- data/test/dummy/db/migrate/20150708104536_devise_token_auth_create_unconfirmable_users.rb +8 -13
- data/test/dummy/db/migrate/20160103235141_devise_token_auth_create_scoped_users.rb +8 -13
- data/test/dummy/db/migrate/20160629184441_devise_token_auth_create_lockable_users.rb +8 -13
- data/test/dummy/{tmp/generators/db/migrate/20171014052631_devise_token_auth_create_users.rb → db/migrate/20190924101113_devise_token_auth_create_confirmable_users.rb} +8 -14
- data/test/dummy/db/schema.rb +11 -71
- data/test/dummy/lib/migration_database_helper.rb +15 -1
- data/test/dummy/tmp/generators/app/controllers/application_controller.rb +6 -0
- data/test/dummy/tmp/generators/app/models/azpire/v1/human_resource/user.rb +56 -0
- data/test/dummy/tmp/generators/config/initializers/devise_token_auth.rb +12 -0
- data/test/factories/users.rb +41 -0
- data/test/lib/devise_token_auth/blacklist_test.rb +19 -0
- data/test/lib/devise_token_auth/rails/custom_routes_test.rb +29 -0
- data/test/lib/devise_token_auth/rails/routes_test.rb +87 -0
- data/test/lib/devise_token_auth/token_factory_test.rb +191 -0
- data/test/lib/devise_token_auth/url_test.rb +9 -7
- data/test/lib/generators/devise_token_auth/install_generator_test.rb +67 -37
- data/test/lib/generators/devise_token_auth/install_generator_with_namespace_test.rb +222 -0
- data/test/lib/generators/devise_token_auth/install_views_generator_test.rb +3 -1
- data/test/models/concerns/mongoid_support_test.rb +31 -0
- data/test/models/concerns/tokens_serialization_test.rb +104 -0
- data/test/models/confirmable_user_test.rb +35 -0
- data/test/models/only_email_user_test.rb +2 -8
- data/test/models/user_test.rb +18 -79
- data/test/support/controllers/routes.rb +43 -0
- data/test/test_helper.rb +83 -26
- metadata +153 -44
- data/config/initializers/devise.rb +0 -196
- data/lib/generators/devise_token_auth/templates/user.rb +0 -7
- data/test/dummy/app/models/evil_user.rb +0 -3
- data/test/dummy/app/models/nice_user.rb +0 -7
- data/test/dummy/app/models/unregisterable_user.rb +0 -7
- data/test/dummy/config/initializers/assets.rb +0 -8
- data/test/dummy/db/migrate/20140928231203_devise_token_auth_create_evil_users.rb +0 -64
- data/test/dummy/db/migrate/20150409095712_devise_token_auth_create_nice_users.rb +0 -61
- data/test/dummy/tmp/generators/app/models/user.rb +0 -11
- data/test/integration/navigation_test.rb +0 -10
@@ -0,0 +1,222 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'test_helper'
|
4
|
+
require 'fileutils'
|
5
|
+
require 'generators/devise_token_auth/install_generator' if DEVISE_TOKEN_AUTH_ORM == :active_record
|
6
|
+
require 'generators/devise_token_auth/install_mongoid_generator' if DEVISE_TOKEN_AUTH_ORM == :mongoid
|
7
|
+
|
8
|
+
module DeviseTokenAuth
|
9
|
+
class InstallGeneratorTest < Rails::Generators::TestCase
|
10
|
+
tests InstallGenerator if DEVISE_TOKEN_AUTH_ORM == :active_record
|
11
|
+
tests InstallMongoidGenerator if DEVISE_TOKEN_AUTH_ORM == :mongoid
|
12
|
+
destination Rails.root.join('tmp/generators')
|
13
|
+
|
14
|
+
# The namespaced user model for testing
|
15
|
+
let(:user_class) { 'Azpire::V1::HumanResource::User' }
|
16
|
+
let(:namespace_path) { user_class.underscore }
|
17
|
+
let(:table_name) { user_class.pluralize.underscore.gsub('/','_') }
|
18
|
+
|
19
|
+
describe 'user model with namespace, clean install' do
|
20
|
+
setup :prepare_destination
|
21
|
+
|
22
|
+
before do
|
23
|
+
run_generator %W[#{user_class} auth]
|
24
|
+
end
|
25
|
+
|
26
|
+
test 'user model (with namespace) is created, concern is included' do
|
27
|
+
assert_file "app/models/#{namespace_path}.rb" do |model|
|
28
|
+
assert_match(/include DeviseTokenAuth::Concerns::User/, model)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
test 'initializer is created' do
|
33
|
+
assert_file 'config/initializers/devise_token_auth.rb'
|
34
|
+
end
|
35
|
+
|
36
|
+
test 'subsequent runs raise no errors' do
|
37
|
+
run_generator %W[#{user_class} auth]
|
38
|
+
end
|
39
|
+
|
40
|
+
if DEVISE_TOKEN_AUTH_ORM == :active_record
|
41
|
+
test 'migration is created for user model with namespace' do
|
42
|
+
assert_migration "db/migrate/devise_token_auth_create_#{table_name}.rb"
|
43
|
+
end
|
44
|
+
|
45
|
+
test 'migration file for user model with namespace contains rails version' do
|
46
|
+
if Rails::VERSION::MAJOR >= 5
|
47
|
+
assert_migration "db/migrate/devise_token_auth_create_#{table_name}.rb", /#{Rails::VERSION::MAJOR}.#{Rails::VERSION::MINOR}/
|
48
|
+
else
|
49
|
+
assert_migration "db/migrate/devise_token_auth_create_#{table_name}.rb"
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
test 'add primary key type with rails 5 when specified in rails generator' do
|
54
|
+
run_generator %W[#{user_class} auth --primary_key_type=uuid --force]
|
55
|
+
if Rails::VERSION::MAJOR >= 5
|
56
|
+
assert_migration "db/migrate/devise_token_auth_create_#{table_name}.rb", /create_table\(:#{table_name}, id: :uuid\) do/
|
57
|
+
else
|
58
|
+
assert_migration "db/migrate/devise_token_auth_create_#{table_name}.rb", /create_table\(:#{table_name}\) do/
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
describe 'existing user model' do
|
65
|
+
setup :prepare_destination
|
66
|
+
|
67
|
+
before do
|
68
|
+
@dir = File.join(destination_root, 'app', 'models')
|
69
|
+
|
70
|
+
@fname = File.join(@dir, 'user.rb')
|
71
|
+
|
72
|
+
# make dir if not exists
|
73
|
+
FileUtils.mkdir_p(@dir)
|
74
|
+
|
75
|
+
case DEVISE_TOKEN_AUTH_ORM
|
76
|
+
when :active_record
|
77
|
+
# account for rails version 5
|
78
|
+
active_record_needle = (Rails::VERSION::MAJOR >= 5) ? 'ApplicationRecord' : 'ActiveRecord::Base'
|
79
|
+
|
80
|
+
@f = File.open(@fname, 'w') do |f|
|
81
|
+
f.write <<-RUBY
|
82
|
+
class User < #{active_record_needle}
|
83
|
+
|
84
|
+
def whatever
|
85
|
+
puts 'whatever'
|
86
|
+
end
|
87
|
+
end
|
88
|
+
RUBY
|
89
|
+
end
|
90
|
+
when :mongoid
|
91
|
+
@f = File.open(@fname, 'w') do |f|
|
92
|
+
f.write <<-'RUBY'
|
93
|
+
class User
|
94
|
+
|
95
|
+
def whatever
|
96
|
+
puts 'whatever'
|
97
|
+
end
|
98
|
+
end
|
99
|
+
RUBY
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
103
|
+
run_generator
|
104
|
+
end
|
105
|
+
|
106
|
+
test 'user concern is injected into existing model' do
|
107
|
+
assert_file 'app/models/user.rb' do |model|
|
108
|
+
assert_match(/include DeviseTokenAuth::Concerns::User/, model)
|
109
|
+
end
|
110
|
+
end
|
111
|
+
|
112
|
+
test 'subsequent runs do not modify file' do
|
113
|
+
run_generator
|
114
|
+
assert_file 'app/models/user.rb' do |model|
|
115
|
+
matches = model.scan(/include DeviseTokenAuth::Concerns::User/m).size
|
116
|
+
assert_equal 1, matches
|
117
|
+
end
|
118
|
+
end
|
119
|
+
end
|
120
|
+
|
121
|
+
describe 'routes' do
|
122
|
+
setup :prepare_destination
|
123
|
+
|
124
|
+
before do
|
125
|
+
@dir = File.join(destination_root, 'config')
|
126
|
+
|
127
|
+
@fname = File.join(@dir, 'routes.rb')
|
128
|
+
|
129
|
+
# make dir if not exists
|
130
|
+
FileUtils.mkdir_p(@dir)
|
131
|
+
|
132
|
+
@f = File.open(@fname, 'w') do |f|
|
133
|
+
f.write <<-RUBY
|
134
|
+
Rails.application.routes.draw do
|
135
|
+
patch '/chong', to: 'bong#index'
|
136
|
+
end
|
137
|
+
RUBY
|
138
|
+
end
|
139
|
+
|
140
|
+
run_generator %W[#{user_class} auth]
|
141
|
+
end
|
142
|
+
|
143
|
+
test 'route method for user model with namespace is appended to routes file' do
|
144
|
+
assert_file 'config/routes.rb' do |routes|
|
145
|
+
assert_match(/mount_devise_token_auth_for '#{user_class}', at: 'auth'/, routes)
|
146
|
+
end
|
147
|
+
end
|
148
|
+
|
149
|
+
test 'subsequent runs do not modify file' do
|
150
|
+
run_generator %W[#{user_class} auth]
|
151
|
+
assert_file 'config/routes.rb' do |routes|
|
152
|
+
matches = routes.scan(/mount_devise_token_auth_for '#{user_class}', at: 'auth'/m).size
|
153
|
+
assert_equal 1, matches
|
154
|
+
end
|
155
|
+
end
|
156
|
+
|
157
|
+
describe 'subsequent models' do
|
158
|
+
before do
|
159
|
+
run_generator %w[Mang mangs]
|
160
|
+
end
|
161
|
+
|
162
|
+
test 'route method is appended to routes file' do
|
163
|
+
assert_file 'config/routes.rb' do |routes|
|
164
|
+
assert_match(/mount_devise_token_auth_for 'Mang', at: 'mangs'/, routes)
|
165
|
+
end
|
166
|
+
end
|
167
|
+
|
168
|
+
test 'devise_for block is appended to routes file' do
|
169
|
+
assert_file 'config/routes.rb' do |routes|
|
170
|
+
assert_match(/as :mang do/, routes)
|
171
|
+
assert_match(/# Define routes for Mang within this block./, routes)
|
172
|
+
end
|
173
|
+
end
|
174
|
+
|
175
|
+
if DEVISE_TOKEN_AUTH_ORM == :active_record
|
176
|
+
test 'migration is created' do
|
177
|
+
assert_migration 'db/migrate/devise_token_auth_create_mangs.rb'
|
178
|
+
end
|
179
|
+
end
|
180
|
+
end
|
181
|
+
end
|
182
|
+
|
183
|
+
describe 'application controller' do
|
184
|
+
setup :prepare_destination
|
185
|
+
|
186
|
+
before do
|
187
|
+
@dir = File.join(destination_root, 'app', 'controllers')
|
188
|
+
|
189
|
+
@fname = File.join(@dir, 'application_controller.rb')
|
190
|
+
|
191
|
+
# make dir if not exists
|
192
|
+
FileUtils.mkdir_p(@dir)
|
193
|
+
|
194
|
+
@f = File.open(@fname, 'w') do |f|
|
195
|
+
f.write <<-RUBY
|
196
|
+
class ApplicationController < ActionController::Base
|
197
|
+
def whatever
|
198
|
+
'whatever'
|
199
|
+
end
|
200
|
+
end
|
201
|
+
RUBY
|
202
|
+
end
|
203
|
+
|
204
|
+
run_generator %W[#{user_class} auth]
|
205
|
+
end
|
206
|
+
|
207
|
+
test 'controller concern is appended to application controller' do
|
208
|
+
assert_file 'app/controllers/application_controller.rb' do |controller|
|
209
|
+
assert_match(/include DeviseTokenAuth::Concerns::SetUserByToken/, controller)
|
210
|
+
end
|
211
|
+
end
|
212
|
+
|
213
|
+
test 'subsequent runs do not modify file' do
|
214
|
+
run_generator %W[#{user_class} auth]
|
215
|
+
assert_file 'app/controllers/application_controller.rb' do |controller|
|
216
|
+
matches = controller.scan(/include DeviseTokenAuth::Concerns::SetUserByToken/m).size
|
217
|
+
assert_equal 1, matches
|
218
|
+
end
|
219
|
+
end
|
220
|
+
end
|
221
|
+
end
|
222
|
+
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'test_helper'
|
2
4
|
require 'fileutils'
|
3
5
|
require 'generators/devise_token_auth/install_views_generator'
|
@@ -14,7 +16,7 @@ module DeviseTokenAuth
|
|
14
16
|
run_generator
|
15
17
|
end
|
16
18
|
|
17
|
-
test
|
19
|
+
test 'files are copied' do
|
18
20
|
assert_file 'app/views/devise/mailer/reset_password_instructions.html.erb'
|
19
21
|
assert_file 'app/views/devise/mailer/confirmation_instructions.html.erb'
|
20
22
|
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'test_helper'
|
4
|
+
|
5
|
+
if DEVISE_TOKEN_AUTH_ORM == :mongoid
|
6
|
+
class DeviseTokenAuth::Concerns::MongoidSupportTest < ActiveSupport::TestCase
|
7
|
+
describe DeviseTokenAuth::Concerns::MongoidSupport do
|
8
|
+
before do
|
9
|
+
@user = create(:user)
|
10
|
+
end
|
11
|
+
|
12
|
+
describe '#as_json' do
|
13
|
+
test 'should be defined' do
|
14
|
+
assert @user.methods.include?(:as_json)
|
15
|
+
end
|
16
|
+
|
17
|
+
test 'should except _id attribute' do
|
18
|
+
refute @user.as_json.key?('_id')
|
19
|
+
end
|
20
|
+
|
21
|
+
test 'should return with id attribute' do
|
22
|
+
assert_equal @user._id.to_s, @user.as_json['id']
|
23
|
+
end
|
24
|
+
|
25
|
+
test 'should accept options' do
|
26
|
+
refute @user.as_json(except: [:created_at]).key?('created_at')
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,104 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
if DEVISE_TOKEN_AUTH_ORM == :active_record
|
4
|
+
describe 'DeviseTokenAuth::Concerns::TokensSerialization' do
|
5
|
+
let(:ts) { DeviseTokenAuth::Concerns::TokensSerialization }
|
6
|
+
let(:user) { FactoryBot.create(:user) }
|
7
|
+
let(:tokens) do
|
8
|
+
# Сreate all possible token's attributes combinations
|
9
|
+
user.create_token
|
10
|
+
2.times { user.create_new_auth_token(user.tokens.first[0]) }
|
11
|
+
user.create_new_auth_token
|
12
|
+
user.create_token
|
13
|
+
|
14
|
+
user.tokens
|
15
|
+
end
|
16
|
+
|
17
|
+
it 'is defined' do
|
18
|
+
assert_equal(ts.present?, true)
|
19
|
+
assert_kind_of(Module, ts)
|
20
|
+
end
|
21
|
+
|
22
|
+
describe '.load(json)' do
|
23
|
+
|
24
|
+
let(:json) { JSON.generate(tokens) }
|
25
|
+
|
26
|
+
let(:default) { {} }
|
27
|
+
|
28
|
+
it 'is defined' do
|
29
|
+
assert_respond_to(ts, :load)
|
30
|
+
end
|
31
|
+
|
32
|
+
it 'handles nil' do
|
33
|
+
assert_equal(ts.load(nil), default)
|
34
|
+
end
|
35
|
+
|
36
|
+
it 'handles string' do
|
37
|
+
assert_equal(ts.load(json), JSON.parse(json))
|
38
|
+
end
|
39
|
+
|
40
|
+
it 'returns object of undesirable class' do
|
41
|
+
assert_equal(ts.load([]), [])
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
describe '.dump(object)' do
|
46
|
+
let(:default) { 'null' }
|
47
|
+
|
48
|
+
it 'is defined' do
|
49
|
+
assert_respond_to(ts, :dump)
|
50
|
+
end
|
51
|
+
|
52
|
+
it 'handles nil' do
|
53
|
+
assert_equal(ts.dump(nil), default)
|
54
|
+
end
|
55
|
+
|
56
|
+
it 'handles empty hash' do
|
57
|
+
assert_equal(ts.dump({}), '{}')
|
58
|
+
end
|
59
|
+
|
60
|
+
it 'removes nil values' do
|
61
|
+
new_tokens = tokens.dup
|
62
|
+
new_tokens[new_tokens.first[0]][:kos] = nil
|
63
|
+
|
64
|
+
assert_equal(ts.dump(tokens), ts.dump(new_tokens))
|
65
|
+
end
|
66
|
+
|
67
|
+
describe 'updated_at' do
|
68
|
+
before do
|
69
|
+
@default_format = ::Time::DATE_FORMATS[:default]
|
70
|
+
::Time::DATE_FORMATS[:default] = 'imprecise format'
|
71
|
+
end
|
72
|
+
|
73
|
+
after do
|
74
|
+
::Time::DATE_FORMATS[:default] = @default_format
|
75
|
+
end
|
76
|
+
|
77
|
+
def updated_ats(tokens)
|
78
|
+
tokens.
|
79
|
+
values.
|
80
|
+
flat_map do |token|
|
81
|
+
[:updated_at, 'updated_at'].map do |key|
|
82
|
+
token[key]
|
83
|
+
end
|
84
|
+
end.
|
85
|
+
compact
|
86
|
+
end
|
87
|
+
|
88
|
+
it 'is defined' do
|
89
|
+
refute_empty updated_ats(tokens)
|
90
|
+
end
|
91
|
+
|
92
|
+
it 'uses iso8601' do
|
93
|
+
updated_ats(JSON.parse(ts.dump(tokens))).each do |updated_at|
|
94
|
+
Time.strptime(updated_at, '%Y-%m-%dT%H:%M:%SZ')
|
95
|
+
end
|
96
|
+
end
|
97
|
+
|
98
|
+
it 'does not rely on Time#to_s' do
|
99
|
+
refute_includes(updated_ats(tokens), 'imprecise format')
|
100
|
+
end
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'test_helper'
|
4
|
+
|
5
|
+
class ConfirmableUserTest < ActiveSupport::TestCase
|
6
|
+
describe ConfirmableUser do
|
7
|
+
describe 'creation' do
|
8
|
+
test 'email should be saved' do
|
9
|
+
@resource = create(:confirmable_user)
|
10
|
+
assert @resource.email.present?
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
describe 'updating email' do
|
15
|
+
test 'new email should be saved to unconfirmed_email' do
|
16
|
+
@resource = create(:confirmable_user, email: 'old_address@example.com')
|
17
|
+
@resource.update(email: 'new_address@example.com')
|
18
|
+
assert @resource.unconfirmed_email == 'new_address@example.com'
|
19
|
+
end
|
20
|
+
|
21
|
+
test 'old email should be kept in email' do
|
22
|
+
@resource = create(:confirmable_user, email: 'old_address@example.com')
|
23
|
+
@resource.update(email: 'new_address@example.com')
|
24
|
+
assert @resource.email == 'old_address@example.com'
|
25
|
+
end
|
26
|
+
|
27
|
+
test 'confirmation_token should be changed' do
|
28
|
+
@resource = create(:confirmable_user, email: 'old_address@example.com')
|
29
|
+
old_token = @resource.confirmation_token
|
30
|
+
@resource.update(email: 'new_address@example.com')
|
31
|
+
assert @resource.confirmation_token != old_token
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -1,15 +1,9 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'test_helper'
|
2
4
|
|
3
5
|
class OnlyEmailUserTest < ActiveSupport::TestCase
|
4
6
|
describe OnlyEmailUser do
|
5
|
-
test 'trackable is disabled' do
|
6
|
-
refute OnlyEmailUser.method_defined?(:sign_in_count)
|
7
|
-
refute OnlyEmailUser.method_defined?(:current_sign_in_at)
|
8
|
-
refute OnlyEmailUser.method_defined?(:last_sign_in_at)
|
9
|
-
refute OnlyEmailUser.method_defined?(:current_sign_in_ip)
|
10
|
-
refute OnlyEmailUser.method_defined?(:last_sign_in_ip)
|
11
|
-
end
|
12
|
-
|
13
7
|
test 'confirmable is disabled' do
|
14
8
|
refute OnlyEmailUser.method_defined?(:confirmation_token)
|
15
9
|
refute OnlyEmailUser.method_defined?(:confirmed_at)
|
data/test/models/user_test.rb
CHANGED
@@ -1,22 +1,19 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'test_helper'
|
2
4
|
|
3
5
|
class UserTest < ActiveSupport::TestCase
|
4
6
|
describe User do
|
5
|
-
before do
|
6
|
-
@password = Faker::Internet.password(10, 20)
|
7
|
-
@email = Faker::Internet.email
|
8
|
-
@success_url = Faker::Internet.url
|
9
|
-
@resource = User.new()
|
10
|
-
end
|
11
|
-
|
12
7
|
describe 'serialization' do
|
13
8
|
test 'hash should not include sensitive info' do
|
9
|
+
@resource = build(:user)
|
14
10
|
refute @resource.as_json[:tokens]
|
15
11
|
end
|
16
12
|
end
|
17
13
|
|
18
14
|
describe 'creation' do
|
19
15
|
test 'save fails if uid is missing' do
|
16
|
+
@resource = User.new
|
20
17
|
@resource.uid = nil
|
21
18
|
@resource.save
|
22
19
|
|
@@ -26,53 +23,35 @@ class UserTest < ActiveSupport::TestCase
|
|
26
23
|
|
27
24
|
describe 'email registration' do
|
28
25
|
test 'model should not save if email is blank' do
|
29
|
-
@resource
|
30
|
-
@resource.password = @password
|
31
|
-
@resource.password_confirmation = @password
|
26
|
+
@resource = build(:user, email: nil)
|
32
27
|
|
33
28
|
refute @resource.save
|
34
|
-
assert @resource.errors.messages[:email] == [I18n.t(
|
29
|
+
assert @resource.errors.messages[:email] == [I18n.t('errors.messages.blank')]
|
35
30
|
end
|
36
31
|
|
37
32
|
test 'model should not save if email is not an email' do
|
38
|
-
@resource
|
39
|
-
@resource.email = '@example.com'
|
40
|
-
@resource.password = @password
|
41
|
-
@resource.password_confirmation = @password
|
33
|
+
@resource = build(:user, email: '@example.com')
|
42
34
|
|
43
35
|
refute @resource.save
|
44
|
-
assert @resource.errors.messages[:email] == [I18n.t(
|
36
|
+
assert @resource.errors.messages[:email] == [I18n.t('errors.messages.not_email')]
|
45
37
|
end
|
46
38
|
end
|
47
39
|
|
48
40
|
describe 'email uniqueness' do
|
49
41
|
test 'model should not save if email is taken' do
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
email: @email,
|
54
|
-
provider: provider,
|
55
|
-
password: @password,
|
56
|
-
password_confirmation: @password
|
57
|
-
)
|
58
|
-
|
59
|
-
@resource.email = @email
|
60
|
-
@resource.provider = provider
|
61
|
-
@resource.password = @password
|
62
|
-
@resource.password_confirmation = @password
|
42
|
+
user_attributes = attributes_for(:user)
|
43
|
+
create(:user, user_attributes)
|
44
|
+
@resource = build(:user, user_attributes)
|
63
45
|
|
64
46
|
refute @resource.save
|
65
|
-
assert @resource.errors.messages[:email]
|
47
|
+
assert @resource.errors.messages[:email].first.include? 'taken'
|
66
48
|
assert @resource.errors.messages[:email].none? { |e| e =~ /translation missing/ }
|
67
49
|
end
|
68
50
|
end
|
69
51
|
|
70
52
|
describe 'oauth2 authentication' do
|
71
53
|
test 'model should save even if email is blank' do
|
72
|
-
@resource
|
73
|
-
@resource.uid = 123
|
74
|
-
@resource.password = @password
|
75
|
-
@resource.password_confirmation = @password
|
54
|
+
@resource = build(:user, :facebook, email: nil)
|
76
55
|
|
77
56
|
assert @resource.save
|
78
57
|
assert @resource.errors.messages[:email].blank?
|
@@ -81,9 +60,7 @@ class UserTest < ActiveSupport::TestCase
|
|
81
60
|
|
82
61
|
describe 'token expiry' do
|
83
62
|
before do
|
84
|
-
@resource =
|
85
|
-
@resource.skip_confirmation!
|
86
|
-
@resource.save!
|
63
|
+
@resource = create(:user, :confirmed)
|
87
64
|
|
88
65
|
@auth_headers = @resource.create_new_auth_token
|
89
66
|
|
@@ -94,50 +71,14 @@ class UserTest < ActiveSupport::TestCase
|
|
94
71
|
test 'should properly indicate whether token is current' do
|
95
72
|
assert @resource.token_is_current?(@token, @client_id)
|
96
73
|
# we want to update the expiry without forcing a cleanup (see below)
|
97
|
-
@resource.tokens[@client_id]['expiry'] = Time.now.to_i - 10.seconds
|
74
|
+
@resource.tokens[@client_id]['expiry'] = Time.zone.now.to_i - 10.seconds
|
98
75
|
refute @resource.token_is_current?(@token, @client_id)
|
99
76
|
end
|
100
77
|
end
|
101
78
|
|
102
|
-
describe 'user specific token lifespan' do
|
103
|
-
before do
|
104
|
-
@resource = users(:confirmed_email_user)
|
105
|
-
@resource.skip_confirmation!
|
106
|
-
@resource.save!
|
107
|
-
|
108
|
-
auth_headers = @resource.create_new_auth_token
|
109
|
-
@token_global = auth_headers['access-token']
|
110
|
-
@client_id_global = auth_headers['client']
|
111
|
-
|
112
|
-
def @resource.token_lifespan
|
113
|
-
1.minute
|
114
|
-
end
|
115
|
-
|
116
|
-
auth_headers = @resource.create_new_auth_token
|
117
|
-
@token_specific = auth_headers['access-token']
|
118
|
-
@client_id_specific = auth_headers['client']
|
119
|
-
end
|
120
|
-
|
121
|
-
test 'works per user' do
|
122
|
-
assert @resource.token_is_current?(@token_global, @client_id_global)
|
123
|
-
|
124
|
-
time = Time.now.to_i
|
125
|
-
expiry_global = @resource.tokens[@client_id_global]['expiry']
|
126
|
-
|
127
|
-
assert expiry_global > time + DeviseTokenAuth.token_lifespan - 5.seconds
|
128
|
-
assert expiry_global < time + DeviseTokenAuth.token_lifespan + 5.seconds
|
129
|
-
|
130
|
-
expiry_specific = @resource.tokens[@client_id_specific]['expiry']
|
131
|
-
assert expiry_specific > time + 55.seconds
|
132
|
-
assert expiry_specific < time + 65.seconds
|
133
|
-
end
|
134
|
-
end
|
135
|
-
|
136
79
|
describe 'expired tokens are destroyed on save' do
|
137
80
|
before do
|
138
|
-
@resource =
|
139
|
-
@resource.skip_confirmation!
|
140
|
-
@resource.save!
|
81
|
+
@resource = create(:user, :confirmed)
|
141
82
|
|
142
83
|
@old_auth_headers = @resource.create_new_auth_token
|
143
84
|
@new_auth_headers = @resource.create_new_auth_token
|
@@ -149,15 +90,13 @@ class UserTest < ActiveSupport::TestCase
|
|
149
90
|
end
|
150
91
|
|
151
92
|
test 'current token was not removed' do
|
152
|
-
assert @resource.tokens[@new_auth_headers[
|
93
|
+
assert @resource.tokens[@new_auth_headers['client']]
|
153
94
|
end
|
154
95
|
end
|
155
96
|
|
156
97
|
describe 'nil tokens are handled properly' do
|
157
98
|
before do
|
158
|
-
@resource =
|
159
|
-
@resource.skip_confirmation!
|
160
|
-
@resource.save!
|
99
|
+
@resource = create(:user, :confirmed)
|
161
100
|
end
|
162
101
|
|
163
102
|
test 'tokens can be set to nil' do
|
@@ -0,0 +1,43 @@
|
|
1
|
+
class Module
|
2
|
+
include Minitest::Spec::DSL
|
3
|
+
end
|
4
|
+
|
5
|
+
module ControllerRoutesAfterBlock
|
6
|
+
after do
|
7
|
+
Rails.application.reload_routes!
|
8
|
+
end
|
9
|
+
end
|
10
|
+
|
11
|
+
module CustomControllersRoutes
|
12
|
+
include ControllerRoutesAfterBlock
|
13
|
+
|
14
|
+
before do
|
15
|
+
Rails.application.routes.draw do
|
16
|
+
mount_devise_token_auth_for 'User', at: 'nice_user_auth', controllers: {
|
17
|
+
registrations: 'custom/registrations',
|
18
|
+
confirmations: 'custom/confirmations',
|
19
|
+
passwords: 'custom/passwords',
|
20
|
+
sessions: 'custom/sessions',
|
21
|
+
token_validations: 'custom/token_validations',
|
22
|
+
omniauth_callbacks: 'custom/omniauth_callbacks'
|
23
|
+
}
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
module OverridesControllersRoutes
|
29
|
+
include ControllerRoutesAfterBlock
|
30
|
+
|
31
|
+
before do
|
32
|
+
Rails.application.routes.draw do
|
33
|
+
mount_devise_token_auth_for 'User', at: 'evil_user_auth', controllers: {
|
34
|
+
confirmations: 'overrides/confirmations',
|
35
|
+
passwords: 'overrides/passwords',
|
36
|
+
omniauth_callbacks: 'overrides/omniauth_callbacks',
|
37
|
+
registrations: 'overrides/registrations',
|
38
|
+
sessions: 'overrides/sessions',
|
39
|
+
token_validations: 'overrides/token_validations'
|
40
|
+
}
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|