Skip to content

Commit

Permalink
Allow tokens to be set to nil before save
Browse files Browse the repository at this point in the history
  • Loading branch information
colavitam committed Jul 16, 2015
1 parent 9ea86bb commit f75f5d9
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 4 deletions.
10 changes: 6 additions & 4 deletions app/models/devise_token_auth/concerns/user.rb
Original file line number Diff line number Diff line change
Expand Up @@ -251,10 +251,12 @@ def sync_uid
end

def destroy_expired_tokens
self.tokens.delete_if{|cid,v|
expiry = v[:expiry] || v["expiry"]
DateTime.strptime(expiry.to_s, '%s') < Time.now
}
if self.tokens
self.tokens.delete_if do |cid, v|
expiry = v[:expiry] || v["expiry"]
DateTime.strptime(expiry.to_s, '%s') < Time.now
end
end
end

end
13 changes: 13 additions & 0 deletions test/models/user_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,19 @@ class UserTest < ActiveSupport::TestCase
end
end

describe 'nil tokens are handled properly' do
before do
@resource = users(:confirmed_email_user)
@resource.skip_confirmation!
@resource.save!
end

test 'tokens can be set to nil' do
@resource.tokens = nil
assert @resource.save
end
end

describe "#generate_url" do
test 'URI fragment should appear at the end of URL' do
params = {client_id: 123}
Expand Down

0 comments on commit f75f5d9

Please sign in to comment.